# 1 Overview

# **About This Chapter**

Read this chapter to find out

- A general overview of the AIC-7850 host adapter chip
- Features of the AIC-7850 host adapter chip
- Reference documents applicable to the AIC-7850 host adapter chip

\* \* \* \* \* |

#### Introduction

The AIC-7850 provides advanced host adapter features in a single chip with a SCSI-2 bus controller and a full featured PCI 32-bit bus master with zero wait state transfer capability including PCI enhanced data transfer commands. The AIC-7850 chip incorporates a dedicated processor, the SCSI PhaseEngine™ (RISC Sequencer), which executes a SCSI command described by a Sequencer Control Block (SCB). Three SCBs may be stored in the internal SCB Array. These SCBs are executed independently of the SCSI target ID in the order that they are received. The SCB is a data structure which contains all information necessary for the execution of the command. The sequencer in the chip handles all phases of the SCSI bus, including the Disconnect/Reconnect and Command Complete message. On the PCI host side, bus master transfers are made in a 64-bit address space at up to the maximum burst rate of 133 MBytes/sec with data buffering of 128 bytes.

## **Feature Summary**

- Automatic data threshold selection
- Power down modes
- Scatter/Gather operations supported
- Extremely low SCSI command overhead
- Data residue reported on underruns
- One interrupt per command completion, multiple command completions may be queued on a single interrupt
- Queued commands per Target/LUN
- Overlapped command execution
- Modify Data Pointers message handled
- Tagged Queuing supported
- SCSI Configured AutoMagically (SCAM level 1 support)
- Data path from PCI bus to SCSI bus internally byte parity protected
- Hardware address breakpoint capability for software debug

#### **SCSI Features**

- Fast (10 MHz) data transfers
- Auto SCSI bus PIO
- Selectable SCSI output active negation
- SCSI termination power down control or general purpose control
- SCAM level 1 support
- Digital filtering for incoming REQ and ACK signals

#### PCI 32-bit Interface

- Direct pin out connection to PCI 32-bit bus interface
- PCI bus master with zero wait state 32-bit memory data transfers at 133 MBytes/sec, capable of leading and trailing 32-bit boundary offset bytes, with a 32-bit address range within a selected 64-bit address page
- Supports both PCI single and dual address cycles
- PCI bus master/slave timing referenced to PCI signal PCLK (33.3 MHz max)
- PCI bus master programmable Latency Timer, Cache Size, and Interrupt Line Select registers
- PCI bus access of AIC-7850 device registers from both PCI I/O and memory address spaces
- Supports medium PCI target device-select response time
- Supports enhanced PCI system memory data Read and Write commands
- Cache line streaming capability
- Supports PCI bus address and data parity generation and checking
- Supports PCI PERR and SERR requirements
- Data transfers may be selected to be initiated by CACHESIZE or data level thresholds
- Data FIFO data flush for transfers to system memory
- IRQA# interrupt generation from hardware, firmware, and software controlled sources
- Supports reduced power requirements when not performing master data transfers
- Provides diagnostic support for PCI bus parity error checking

#### **Data Buffer**

- Data FIFO provides 128 bytes of storage, dual-ported RAM, with parity per byte
- Programmable data and cache size threshold levels to initiate PCI bus master requests
- Early FIFO full status
- Multi byte-width data ports: 8 (PCI), 2 (SCSI), 1 (sequencer or driver) byte with byte parity
- Byte write parity generation and byte read parity checking
- Read/write capable address counters
- Partial quad word detection and adjustment
- Starting address byte offset capable

#### Scratch RAM

- 64 bytes of dual-ported SRAM, accessible by sequencer and host drivers
- Byte parity protected

#### Sequencer (SCSI PhaseEngine)

- RISC instruction per clock design
- Clock rate selectable for 8 or 10 MHz operation
- SRAM microcode storage, 512 29-bit words plus byte parity
- Sixteen instruction group types
- Operation may be paused by maskable interrupt condition or software driver
- Diagnostic single-step and address breakpoint
- SLEEP mode for chip power reduction

#### **SCB Array**

- Internal SCB Array for storage of three SCBs
- SCBPTR register for SCB page (32-bytes) selection
- SCBCNT register for auto SCB address increment
- SCB write supports 32-bit burst transfers
- Queue In and Queue Out FIFO (entry depths of 8 with stored count status)
- Queue In and Queue Out CNT (entry depths of 255 with stored count status)
- SCB, Queue In and Queue Out are byte parity protected

# AIC-7850 Block Diagram



Figure 1-1. AIC-7850 Block Diagram

## **Reference Documents**

Reference is made in this specification to the following additional documents:

- Peripheral Component Interconnect (PCI) Local Bus Interface Specification, Rev. 2.0
- AIC-7770 Specification 707001, Adaptec Inc.
- SCSI-2 Specification ANSI Standard # X3T9.2 Rev 10h

# ••••• System Cycles

# **About This Chapter**

Read this chapter to find out

- The PCI Master Bus Cycles
- The PCI Slave Bus Cycles

# •••• 10

# **PCI Master Bus Cycles**



Figure 10-1. Master Parking on Bus



Figure 10-2. Master Single Transfer Write



Figure 10-3. Master Single Transfer Read



Figure 10-4. Master Burst Transfer Write

The AIC-7850 is capable of cache line streaming, with no wait states, however the target disconnects at end of cache line



Float Condition (signals other than AD, CBE, and PAR require pull-up resistors on the system board)
 AIC-7850 target response

- .. AIC-7850 MRDC burst to cache line boundary
- \*\*\* AIC-7850 MRDC burst for 16-byte cache line The AIC-7850 is capable of cache line streaming, with no wait states, however the target disconnects at end of cache line

Figure 10-5. Master Burst Transfer Read

# **PCI Slave Bus Cycles**





Float Condition (signals other than AD, CBE, and PAR require pull-up resistors on the system board)

- \* AIC-7850 target response
- \*\* AIC-7850 register access cycle
- \*\*\* May be delayed one or more clocks for some addresses

Figure 10-6. Slave Single Transfer Write



Float Condition (signals other than AD, CBE, and PAR require pull-up resistors on the system board)

- \* AIC-7850 target response
- \*\* AIC-7850 register access cycle
- \*\*\* May be delayed one or more clocks for some addresses

Figure 10-7. Slave Single Transfer Read



Float Condition (signals other than AD, CBE, and PAR require pull-up resistors on the system board)

- \* AIC-7850 target response
- \* \* AIC-7850 register access cycle
- \*\*\* May be delayed one or more clocks for some addresses

Figure 10-8. Slave Retry



 Float Condition (signals other than AD, CBE, and PAR require pull-up resistors on the system board)

- \* AIC-7850 target response
- \*\* AIC-7850 register access cycle with data wide error

Figure 10-9. Slave Target Abort (width error)



Float Condition (signals other than AD, CBE, and PAR require pullup resistors on the system board)

- \* AIC-7850 target response
- \*\* AIC-7850 register access cycle with unsupported burst

Figure 10-10. Slave Burst Disconnect

Package Outline

# **About This Chapter**

Read this chapter to find out

- A package outline of the AIC-7850
- A mechanical drawing of the AIC-7850

# AIC-7850 Package Outline



Figure 11-1. AIC-7850 Package Outline

# **AIC-7850 Mechanical Outline**



Figure 11-2. AIC-7850 Mechanical Outline

Table 11-1. MQFP Dimensions (100 pin)

|        | Short (JEDEC) Leadform |       |        |     |
|--------|------------------------|-------|--------|-----|
|        | m                      | m     | m      | ils |
| Symbol | min                    | max   | min    | max |
| Α      | •                      | 3.40  | •      | 134 |
| A1     | 0.25                   | •     | 10     | -   |
| A2     | 2.55                   | 3.05  | 100    | 120 |
| В      | 0.22                   | 0.38  | 9      | 15  |
| D      | 22.95                  | 23.45 | 904    | 923 |
| D1     | 19.90                  | 20.10 | 783    | 791 |
| E      | 16.95                  | 17.45 | 667    | 687 |
| E1     | 13.90                  | 14.10 | 547    | 555 |
| е      | .65                    | BSC   | 26     | BSC |
| L      | 0.73                   | 1.03  | 29     | 41  |
| L1     | 1.6 REF                |       | 63 REF |     |
| ααα    | .1                     | 2     |        | 5   |

Controlling dimensions are millimeters.

- Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is .25 mm per side. Dimensions D1 and E1 do include mold mismatch.
- Dimension B does not include dambar protrusion. Allowable protrusion shall be 0.8 mm total in excess of B dimension at maximum material condition.
- Solder plate thickness shall be 200 microinches min.

# Pin Description

# **About This Chapter**

Read this chapter to find out

- A summary of the pin pad type and signal assignment
- A detailed description of the supported PCI-32 pin signals

# \*\*\*\* 2

# **Pin Pad Type and Signal Assignment Summary**

The pins are summarized here, listing the name, pin number, if the pin is an input, and the type and drive of the outputs. The type definitions are listed in Table 2-1. A more complete description follows the summary.

Table 2-1. Pin Type Definitions

| Туре  | Definition                                                      |  |  |
|-------|-----------------------------------------------------------------|--|--|
| 1     | Input                                                           |  |  |
| 3ST/# | Tri-state Output/Min Drive Current in mA                        |  |  |
| OD/#  | Open Drain Output/Min Drive Current in mA                       |  |  |
| NOD/# | Current Source Capable Open Drain Output/Min Sink Current in mA |  |  |

#### **Host Interface**

Table 2-2. Host Interface

| Signal Name | Pin Number                                                                     | I/O Driver<br>PCI Master | VO Driver<br>PCI Target | Notes |
|-------------|--------------------------------------------------------------------------------|--------------------------|-------------------------|-------|
| AD[31:00]   | 86-88, 90-91, 93-95, 99, 100, 1, 3, 4, 6, 7, 9, 25-28, 30-33, 36, 38-41, 43-45 | I, 3ST/6                 | I, 3ST/6                | 2     |
| CBE[3:0]#   | 97, 10, 23, 34                                                                 | 3ST/6                    | l l                     | 2     |
| DEVSEL#     | 17                                                                             | 1                        | 3ST/6                   | 1,2   |
| FRAME#      | 11                                                                             | 3ST/6                    | 1                       | 1, 2  |
| GNT#        | 84                                                                             | I                        | NA                      | 2     |
| IDSEL       | 98                                                                             | NA                       | l                       | 2     |
| IRDY#       | 12                                                                             | 3ST/6                    | F                       | 1,2   |
| PAR         | 21                                                                             | I, 3ST6                  | I, 3ST6                 | 2     |
| PCLK        | 82                                                                             | 1                        | 1                       |       |
| PREQ#       | 85                                                                             | 3ST/6                    | NA                      | 2     |
| PERR#       | 19                                                                             | I, 3ST/6                 | I, 3ST/6                | 1, 2  |
| RST#        | 80                                                                             | 1                        | 1                       | 2     |
| SERR#       | 20                                                                             | NA                       | OD/6                    | 1,2   |
| STOP#       | 18                                                                             | 1                        | 3ST/6                   | 1, 2  |
| TRDY#       | 14                                                                             | I                        | 3ST/6                   | 1, 2  |
| IRQA#       | 4                                                                              | OD                       | OD                      | 1     |

<sup>&</sup>lt;sup>1</sup> Signal requires external pull-up resistors.

<sup>&</sup>lt;sup>2</sup> Signal may be operated on a 5V or 3.3V PCI bus. All other pins operate only on a 5V bus.

#### **SCSI** Interface

Table 2-3. SCSI Interface

| Signal Name | Pin Number           | VO Driver |
|-------------|----------------------|-----------|
| SCD7#-SCD0# | 69-71, 73-75, 77, 79 | I, NOD/48 |
| SCDPL#      | 67                   | I, NOD/48 |
| CD#         | 54                   | I, NOD/48 |
| IO#         | 53                   | I, NOD/48 |
| MSG#        | 57                   | I, NOD/48 |
| REQ#        | 56                   | 1, NOD/48 |
| ACK#        | 60                   | I, NOD/48 |
| RESET#      | 62                   | I, OD/48  |
| SEL#        | 58                   | I, OD/48  |
| BSY#        | 65                   | I, OD/48  |
| ATN#        | 66                   | I, NOD/48 |

### **SCSI Termination Power Control Pin**

Table 2-4. SCSI Termination Power Control Pin

| Signal Name         | Pin Number | VO Driver |
|---------------------|------------|-----------|
| STPWDN <sup>1</sup> | 51         | I, 3ST/24 |

<sup>&</sup>lt;sup>1</sup> This pin is proposed to be reconfigured as a serial port VO pin in the future implementation of the AIC-7850.

#### **Other Pins**

Table 2-5. Other Pins

| Signal Name | Pin Number | VO Driver |
|-------------|------------|-----------|
| CLKIN       | 49         | 1         |

### **Power Distribution Pins**

Table 2-6. Power Distribution Pins

| Signal Name | Pin Number                           | I/O Driver | Notes |  |
|-------------|--------------------------------------|------------|-------|--|
| CVCC(3:0)   | 15, 48, 63, 83                       |            |       |  |
| CGND(3:0)   | 64, 50,13, 81                        |            |       |  |
| SVCC(2:0)   | 76, 59, 52                           |            |       |  |
| SGND(5:1)   | 78, 72, 68, 61, 55                   |            |       |  |
| PVCC(3:0)   | 37, 24, 5, 92                        |            |       |  |
| PGND(14:0)  | 46, 42, 35, 29, 22, 16, 8, 2, 96, 89 |            |       |  |

CVCC = Core Logic Power Pin
CGND = Core Logic Ground Pin
SVCC = SCSI Pad Ring Power Pin
SGND = SCSI Pad Ring Ground Pin
PVCC = PCI Pad Ring Power Pin
PGND = PCI Pad Ring Ground Pin
Note: The different ()VCC and ()GND pin strings are not internally connected

## **Pin Signal Description**

The logical state of a signal name that does not end in a # symbol is asserted or active when high and is deasserted or inactive when low. The logical state of a signal name that ends in a # symbol is asserted or active when low and is deasserted or inactive when high.

#### Supported PCI-32 Pin Signals

**Symbol:** AD[31:00] **Type:** in-t/s

Address and data are multiplexed on the same PCI bus pin. During the first clock of a transaction AD[31:00] contain a physical byte address of (32-bits) called low address 31:00 for Single Address Cycles (SAC). During subsequent clocks, AD[31:00] contain data of (32-bits) called low data 31:00, except for Dual Address Cycles (DAC) where both the first (low address 31:00) and second (high address 63:32) clocks of a transaction contain address and the remaining clocks contain data (low data 31:00). The turn-around PCLK period for AD[31:00] is the idle cycle between transactions.

A PCI read or write bus transaction consist of one Address phase (SAC) or two Address phases (DAC) followed by one or more Data phases. Each PCI Data phase may consist of one or more PCLK periods. Little-endian byte ordering is used. AD[07:00] define the least significant byte and AD[31:24] the most significant byte. All 32 AD[31:00] bits must be driven to stable values (excluding turn around PCLK periods) during every Address and Data phase, to enable even-parity checking. All AD[31:00] bits must be decoded for memory and I/O phases to allow for future address expansion.

The use of AD[01:00] varies in the Address phase of the three different PCI address spaces:

■ In the PCI Configuration address space, AD[01:00] are used to identify the type of configuration space the access is intended for. AD[01:00] are a value of 0h to identify the configuration space as type 0 and a value of 1h for type 1, with values of 2h and 3h reserved. Type 0 configuration accesses are not propagated beyond the local PCI bus and must be claimed by a local device or terminated with master-abort. Type 1 configuration accesses are for targets that do not reside on the local PCI bus. For type 0, AD[07:02] define a 32-bit register address within the configuration address space. Thus, configuration address space defaults to Double Word (DWD) addressing aligned to the DWD boundary. Targets with multiple functions must contain a configuration space for each function. The value supplied on AD[10:08] is used to point to each space. The AIC-7850, as a single function target supporting type 0 address space, accesses with a single configuration space. The AIC-7850 as a target, uses positive address decoding over AD[07:02] along with CBE[3:0]# (command is CRDC or CWRC), IDSEL, AD[01:00] = 0h and FRAME# to validate the configuration register address decode, then asserts DEVSEL# to claim the transaction. IDSEL is normally connected to an ADn signal in the range of AD[31:11] of the PCI bus.

AIC-7850 Configuration Space Address Format

| Reserved for IDSEL (single-bit) | Function Number | Register Number | Configuration Space Type |
|---------------------------------|-----------------|-----------------|--------------------------|
| AD[31:11]                       | AD[10:08]       | AD[07:02)       | AD[01:00]                |

■ In the IO address space, all 32 AD lines are used to provide for direct byte address decoding. The AIC-7850 as a target uses positive address decoding over BASEADR0 register (stored value), AD[31:08] (for mapping), CBE[3:0]# (for command), AD[07:00] (for register address) and FRAME# to validate the Device Space register 256 decodes.

When the AIC-7850 as a target is enabled to allow access to its Device Space registers from the PCI IO address space, the use of AD[01:00] during the Address phase allows the AIC-7850 to validate the register address decode and claim the transaction (assert DEVSEL# = medium speed). TRDY# is deasserted for the first Data phase to allow the Data phase CBE value to become valid for byte steering to the internal 8-bit register path for a three PCLK data transfer cycle for register write. For register read, TRDY# is deasserted for the required AD[31:00] turn-around cycle, plus an additional PCLK for H/W registers, plus one or more to enable internal or external RAM data to become valid. Note, additional PCLKs are required for some addresses due to mode conditions.

■ In the PCI memory address space, AD[01:00] are excluded from the address decode and as such, the address defaults to Double Word (DWD) addressing aligned to the DWD boundary. The value AD[01:00] are used in the memory address space to indicate different Memory Address Transfer modes. A value of 0h indicates linear address increment mode, a value of 1h indicates Address Cache Line Toggle mode, and the values of 2h and 3h are reserved. The AIC-7850 as a master or target only supports the linear address increment mode.

When the AIC-7850 as a target is enabled to allow access to its Device Space registers from the PCI memory address space, it will use positive address decoding over BASEADR1 register (stored value), AD[31:02], CBE[3:0]# (command) and FRAME# to obtain the DWD access decode and claim the transaction by asserting (DEVSEL# = medium speed). Then use the CBE[3:0]# (data) value to complete the Device Space register decode. TRDY# is deasserted for the first Data phase to allow the Data phase CBE value to become valid for byte steering to the internal 8-bit register path for a three PCLK data transfer cycle for register write. For register read TRDY# is deasserted for the required AD[31:00] turn-around cycle, plus an additional PCLK for H/W registers, plus one or more to enable internal or external RAM data to become valid. Note, additional PCLKs are required for some addresses due to mode conditions.

The use of AD[31:00] varies in the Data phase of transactions as follows when the AIC-7850 is a bus master or a bus target:

Bus target Data phase transactions to the AIC-7850's 8-bit Device Space registers will use the AD[31:00] byte indicated by a single asserted CBE# for all registers. Should more than one CBE# be asserted (indicates a nonsupported data width), the AIC-7850 will indicate Target Abort. When more than one Data phase is indicated (burst operation), the AIC-7850 will indicate Disconnect and only accept the first Data phase (except for SCB double word write, where bursting is allowed, with linear burst order only). When no CBE bits are asserted, the AIC-7850 will not store the associated data for (write) and will supply all AD[31:00] bytes with 0h value for (read).

■ Bus target Data phase transactions to the AIC-7850's configuration space supports up to (32-bit) data transfers on AD[31:00] with the valid data bytes indicated with the CBE[3:0]# value for (write), for (read) the AIC-7850 will always source all bytes of the addressed register. Reading reserved configuration space

register bytes/bits always return zero for the value. Data written to reserved configuration space register bits or bytes is discarded. No error indication is made for reading or writing to reserved registers. When more than one Data phase is indicated (burst operation), the AIC-7850 will indicate Disconnect and only accept the first Data phase.

- The AIC-7850 as a master will always transfer leading offset data bytes, if they exist, to reach the next DWD boundary in the first Data phase of a transaction, providing the byte count is sufficient. Then four bytes will be transferred at a time from DWD boundary to DWD boundary until the last Data phase, which will transfer any trailing offset bytes that may exist, to expire the byte count.
- The AIC-7850 as a target does not support expansion ROM accesses. The External ROM Control register (EXROMCTL) is read-only with value 0.

**Symbol:** CBE[3:0]# **Type:** in-t/s

Bus Command and Byte Enables are multiplexed on the same PCI pins. During the Address phase of a transaction, CBE[3:0]# contain a Bus command that defines the function to be performed during the transaction. CBE[3:0]# command encodings are viewed on the bus where a 1 indicates a high voltage and 0 is a low voltage. During the Data phase of a transaction, CBE[3:0]# define which data bytes of AD[31:00] contain valid data. CBE0# applies to AD[07:00] and CBE3# to AD[31:24]. The AIC-7850 asserts CBE[3:0]# when in Master mode to indicate the location of the first byte in a 32-bit boundary space and to match the data width being transferred. CBE[3:0]# are asserted (=0) by the system board or a bus master to access the AIC-7850 as a bus slave. No more than one CBE# may be asserted at a time for transactions to the AIC-7850's 8-bit Device registers without causing a Target Abort reply (except for SCB double word writes where bursting is allowed).

**Note:** Data phases that do not have at least one asserted CBEn# do not transfer data, however all data bytes must be stable so that parity may be developed, and appear as NOPs on the bus.

The turn-around PCLK period for CBE[3:0]# is the idle cycle between transactions. The commands assigned to CBE[3:0]# in the PCI specification are as follows:

| Δd | dress | Pha | ISP |
|----|-------|-----|-----|
|    |       |     |     |

|          |         |                             | AIC-7850 | Support |
|----------|---------|-----------------------------|----------|---------|
| CBE[3:]# | Command | Туре                        | Target   | Master  |
| 0000     | IAC     | Interrupt Acknowledge       | No       | No      |
| 0001     | SSC     | Special Cycle               | No       | No      |
| 0010     | IORDC   | IO Read                     | Yes      | No      |
| 0011     | IOWRC   | IO Write                    | Yes      | No      |
| 0100     | RSVD    |                             | No       | No      |
| 0101     | RSVD    |                             | No       | No      |
| 0110     | MRDC    | Memory Read                 | Yes      | Yes     |
| 0111     | MWRC    | Memory Write                | Yes      | Yes     |
| 1000     | RSVD    |                             | No       | No      |
| 1001     | RSVD    |                             | No       | No      |
| 1010     | CRDC    | Configuration Read          | Yes      | No      |
| 1011     | CWRC    | Configuration Write         | Yes      | No      |
| 1100     | MRDMC   | Memory Read Multiple        | **       | Yes     |
| 1101     | DAC     | Dual Address Cycle          | No       | Yes     |
| 1110     | MRDLC   | Memory Read Line            | **       | Yes     |
| 1111     | MWRIC   | Memory Write and Invalidate | *        | Yes     |

<sup>\*</sup> Defaults to Memory Write

<sup>\*\*</sup> Defaults to Memory Read

The AIC-7850 CBE[3:0]# values used/accepted during a Data phase to indicate the valid data bytes are as follows:

**Data Phase** 

|          | AIC-7850 | Support |
|----------|----------|---------|
| CBE[3:]# | Target   | Master  |
| 1110     | bc       | m       |
| 1101     | bc       | m       |
| 1011     | bc       | m       |
| 0111     | b        | m       |
| 1100     | b        | m       |
| 1001     | b        | m       |
| 0011     | b        | m       |
| 1000     | b        | m       |
| 0001     | ab       | m       |
| 0000     | n        | m       |
| 1111     |          | -       |

a = SCB doubleword write access

**Symbol:** DEVSEL# **Type:** in-s/t/s

Device Select#. When asserted, indicates the driving device has decoded its address as the selected target of the current bus transaction. DEVSEL# once asserted cannot be deasserted until FRAME# is sampled deasserted, except for the target-abort case. Also DEVSEL# must be asserted for one or more PCLKs before a target-abort condition may be signaled. The AIC-7850 as a slave asserts DEVSEL# with medium speed timing when responding as a result of a valid and supported command directed to the AIC-7850's Configuration register space, and when enabled, to the Device register space, or to the external ROM. The AIC-7850 as a master, samples DEVSEL# when initiating a transaction to a selected target to determine if the target is capable of proceeding with the current transaction. In the case when DEVSEL# is not asserted by the selected target for six PCLKs (SAC) or seven PCLKs (DAC) after FRAME# is asserted, the AIC-7850 will perform a master-abort (on PCLK seven (SAC) or eight (DAC) deassert FRAME# on the next PCLK (if still asserted) and on the next PCLK deassert IRDY#). Alternately where FRAME# was deasserted after one PCLK (indicates only one Data phase in the transaction), the AIC-7850 will perform a master-abort (on PCLK seven (SAC) or eight (DAC) deassert IRDY#). The AIC-7850 will not retry transactions that resulted in a master abort (no response from target) and will generate an interrupt to the driver with RMA status active. Intervention is required for the AIC-7850 to continue with bus master transactions. The turn-around PCLK period for DEVSEL# is the Address phase of a transaction. The AIC-7850 as a master never asserts DEVSEL#.

b = Configuration register 32-bit registers access

c = Device space 8-bit register or external EEPROM write access

m = System memory access (AIC-7850 outputs only listed CBE[3:0] values)

n = No data transfers (Note all AD[31:00] are driven for parity checking) with normal data phase timing

**Symbol:** FRAME# **Type:** in-s/t/s

Frame#. Asserted by the current master to indicate the duration of a bus transaction. The assertion of FRAME# identifies an Address phase of a transaction. The deassertion of FRAME# identifies the final data phase of the transaction (FRAME# cannot be deasserted while IRDY# is deasserted for the final data phase). An idle cycle (PCI bus free) occurs when both FRAME# and IRDY# are deasserted. The turn-around PCLK period for FRAME# is the idle cycle between transactions. See DEVSEL# for the AIC-7850 Master Abort conditions. The AIC-7850 as a target never asserts FRAME#.

The AIC-7850 asserts FRAME# with the same PCLK that asserts an address value on AD[31:00] for SAC or DAC. When the transaction is a DAC, FRAME# remains asserted for the second PCLK Address phase and for all Data phases that follow, until the last Data phase where FRAME# will be deasserted.

**Symbol:** GNT# **Type:** in

**Grant#**. Asserted indicates to a master that a bus transaction may be performed. This is a point-to-point signal with every master having its own GNT# signal. Only one GNT# may be asserted by the PCI System Board Central Resource Arbitrator at a time. The Arbitrator may deassert GNT# at any time (one PCLK period minimum assertion) and may also assert GNT# when the master is not asserting REQ# (park the bus) to require the master to drive bus signals AD[31:00], CBE[3:0]# (and PAR delayed by one PCLK) within eight PCLK (recommended value is by two to three PCLKs) to prevent bus float conditions. In the case where GNT# is deasserted and FRAME# is asserted on the same PCLK, the bus transaction is valid and will continue. One GNT# can be deasserted coincident with another GNT# being asserted if the bus is not idle. Otherwise a one PCLK delay is required between the deassertion of one GNT# and the assertion of the next GNT#. The newly granted master may not start a transaction until an IDLE cycle (FRAME# and IRDY# deasserted) is sampled. GNT# is held in a tri-stated condition while RST# is asserted. The AIC-7850 extends an asserted RST# internally and thus will not recognize GNT# in any state until after the extension expires. Except for the RST# condition, the AIC-7850 will drive AD[31:00] and CBE[3:0]# on the first PCLK, GNT# is sampled asserted with the PCI bus idle, then PAR one PCLK later. The AIC-7850 will also drive and assert FRAME# if PREQ# is asserted.

**Symbol:** IDSEL **Type:** in

**Initialization Device Select.** Used in lieu of the upper 24 ADn address signals and is valid only during configuration read and write transactions and is validated with FRAME# assertion and valid CBEn# values. IDSEL is a point-to-point signal with each agent having its own IDSEL. PCI convention is to connect a different AD[31:11] line to IDSEL input of each device on the bus, the AIC-7850 will respond to all accesses in its configuration address range.

**Symbol:** IRDY# in-s/t/s

Initiator Ready#. Asserted to indicate the current master's ability to complete the current Data phase of a transaction. During a write, IRDY# indicates that the master is asserting valid data on AD[31:00]. During a read, it indicates the master is prepared to accept data on AD[31:00]. It is used in conjunction with TRDY#. Wait cycles are inserted until both IRDY# and TRDY# are asserted together. A Data phase is completed on any PCLK when IRDY# and TRDY# are both sampled asserted. An idle cycle (PCI bus free) occurs when both FRAME# and IRDY# are deasserted. The turn-around PCLK period for IRDY# is the Address phase of a transaction.

The AIC-7850 as a master asserts IRDY# with the same PCLK that starts a Data phase on AD[31:00].

**Symbol:** PAR **Type:** in-t/s

Parity. The even-parity bit that protects both AD[31:00] and C/BE[3:0]# signals. PAR is generated by the agent that is sourcing the 32-bit address of the transaction and/or the data of the transaction and includes the CBE[3:0] values even if not sourcing them. The state of PAR is valid for the value on AD[31:00] and CBE[3:0] during the previous PCLK period for address and for the PCLK that transferred data, excluding PAR turn-around PCLK periods which occur in the PCLK following the turn-around PCLK period of AD[31:00]. The agent detecting parity errors will set the DPE bit in the Configuration Status register without regard for the state of PERRESPEN bit. The AIC-7850 as a target indicates SERR for address parity error detection when both PERRESPEN and SERRESPEN are active. The AIC-7850 as a target will assert PERR for data parity errors when PERRESPEN is active.

**Symbol:** PCLK **Type:** cin

PCI Bus Clock Input. Provides timing for all transactions on the PCI bus. All other PCI signals are sampled on the rising edge of PCLK, and all parameters are defined with respect to this edge. PCLK is a controlled skew, point-to-point signal to each agent and is only driven by the PCI System Board Central Resource. The PCLK signal for the AIC-7850 is a maximum rate of 33.3 MHz. When POWRDN is active, the AIC-7850 restricts the use of PCLK to only Configuration address space and the AIC-7850 Device registers which are accessible only from the PCI bus (not from the internal sequencer). PCLK signal used by other logic is maintained in the active state (=1) when POWRDN is active. Note, all internal logic is static allowing the PCLK and the CLKIN signals to be stopped externally if desired when no active SCSI commands are in process for maximum power down mode. See RAMPS# for a buffered version of PCLK for external adapter board use.

Symbol: PREQ#
Type: t/s

PCI Request#. When asserted, indicates to the PCI System Board Arbitrator that a master desires use of the bus. This is a point-to-point signal with every master having its own PREQ#. Arbitration for the PCI bus is performed either when the bus is idle or in parallel with the transaction in process. When only a single Data phase is to be performed, PREQ# should be deasserted with the same PCLK that asserts FRAME#. When a transaction is terminated by a target, the master must deassert its PREQ# for a minimum of two PCLK periods (one period must include the bus idle period). This allows another agent to use the bus while the previous target (that requested the STOP) prepares to continue.

**Note:** This is not required where the master deasserted FRAME# indicating the last Data phase of a transaction is in process. In this case, provided GNT# is still asserted, the master could start another transaction without deasserting PREQ#.

PREQ# is asserted by the AIC-7850 to become a bus master provided that the MASTEREN bit is active and either ISPACEEN or MSPACEEN bits (to allow access to the AIC-7850's Device registers) is/are active in the Configuration Command register for the following conditions:

- For system memory to data FIFO transfers (HDMAEN and DIRECTION are active and CACHETHEN inactive), when DFTHRSH or FIFOEMP becomes active. In this case, PREQ# remains asserted until DFSDH or FIFOFULL becomes active or STOP# is asserted, as long as HDMAEN is active, HCNT is not zero, and GNT# is asserted (or, if deasserted, until the latency timer has expired for pre-empt conditions and if performing a cache line referenced command MRDMC, until the in-process cache line transfer has been completed with MRDCEN not active. When MRDCEN is active, the in-process cache line transfer will be truncated).
- For system memory to data FIFO transfers (HDMAEN and DIRECTION are active and CACHETHEN inactive), when DFCACHETH becomes active. PREQ# will be asserted until the cache line is completed and DFCACHETH is inactive or (STOP# is asserted), as long as HDMAEN is active, HCNT is not zero, and GNT# is asserted (or, if deasserted, until the latency timer has expired for preempt conditions and if performing a Cache Line Referenced command MRDLC until the inprocess cache line transfer has been completed with MRDCEN not active. When MRDCEN is active, the in-process cache line transfer will be truncated).
- For data FIFO to system memory transfers (HDMAEN active and DIRECTION and CACHETHEN inactive), when DFTHRSH, DFSXDONE, or FIFOFULL becomes active. In this case, PREQ# remains asserted until FIFOEMP is active or STOP# is asserted, as long as HDMAEN is active, HCNT is not zero, and GNT# is asserted (or, if not asserted, until the latency timer has expired for pre-empt conditions and if performing a Cache Line Referenced command or (MWRIC), until the cache line transfer has been completed).

■ For data FIFO to system memory transfers (HDMAEN and CACHETHEN active and DIRECTION inactive), when DFCACHETH becomes active. In this case, PREQ# remains asserted until the cache line is completed (or multiple cache lines are completed if DFCACHETH remains active), or STOP# is asserted, as long as HDMAEN is active, HCNT is not zero, and GNT# is asserted (or, if not asserted, until the latency timer has expired for pre-empt conditions and if performing a Cache Line Referenced command (MWRIC), until the cache line transfer has been completed).

**Note:** PREQ# output will be floated whenever RST# is asserted.

**Symbol:** PERR# in-s/t/s

Parity Error#. May be asserted (pulsed for one PCLK period for each detected error provided that the Parity Error Response bit, PERRESPEN, is active in the Configuration Command register) only by the agent receiving the data. Also, a target cannot assert PERR# until it has claimed the access by asserting DEVSEL# and completing the data transfer. The turn-around PCLK for PERR# is the third PCLK period after the last address PAR period of an agent. PERR# is asserted for detected errors two PCLK periods after the data that contained the error as per the following sequence:

- 1 From PCLK N that transfers the data (both TRDY# and IRDY# are asserted) that data parity is to be generated for.
- **2** From PCLK N+1 PAR is asserted for the data asserted in PCLK N.
- **3** From PCLK N+2 assert PERR# when an even-parity error was indicated on the PCLK N+1 sample of data.
- 4 From PCLK (N+2)+1 deassert PERR# and when the last PERR# cycle wait for one more PCLK period before floating PERR#.

The AIC-7850 asserts PERR# only for detected data parity errors for received data when PERRESPEN is active but always sets DPE bit active in the Configuration Status register.

**Symbol:** RST# **Type:** in

**Reset#**. When asserted forces agents to a known initialization state. RST# may be asynchronous to PCLK when asserted or deasserted. Deassertion is guaranteed to be a clean, bounce-free edge.

- All n/o/d, t/s and s/t/s type signals are forced to a high impedance state.
- All o/d type signals are forced to float.
- All agent internal registers (Device and Configuration) are forced to specified states.
- All internal RAM data values should be considered indeterminate.

**Note:** The AIC-7850's internal Power-On-Reset (POR) activated by assertion of RST# is extended two CLKIN rising edges to ensure complete internal initialization, should short RST# assertions occur, and to provide an internally synchronized inactivation of the AIC-7850 initialization. POR is also activated by a write to the CHIPRST bit in Device HCNTRL register.

**Symbol:** SERR# **Type:** in-o/d

System Error#. May be asserted by a PCI agent that detects an address parity error (provided that PERRESPEN and SERRESPEN are active) during the Address phase of a transaction or for data parity errors on special cycles and for any other system error where the result will be a catastrophic error. The transaction master is solely responsible for reporting master or target aborts; targets do not assert SERR# when using target-abort termination. SERR# is restored only by a weak pull-up on the system board, and may take several PCLK periods to recover to a deasserted state. SERR# is asserted (pulsed for one PCLK period) for detected address errors two PCLK periods after the address that contained the error as per the following sequence:

- 1 From PCLK N for the address that is being asserted, for which parity is to be generated for.
- 2 From PCLK N+1 PAR is asserted for the address asserted in PCLK N.
- From PCLK N+2 assert SERR# when an even-parity error was indicated on the PCLK N+1 sample of the address.
- 4 From PCLK (N+2)+1 deassert SERR#.

The AIC-7850 as a target only asserts SERR# for all detected address parity errors when PERRESPEN and SERRESPEN are active. In all cases, DPE will be set active without regard for the enables.

**Symbol:** STOP# in-s/t/s

**Stop**. When asserted, indicates the current target is requesting the master to stop the current Data phase of a transaction in process. STOP#, once asserted, must remain asserted until FRAME# is deasserted and data may or may not be transferred in the final Data phase of the transaction. The turn-around PCLK period for STOP# is the Address phase of a transaction.

The AIC-7850, when attempting to perform a transaction to a target that responds with Target-Stop (disconnect) or Target-Retry, will retry the transaction with the next address to be transferred. When the response is Target-Abort, the AIC-7850 will not retry and will set the RTA bit in the Configuration Status register active and generate an interrupt IRQA#. See the Device CLRINT register for clearing this interrupt.

**Note:** For Target-Abort this means the SCSI data segment transfer will stall and software/firmware intervention is required.)

The AIC-7850 as a target asserts STOP# (disconnect with data transferred) when FRAME# is indicating burst cycles (except for SCB double word write transactions where bursting is allowed). This is not an error condition.

Typical AIC-7850 PCI Data Transfer Status

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition<br>Normal Master Ending |
|--------|-------|---------|-------|-------|-----------------------------------|
| N      | N     | N       | N     | N     | Bus idle                          |
| Υ      | N     | N       | N     | N     | Master starts SAC                 |
| Υ      | Υ     | N       | N     | N     |                                   |
| Υ      | Υ     | Υ       | N     | N     | Target responds                   |
| Υ      | Υ     | Υ       | Υ     | N     | Data transferred                  |
| Υ      | Υ     | Υ       | Υ     | N     | Data transferred                  |
| N      | Υ     | Υ       | Υ     | N     | Last data transferred             |
| N      | N     | N       | N     | N     | Bus idle                          |

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition<br>Normal Master Ending |
|--------|-------|---------|-------|-------|-----------------------------------|
| N      | N     | N       | N     | N     | Bus idle                          |
| Υ      | N     | N       | N     | N     | Master starts DAC                 |
| Υ      | N     | N       | N     | N     |                                   |
| Υ      | Υ     | N       | N     | N     |                                   |
| Υ      | Υ     | Υ       | N     | N     | Target responds                   |
| Υ      | Υ     | Υ       | Υ     | N     | Data transferred                  |
| Υ      | Υ     | Υ       | Υ     | N     | Data transferred                  |
| N      | Υ     | Υ       | Υ     | N     | Last data transferred             |
| N      | N     | N       | N     | N     | Bus idle                          |

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition Target Disconnected with Data |
|--------|-------|---------|-------|-------|-----------------------------------------|
| N      | N     | N       | N     | N     | Bus idle                                |
| Υ      | N     | N       | N     | N     | Master starts SAC                       |
| Υ      | Υ     | N       | N     | N     |                                         |
| Y      | Υ     | Υ       | N     | N     | Target responds                         |
| Υ      | Υ     | Υ       | Y     | N     | Data transferred                        |
| Υ      | Υ     | Υ       | Υ     | Υ     | Last data transferred                   |
| N      | Υ     | N       | N     | Υ     | No data transferred                     |
| N      | N     | N       | N     | N     | Bus idle                                |

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition Target Disconnected without Data |
|--------|-------|---------|-------|-------|--------------------------------------------|
| N      | N     | N       | N     | N     | Bus idle                                   |
| Υ      | N     | N       | N     | N     | Master starts SAC                          |
| Υ      | Υ     | N       | N     | N     |                                            |
| Υ      | Υ     | Υ       | N     | N     | Target responds                            |
| Υ      | Υ     | Y       | Υ     | N     | Data transferred                           |
| Υ      | Υ     | Υ       | N     | Υ     | No data transferred                        |
| N      | Υ     | N       | N     | Υ     |                                            |
| N      | N     | N       | N     | N     | Bus idle                                   |

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition<br>Target Retry |
|--------|-------|---------|-------|-------|---------------------------|
| N      | N     | N       | N     | N     | Bus idle                  |
| Υ      | N     | N       | N     | N     | Master starts SAC         |
| Υ      | Υ     | N       | N     | N     |                           |
| Υ      | Υ     | Υ       | N     | Υ     | Target responds           |
| N      | Υ     | Υ       | N     | Y     | No data transferred       |
| N      | N     | N       | N     | N     | Bus idle                  |

| N         N         N         N         N         Bus idle           Y         N         N         N         Master starts SAC           Y         Y         N         N         N           Y         Y         N         N         N         Target responds           Y         Y         N         N         Y         No data transferred           N         Y         N         N         Y         No data transferred | FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition<br>Target Abort |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|---------|-------|-------|---------------------------|
| Y Y N N N Y Y Y N N Target responds Y Y N N Y No data transferred                                                                                                                                                                                                                                                                                                                                                              | N      | N     | N       | N     | N     | Bus idle                  |
| Y Y Y N N Target responds Y Y N N Y No data transferred                                                                                                                                                                                                                                                                                                                                                                        | Υ      | N     | N       | N     | N     | Master starts SAC         |
| Y Y N N Y No data transferred                                                                                                                                                                                                                                                                                                                                                                                                  | Υ      | Υ     | N       | N     | N     |                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                | Υ      | Υ     | Υ       | N     | N     | Target responds           |
| N Y N N Y No data transferred                                                                                                                                                                                                                                                                                                                                                                                                  | Υ      | Υ     | N       | N     | Υ     | No data transferred       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                | N      | Υ     | N       | N     | Υ     | No data transferred       |
| N N N N Bus idle                                                                                                                                                                                                                                                                                                                                                                                                               | N      | N     | N       | N     | N     | Bus idle                  |

| FRAME# | IRDY# | DEVSEL# | TRDY# | STOP# | Condition<br>Master Abort  |
|--------|-------|---------|-------|-------|----------------------------|
| N      | N     | N       | N     | N     | Bus idle                   |
| Υ      | N     | N       | N     | N     | Master starts SAC          |
| Υ      | Υ     | N       | N     | N     |                            |
| Υ      | Υ     | N       | N     | N     |                            |
| Υ      | Υ     | N       | N     | N     |                            |
| Υ      | Υ     | N       | N     | N     |                            |
| Y      | Υ     | N       | N     | N     |                            |
| Υ      | Υ     | N       | N     | N     |                            |
| Υ      | Υ     | N       | N     | N     | Master declares abort      |
| N      | Υ     | N       | N     | N     | FRAME/IRDY ending sequence |
| N      | N     | N       | N     | N     | Bus idle                   |

Symbol: TRDY#
Type: in-s/t/s

Target Ready#. Asserted to indicate the current slave's ability to complete the current Data phase of a transaction. During a read, TRDY# indicates that the slave is asserting valid data on AD[31:00]. During a write it indicates the slave is prepared to accept data. It is used in conjunction with IRDY#. Wait cycles are inserted until both IRDY# and TRDY# are asserted together. Wait cycles should be minimized, when more than eight are expected, except for the first transfer, the transaction should be disconnected by the target and retried by the master. A Data phase is completed on any PCLK when IRDY# and TRDY# are both sampled asserted. The turn-around PCLK period for TRDY# is the Address phase of a transaction.

The AIC-7850 as a target will always have TRDY# deasserted in the first PCLK period of the first Data phase so that the asserted CBE# value may be decoded for internal byte steering and for read access required AD[31:00] turn-around. TRDY# will also be deasserted for additional PCLKs for RAM data to become valid, and when PAUSEACK is not active and the access is to a register that requires it to be active for the host driver to access the register (see PAUSE[ACK] bit in the Device HCNTRL register). When TRDY# is not asserted within eight PCLKs for Data phases, the AIC-7850 will respond with Disconnect when the data transfers. Additionally, should TRDY# not be asserted before the Exceed Timer expires, the AIC-7850 will respond with Retry. The Exceed Timer is an escape timer that should only time-out should a requested AIC-7850 address/register not be available for long periods of time (not a normal condition), and is provided to prevent hanging the system.

#### Nonsupported PCI-32 Pin Signals

| IRQB# | SDONE# |
|-------|--------|
| IRQC# | TCK    |
| IRQD# | TDI    |
| LOCK# | TDO    |
| SBO#  | TMS    |
|       | TRST#  |

#### Nonsupported PCI-64 Extension Signals

| ACK64#   | PAR64  |
|----------|--------|
| BE#[7:4] | REQ64# |
| D[63:32] |        |

### Supported PCI Pin Side Band Signal

Table 2-7. Supported PCI Pin Side Band Signals

| Symbol | Туре | Definition                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQA#  | o/d  | Interrupt Request A. IRQA# assertion state changes are synchronized to PCLK for PCI type errors and parity errors. The AIC-7850 interrupt conditions cannot assert IRQA# when the INTEN bit is not active or the POWRDN bit is active in the HCNTRL register. For IRQA# assertion conditions see the INTSTAT register. Note IRQA# output is floated when RST# is asserted and also used in test modes. |

### **External PCI-32 Pin Signal Type Definition**

Table 2-8. External PCI-32 Pin Signal Type Definition

| Туре     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cin      | Clock Input is a special clock high drive input-only receive signal.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| in       | Input is a standard input-only receive signal.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| t/s      | Three-state is an output signal with control enabled output driver.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| in-t/s   | In-three-state is a bidirectional signal, with control enabled output driver and an internally connected standard input.                                                                                                                                                                                                                                                                                                                                                               |
| in-s/t/s | Sustained Three-state is a bidirectional signal, active low three-state signal and driven by one, and only one, agent at a time. The agent that drives an in-s/t/s signal low must drive it high for at least one PCLK before letting it float. A new agent cannot start driving an in-s/t/s signal any sooner than one clock after the previous owner floats it. A pull-up sustains the inactive state until another agent drives it and is provided by the PCl bus central resource. |
| o/d      | <b>Open Drain</b> is an open drain output. The system board provides a light pull-up for o/d signals. Multiple devices share the signal as a wire-OR. The signal is asserted synchronous with PCLK for one PCLK period. The signal deassertion period is determined by the RC time period provided by the pull-up.                                                                                                                                                                     |

# SCSI Interface Pin Signals

Table 2-9. SCSI Interface Pin Signals

| Symbol    | Type     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|-----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SCD[7:0]# | in-n/o/d | SCSI Data [7:0] #. The SCSI data lines drive the ID during arbitration and selection, and command and data information as well as status and messages. SCD[7:0] are used for 8-bit data transfers.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| SCDPL#    | in-n/o/d | SCSI Low Byte Parity #. This bit provides odd parity for SCD[7:0]#.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| CD#       | in-n/o/d | Command/Data #. This control line is received when in Initiator mode or driven when in Target mode. It indicates Command or Message phase when asserted, and Data phase when deasserted. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                |  |
| IO#       | in-n/o/d | In/Out #. This control line is received when in Initiator mode or driven when in Target mode. It indicates the In direction when asserted, and the Out direction when deasserted. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                       |  |
| MSG#      | in-n/o/d | Message #. This control line is received when in Initiator mode or driven when in Target mode. It indicates a Message phase when asserted, and a Command or Data phase when deasserted. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                 |  |
| REQ#      | in-n/o/d | Request #. This control line is received by the device when in Initiator mode and driven when in Target mode. A Target will assert REQ# to indicate a byte is ready or is needed by the Target. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                         |  |
| ACK#      | in-n/o/d | <b>Acknowledge #.</b> This control line is received by the device when in Target mode and driven when in Initiator mode. An Initiator will assert ACK# to indicate a byte is ready for or was received from the Target. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                 |  |
| RESET#    | in-o/d   | Reset #. This line is received and/or driven. It is interpreted as a hard reset and will clear all commands pending on the SCSI bus. This control signal is used for 8 or 16-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| SEL#      | in-o/d   | <b>Select #</b> . This line is driven after a successful arbitration to Select as an Initiator or Reselect as a Target, and otherwise it is received. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| BSY#      | in-o/d   | <b>Busy #.</b> This line is driven by the Initiator as a handshake during arbitration, and received for the rest of the transfer. As a Target, it is driven also as a handshake during Arbitration, and then is driven for the rest of the transfer. This control signal is used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                    |  |
| ATN#      | in-n/o/d | Attention #. This line is driven as an Initiator when a special condition occurs. It is received by the Target. This control signal is also used for 8-bit transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| STPWDN    | t∕s      | SCSI Termination Power Down Control. Provides the capability to enable or disable the external SCSI bus termination power source. The enable/disable polarity of STPWCTL may be selected with the STPWLEVEL bit in the Configuration DEVCONFIG register and the actual enable/disable state is selected with the STPWEN bit in the Device SXFRCTL1 register. CHIPRST forces STPWCTL to the selected disabled state and STPWEN to the inactive state. While RST# assertion forces STPWCTL to be floated, and both STPWLEVEL and STPWEN to be inactive. STPWCTL may also be used for a general purpose output control bit. |  |

### **SCSI Pin Signal Type Definition**

Table 2-10. SCSI Pin Signal Type Definition

| Туре     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inpu     | Input-pull-up is a standard input-only receive signal with an internal pull-up.                                                                                                                                                                                                                                                                                                                                                                          |
| t/s      | Three-state is an output signal with control enabled output driver.                                                                                                                                                                                                                                                                                                                                                                                      |
| inpu-t/s | Input-pull-up-three-state is a bidirectional signal, with control enabled output driver and an internally connected input with an internal pull-up.                                                                                                                                                                                                                                                                                                      |
| in-n/o/d | Active Negation capable Sustained Open Drain is a hybrid of a three-state and open drain, with internally connected input receiver (with hysteresis and input disable). External logic normally provides pull-up for n/o/d signals and this pull-up may be enhanced by use of the Active Negation function. Multiple devices share the signal as a wire-OR. The output will only provide Active Negation function during SCSI Synchronous Data transfer. |
| in-o/d   | Sustained Open Drain is an open drain output, with internally connected input receiver (with hysteresis and input disable). External logic provides pull-up for o/d signals. Multiple devices share the signal as a wire-OR.                                                                                                                                                                                                                             |

### **Other Pin Signals**

Table 2-11. Other Pin Signals

| Symbol | Туре | Definition                                                                                                                                                                   |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKIN  | in   | Clock Input. Standard input (AIC-7850) - 40 MHz nominal input frequency. Used internally by the SCSI, sequencer, Data FIFO, memory port, and the PCI host blocks for timing. |

### Other Pin Signal Type Definition

Table 2-12. Other Pin Signal Type Definition

| Туре     | Definition                                                                                                                                                              |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| in       | Input is a is a standard input-only receive signal.                                                                                                                     |  |
| inpu-t/s | pu-t/s <b>Input-three-state</b> is a bidirectional signal, with control enabled output driver and an intern connected standard input with internally connected pull-up. |  |
| t/s      | Three-state is an output signal with control enabled output driver.                                                                                                     |  |
| in-t/s   | In-three-state is a bidirectional signal, with control enabled output driver and an internally connected standard input.                                                |  |

### **Power Distribution Pin Signals**

Table 2-13. Core Logic Power Pins

| Pin Name | Usage | Definition                         |
|----------|-------|------------------------------------|
| CVCCn    | PWR   | Core Logic Positive Voltage Supply |
| CGNDn    | PWR   | Core Logic Ground                  |

No other external pins are connected to or utilize power supplied by Core Logic power pin except pin 82.

Table 2-14. SCSI Interface Power Pins

| Pin Name | Usage | Definition                              |
|----------|-------|-----------------------------------------|
| SVCCn    | PWR   | SCSI Bus Driver Positive Voltage Supply |
| SGNDn    | PWR   | SCSI Bus Driver Ground                  |

The following external pins are connected to and utilize power supplied by these pins:

| ACK# | IO#    | RESET#    |
|------|--------|-----------|
| ATN# | SCDPL# | SCD[7:0]# |
| BSY# | MSG#   | SEL#      |
| CD#  | REO#   | STPWDN    |

Table 2-15. PCI Interface Power Pins

| Pin Name | Usage | Definition                             |   |
|----------|-------|----------------------------------------|---|
| PVCCn    | PWR   | PCI Bus Driver Positive Voltage Supply | • |
| PGNDn    | PWR   | PCI Bus Driver Ground                  |   |

The following external pins are connected to and utilize power supplied by the PVCCn pins:

| AD[31:00] | FRAME# | IRQA# | RST#  |
|-----------|--------|-------|-------|
| CBE[3:0]# | GNT#   | PAR   | SERR# |
| CLKIN     | IDSEL  | PERR# | STOP# |
| DEVSEL#   | IRDY#  | PREQ# | TRDY# |

The following external pins are connected to and utilize power supplied by the PGNDn pins:

| AD[31:00] | GNT#  | PAR   | RST#  |
|-----------|-------|-------|-------|
| CBE[3:0]# | IDSEL | PCLK  | SERR# |
| CLKIN     | IRDY# | PERR# | STOP# |
| DEVSEL#   | IRQA# | PREQ# | TRDY# |
| FRAME#    |       |       |       |

Register Description

## **About This Chapter**

Read this chapter to find out

- A summary of the complete name and mnemonic for each register in the AIC-7850 divided into groups with a common address range
- A summary of the AIC-7850 Register Bit Definitions

## \*\*\*\* 3

### **AIC-7850 Register Block Address Map**

The AIC-7850 internal device register block address map (for PCI bus access) is contained within a 256 address range of M00h-MFFh where M is a prefix base address supplied in BASEADR0 or BASEADR1 Configuration space registers.

The AIC-7850 internal configuration register block address map (for PCI bus access) is contained within a 256 address range of N00h-NFFh where N is a prefix address supplied by one of AD[31:11] which is expected to be connected to the AIC-7850 pin IDSEL.

For sequencer access, the Device register block address map is 256 addresses for reading and 256 addresses for writing, both active at the same time, with the range of 00h-FFh and indicated as DS-xx-xx. The block ranges are summarized below.

| Register Block                                 | Address Range     |
|------------------------------------------------|-------------------|
| SCSI                                           | M00-M1F, DS-00-1F |
| Scratch RAM                                    | M20-M5F, DS-20-5F |
| Sequencer<br>(SCSI PhaseEngine)                | M60-M7F, DS-60-7F |
| Host, SCB, Data FIFO                           | M80-M9F, DS-80-9F |
| SCB Array                                      | MA0-MBF, DS-A0-BF |
| RSVD                                           | MC0-MDF, DS-C0-DF |
| RSVD                                           | ME0-MFF, DS-E0-FF |
| Configuration (defined header)                 | N00-N3F           |
| Configuration<br>(device specific)<br>AIC-7850 | N40, N41, N43     |
| Not Used                                       | N42, N44-NFF      |

## **AIC-7850 Register Summary**

The summary below lists the complete name and mnemonic of each register in the chip. The list is divided into groups with a common address range. When the host must access these registers the sequencer must be paused, except when noted otherwise.

### **SCSI Device Registers**

M00-M1F, DS-00-1F

Table 3-1. SCSI Device Registers

| Register Name                | Mnemonic | Read/Write | Size        | Init | Address | Comments                                                          |
|------------------------------|----------|------------|-------------|------|---------|-------------------------------------------------------------------|
| SCSI Sequencer Control       | SCSISEQ  | R/W        | 8/8         | 00   | M00     |                                                                   |
| SCSI Transfer Control 0      | SXFRCTL0 | R/W        | 6/6         | 00   | M01     |                                                                   |
| SCSI Transfer Control 1      | SXFRCTL1 | R/W        | 8/8         | 00   | M02     |                                                                   |
| SCSI Signal In               | SCSISIGI | R/         | 8/          | XX   | M03     |                                                                   |
| SCSI Signal Out              | SCSISIGO | /W         | /8          | _    | M03     |                                                                   |
| SCSI Rate                    | SCSIRATE | R/W        | 7/8         | 00   | M04     |                                                                   |
| SCSLID                       | SCSIID   | R/W        | 8/8         | 00   | M05     |                                                                   |
| SCSI Latched Data Low        | SCSIDATL | R/W        | <b>8</b> /8 | XX   | M06     |                                                                   |
| SCSI Latched Data High       | SCSIDATH | RSVD       | 0/0         | XX   | M07     |                                                                   |
| SCSI Transfer Count 0        | STCNT0   | R/W        | 8/8         | 00   | M08     |                                                                   |
| SCSI Transfer Count 1        | STCNT1   | R/W        | 8/8         | 00   | M09     |                                                                   |
| SCSI Transfer Count 2        | STCNT2   | R/W        | 8/8         | 00   | MOA     |                                                                   |
| Clear SCSI Interrupt 0       | CLRSINT0 | /W         | /5          | -    | MOB     |                                                                   |
| Clear SCSI Interrupt 1       | CLRSINT1 | /W         | /7          | -    | MOC     |                                                                   |
| SCSI Status 0                | SSTAT0   | R/         | 8/          | 00   | MOB     |                                                                   |
| SCSI Status 1                | SSTAT1   | R/         | 8/          | 00   | MOC     |                                                                   |
| SCSI Status 2                | SSTAT2   | R/         | 6/          | 00   | M0D     |                                                                   |
| SCSI Status 3                | SSTAT3   | R/         | 8/          | 00   | MOE     |                                                                   |
| SCSI Test                    | SCSITEST | R/W        | 4/4         | 00   | MOF     |                                                                   |
| SCSI Interrupt Mode 0        | SIMODE0  | R/W        | 7/7         | 00   | M10     |                                                                   |
| SCSI Interrupt Mode 1        | SIMODE1  | R/W        | 8/8         | 00   | M11     |                                                                   |
| SCSI Data Bus Low            | SCSIBUSL | R/         | 8/          | XX   | M12     |                                                                   |
| SCSI Data Bus High           | SCSIBUSH | RSVD       | 0/          | XX   | M13     |                                                                   |
| SCSI Count Host<br>Address 0 | SHADDR0  | R/         | 8/          | 00   | M14     | Written when HADDLDSEL[1:0]=0 with same value as LHADDR0          |
| SCSI Count Host<br>Address 1 | SHADDR1  | R/         | 8/          | 00   | M15     | Written when<br>HADDLDSEL[1:0]=0<br>with same value as<br>LHADDR1 |
| SCSI Count Host<br>Address 2 | SHADDR2  | R/         | 8/          | 00   | M16     | Written when HADDLDSEL[1:0]=0 with same value as LHADDR2          |

Table 3-1. SCSI Device Registers (Continued)

| Register Name                | Mnemonic | Read/Write | Size | Init | Address | Comments                                                 |
|------------------------------|----------|------------|------|------|---------|----------------------------------------------------------|
| SCSI Count Host<br>Address 3 | SHADDR3  | R/         | 8/   | 00   | M17     | Written when HADDLDSEL[1:0]=0 with same value as LHADDR3 |
| Selection Time-out Timer     | SELTIMER | R/         | 7/   | 00   | M18     |                                                          |
| Selection/Reselection ID     | SELID    | R/         | 4/   | 00   | M19     |                                                          |
| SCSI Block Control           | SBLKCTL  | R/W        | 3/3  | 0    | M1F     |                                                          |

#### **Scratch RAM Device Register**

M20-M5F, DS-20-5F

The scratch RAM area is addressed directly by the sequencer or host driver and is organized as 64 dual-ported byte locations. It is used to store information about the SCSI bus setup, the current operation, or system parameters. It is also used by the sequencer for temporary storage during operation. The sequencer may do read-modify-write accesses in a single access while the host driver may only do either a read or a write during an access. The scratch RAM also contains the capability to be parity protected, see MPARCKEN in the Device Command register.

Table 3-2. Scratch RAM Device

| Register Name          | Mnemonic | Read/Write | Comments |  |
|------------------------|----------|------------|----------|--|
| Scratch RAM (64 bytes) | Scratch  | R/W        |          |  |

## **Sequencer Device Registers**

M60-M7F, DS-60-7F

Table 3-3. Sequencer Device Registers

| Register name                 | Mnemonic | Read/Write | Size | Init | Address | Comments                  |
|-------------------------------|----------|------------|------|------|---------|---------------------------|
| Sequencer Control             | SEQCTL   | R/W        | 8/8  | 90   | M60     |                           |
| Sequencer RAM                 | SEQRAM   | R/W        | 8/8  | XX   | M61     |                           |
| Sequencer RAM Address<br>Low  | SEQADDRL | R/W        | 8/8  | 00   | M62     |                           |
| Sequencer RAM Address<br>High | SEQADDRH | R/W        | 1/1  | 00   | M63     |                           |
| Accumulator                   | ACCUM    | R/W        | 8/8  | 00   | M64     |                           |
| Source Index Register         | SINDEX   | R/W        | 8/8  | 00   | M65     |                           |
| Destination Index Register    | DINDEX   | R/W        | 8/8  | 00   | M66     |                           |
| Break Address 0               | BRKADDR0 | R/W        | 8/8  | 00   | M67     |                           |
| Break Address 1               | BRKADDR1 | R/W        | 2/2  | 80   | M68     |                           |
| All Ones                      | ALLONES  | R/         | 8/   | FF   | M69     |                           |
| All Zeros                     | ALLZEROS | R/         | 8/   | 00   | M6A     |                           |
| No destination                | NONE     | /W         | /8   | -    | M6A     |                           |
| Flags                         | FLAGS    | R/         | 2/   | 00   | M6B     |                           |
| Source Indirect               | SINDIR   | R/         | 8/   | 00   | DS-6C   | Not usable by host driver |
| Destination Indirect          | DINDIR   | /W         | /8   | -    | DS-6D   | Not usable by host driver |
| Function 1                    | FUNCT1   | R/W        | 3/3  | XX   | M6E     |                           |
| Stack                         | STACK    | R/         | 8/   | 00   | M6F     |                           |

## **Host Device Registers**

M80-M9F, DS-80-9F

Table 3-4. Host Device Registers

| Register Name             | Mnemonic    | Read/Write | Size | Init | Address | Comments           |
|---------------------------|-------------|------------|------|------|---------|--------------------|
| DSVendor Identification 0 | DSVENDID0   | R/         | 8/   | 04   | M80     | Host only          |
| DSVendor Identification 1 | DSVENDID1   | R/         | 8/   | 90   | M81     | Host only          |
| DSDevice Identification 0 | DSDEVID0    | R/         | 8/   | 78   | M82     | Host only          |
| DSDevice Identification 1 | DSDEVID1    | R/         | 8/   | 1    | M83     | Host only          |
| DSCommand                 | DSCOMMAND   | R/W        | 8/4  | 00   | M84     |                    |
| DSLatency Timer           | DSLATTIME   | R/         | 8/   | 00   | M85     |                    |
| DSPCi Status              | DSPCISTATUS | R/W        | 8/2  | 00   | M86     |                    |
| Host Control              | HCNTRL      | R/W        | 7/7  | 05   | M87     | Host only          |
| Low Host Address 0        | LHADDR0     | R/W        | 8/8  | 00   | M88     | HADDLDSEL[1:0] = 0 |
| Low Host Address 1        | LHADDR1     | R/W        | 8/8  | 00   | M89     |                    |
| Low Host Address 2        | LHADDR2     | R/W        | 8/8  | 00   | M8A     |                    |
| Low Host Address 3        | LHADDR3     | R/W        | 8/8  | 00   | M8B     |                    |
| High Host Address 0       | HHADDR0     | R/W        | 8/8  | 00   | M88     | HADDLDSEL[1:0] = 1 |
| High Host Address 1       | HHADDR1     | R/W        | 8/8  | 00   | M89     |                    |
| High Host Address 2       | HHADDR2     | R/W        | 8/8  | 00   | M8A     |                    |
| High Host Address 3       | HHADDR3     | R/W        | 8/8  | 00   | M8B     |                    |
| Host Byte Count 0         | HCNT0       | R/W        | 8/8  | 00   | M8C     |                    |
| Host Byte Count 1         | HCNT1       | R/W        | 8/8  | 00   | M8D     |                    |
| Host Byte Count 2         | HCNT2       | R/W        | 8/8  | 00   | M8E     |                    |
| Interrupt Status          | INTSTAT     | W          | /6   | 00   | M91     |                    |
| Interrupt Status          | INTSTAT     | R/         | 8/6  | 00   | M91     | Host only          |
| Clear Interrupt           | CLRINT      | W          | /4   | -    | M92     | Host only          |
| Error                     | ERROR       | R/         | 7/   | 00   | M92     | Host only          |
| Data FIFO Control         | DFCNTRL     | R/W        | 7/7  | 00   | M93     |                    |
| Data FIFO Status          | DFSTATUS    | R/         | 7/   | 21   | M94     |                    |
| Queue Out FIFO            | QOUTFIFO    | R/         | /3   | -    | M9D     | Read by host only  |
| Queue Out Count           | QOUTCNT     | R/         | 8/   | 00   | M9E     | Read by host only  |
| Special Function          | SFUNCT      | R/W        | 8/8  | 00   | M9F     |                    |
| Sleep Control             | SLEEPCTL    | R/W        | 3/3  | 00   | M1C     |                    |

<sup>1</sup> Internal default value (50).

### **Host Configuration Registers**

N00-NFF

Note: Register bytes not listed are reserved, read only and always return 0h when read.

Table 3-5. Host Configuration Registers

| Register Name                  | Mnemonic  | Read/Write | Size  | Init | Address | Comments           |
|--------------------------------|-----------|------------|-------|------|---------|--------------------|
| Vendor Identification 0        | VENDORID0 | R/         | 8/    | 04   | 00      | Byte 0 host only   |
| Vendor Identification 1        | VENDORID1 | R/         | 8/    | 90   | N00     | Byte 1 host only   |
| Device Identification 0        | DEVICEID0 | R/         | 8/    | 78   | N00     | Byte 2 host only   |
| Device Identification 1        | DEVICEID1 | R/         | 8/    | 1    | N00     | Byte 3 host only   |
| Command 0                      | COMMAND0  | R/W        | 8/5   | 00   | N04     | Byte 0 host only   |
| Command 1                      | COMMAND1  | R/W        | 8/1   | 00   | N04     | Byte 1 host only   |
| PCI Status 0                   | STATUS0   | R/         | 8/    | 00   | N04     | Byte 2 host only   |
| PCI Status 1                   | STATUS1   | $R/^2$     | 8/6   | 02   | N04     | Byte 3 host only   |
| Device Revision ID             | DEVREVID  | R/         | 8/    | 02   | N08     | Byte 0 host only   |
| Programming Interface          | PROGINFO  | R/         | 8/    | 00   | N08     | Byte 1 host only   |
| Sub Class                      | SUBCLASS  | R/         | 8/    | 00   | N08     | Byte 2 host only   |
| Base Class                     | BASECLASS | R/         | 8/    | 00   | N08     | Byte 3 host only   |
| Cache Line Size                | CACHESIZE | R/W        | 8/4   | 00   | NOC     | Byte 0 host only   |
| Latency Time                   | LATTIME   | R/W        | 8/6   | 00   | N0C     | Byte 1 host only   |
| Header Type                    | HDRTYPE   | R/         | 8/    | 00   | N0C     | Byte 2 host only   |
| Base Address 0<br>(32-bits)    | BASEADR0  | R/W        | 32/24 | 02   | N10     | Byte 0-3 host only |
| Base Address 1<br>(32-bits)    | BASEADR1  | R/W        | 32/20 | 00   | N14     | Byte 0-3 host only |
| External ROM Control (32-bits) | EXROMCTL  | R/W        | 0/0   | 00   | N30     | Always read 0      |
| Interrupt Line Select          | INTLINSEL | RW         | 8/8   | 00   | N3C     | Byte 0 host only   |
| Interrupt Pin Select           | INTPINSEL | R/         | 8/    | 01   | N3C     | Byte 1 host only   |
| Min_Gnt Status                 | MINGNT    | R/         | 8/    | 08   | N3C     | Byte 2 host only   |
| Max_Lat Status                 | MAXLAT    | R/         | 8/    | 08   | N3C     | Byte 3 host only   |
| Device Configuration           | DEVCONFIG | R/W        | 8/8   | 00   | N40     | Byte 0 host only   |
| Device Status                  | DEVSTATUS | R/         | 3/    | 3    | N40     | Byte 1 host only   |
| PCI Error Generation           | PCIERRGEN | R/W        | 6/6   | 00   | N40     | Byte 3 host only   |

<sup>1</sup> Internal (50).
2 Write of a one value forces active read value to be inactive. Internal default value.

<sup>&</sup>lt;sup>3</sup> Depends on external conditions (PCI bus voltage).

#### **SCB Device Registers**

M90, M9A-M9D, DS-90, 9A-9D

Table 3-6. SCB Device Registers

| Register Name  | Mnemonic | Read/Write | Size | Init | Address | Comments |
|----------------|----------|------------|------|------|---------|----------|
| SCB Pointer    | SCBPTR   | R/W        | 8/8  | 00   | M90     |          |
| SCB Counter    | SCBCNT   | R/W        | 6/6  | 00   | M9A     |          |
| Queue In FIFO  | QINFIFO  | R/W        | 3/3  | 00   | M9B     |          |
| Queue In Count | QINCNT   | R/         | 8/   | 00   | M9C     |          |
| Queue Out FIFO | QOUTFIFO | W          | /3   | _    | M9D     |          |

#### Memory Port Device Registers<sup>1</sup>

Table 3-7. Memory Port Device Registers

| Register Name         | Mnemonic | Read/Write | Size | Init | Address | Comments        |
|-----------------------|----------|------------|------|------|---------|-----------------|
| Serial EEPROM Control | SEECTL   | RSVD       | 0/0  | 00   | M1E     | Always reads 0. |
| Board Control         | BRDCTL   | RSVD       | 0/0  | 00   | M1D     | Always reads 0. |

<sup>&</sup>lt;sup>1</sup> The memory port registers are not supported in the AIC-7850.

#### **Data FIFO Device Registers**

M95, M97, M99 DS-95, 97, 99

Table 3-8. Data FIFO Device Registers

| Register Name           | Mnemonic | Read/Write | Size | Init | Address     | Comments |
|-------------------------|----------|------------|------|------|-------------|----------|
| Data FIFO Write Address | DFWADDR  | R/W        | 7/6  | 00   | M95         |          |
| Data FIFO Read Address  | DFRADDR  | R/W        | 7/6  | 00   | M97         |          |
| Data FIFO Data          | DFDAT    | R/W        | 8/8  | XX   | <b>M</b> 99 |          |

### SCB Array

MA0-MBF, DS-A0-BF

The SCB Array contains a number of 32 byte pages. SCB page selection is determined by the value stored in the Device SCBPTR register. SCB Array pages that have been loaded with valid SCB data are indicated by loading their SCB Array page values into the Queue In FIFO. The sequencer may do read-modify-write instructions in a single access to a selected page. The host driver can only do a read or a write instruction during an access to a selected page, and only when the sequencer is paused (see the PAUSE bit in the device HCNTRL register).

Three SCBs may be stored in the AIC-7850 internal SCB Array. The SCB Array also contains the capability to be parity protected, see MPARCKEN in the Device Command register. The lower 5-bits of the SCB Array address for each SCB page are the same as bits AD[4:2] of the host address bus with bits [1:0] decoded from the single asserted CBE[3:0]# bit, or bits [4:0] of the sequencer address buses, or bits SCBCNT[4:0] of the SCB-

CNT register The upper address bits that select the SCB page are provided by the SCBPTR register.

Table 3-9. SCB Array

| Register Name         | Mnemonic | Read/Write | Comments     |
|-----------------------|----------|------------|--------------|
| SCB Array (pages 0-2) | SCB      | R/W        | Internal RAM |

# **AIC-7850 Register Bit Definition Summary**

Device register address access source is indicated by adding a prefix to the basic register address: PCI source (M, N), Sequencer (DS). All unused and reserved register bits read as 0, and should be written with 0. All unassigned register locations return 0. Reserved (RSVD) denotes anticipated usage. Unused bits are available for future definition.

#### **SCSI Registers**

| SCSISEQ                                                                                 | SXFRCTL0                                                  | SXFRCTL1                                                                                   | SCSISIGO                                                                     | SCSISIGI                                                                   | SCSIRATE                                                                                                |
|-----------------------------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| R/W M/DS-00 (b)                                                                         | R/W M/DS-01 (b)                                           | R/W M/DS-02 (b)                                                                            | W M/DS-03 (b)                                                                | FI M/DS-03 (b)                                                             | R/W M/DS-04 (b)                                                                                         |
| 7 TEMODEO 6 ENSELO 5 ENSELI 4 ENRSELI 3 ENAUTOATNO 2 ENAUTOATNI 1 ENAUTOATNP 0 SCSIRSTO | 7 DFON 6 DFPEXP 5 4 CLRSTCNT 3 SPIOEN 2 SCAMEN 1 CLRCHN 0 | 7 BITBUCKET 6 SWRAPEN 5 ENSPCHK 4 STIMESEL(1) 3 STIMESEL(0) 2 ENSTIMER 1 ACTNEGEN 0 STPWEN | 7 CDO<br>6 IOO<br>5 MSGO<br>4 IATNO<br>3 SELO<br>2 BSYO<br>1 TREQO<br>0 ACKO | 7 CDI<br>6 IOI<br>5 MSGI<br>4 ATNI<br>3 SELI<br>2 BSYI<br>1 REQI<br>0 ACKI | 7 WIDEXFER=0<br>6 SXFR(2)<br>5 SXFR(1)<br>4 SXFR(0)<br>3 SOFS(3)<br>2 SOFS(2)<br>1 SOFS(1)<br>0 SOFS(0) |

| SCSIID<br>R/W M/DS-05 (b) | SCSIDATL<br>R/W M/DS-06 (b) | SCSIDATH<br>R/W M/DS-07 (b) | STCNTO<br>R/W M/DS-08 (b) | STCNT1<br>R/W M/DS-09 (b) | STCNT2<br>R/W M/DS-0A (b) |
|---------------------------|-----------------------------|-----------------------------|---------------------------|---------------------------|---------------------------|
| 7 TID(3)                  | 7 DB(07)                    | 7 RSVD                      | 7 STCNT(07)               | 7 STCNT(15)               | 7 STCNT(23)               |
| 6 TID(2)                  | 6 DB(06)                    | 6 RSVD                      | 6 STCNT(06)               | 6 STCNT(14)               | 6 STCNT(22)               |
| 5 TID(1)                  | 5 DB(05)                    | 5 RSVD                      | 5 STCNT(05)               | 5 STCNT(13)               | 5 STCNT(21)               |
| 4 TID(0)                  | 4 DB(04)                    | 4 RSVD                      | 4 STCNT(04)               | 4 STCNT(12)               | 4 STCNT(20)               |
| 3 OID(3)                  | 3 DB(03)                    | 3 RSVD                      | 3 STCNT(03)               | 3 STCNT(11)               | 3 STCNT(19)               |
| 2 OID(2)                  | 2 DB(02)                    | 2 RSVD                      | 2 STCNT(02)               | 2 STCNT(10)               | 2 STCNT(18)               |
| 1 OID(1)                  | 1 DB(01)                    | 1 RSVD                      | 1 STCNT(01)               | 1 STCNT(09)               | 1 STCNT(17)               |
| 0 OID(0)                  | 0 DB(00)                    | 0 RSVD                      | 0 STCNT(00)               | 0 STCNT(08)               | 0 STCNT(16)               |

| CLRSINTO                                                         | SSTATO                                                                 | CLRSINT1                                                                                     | SSTAT1                                                                            | SSTAT2                                                               | SSTAT3                                                                                                                   |
|------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| W M/DS-0B (b)                                                    | R M/DS-0B (b)                                                          | W M/DS-0C (b)                                                                                | R M/DS-0C (b)                                                                     | R M/DS-0D (b)                                                        | R M/DS-0E (b)                                                                                                            |
| 7 6 CLRSELDO 5 CLRSELDI 4 CLRSELINGO 3 CLRSWRAP 2 1 CLRSPIORDY 0 | 7 TARGET 6 SELDO 5 SELDI 4 SELINGO 3 SWRAP 2 SDONE 1 SPIORDY 0 DMADONE | 7 CLRSELTIMO 6 CLRATNO 5 CLRSCSIRSTI 4 3 CLRBUSFREE 2 CLRSCSIPERR 1 CLRPHASECHG 0 CLRREQINIT | 7 SELTO 6 ATNTARG 5 SCSIRSTI 4 PHASEMIS 3 BUSFREE 2 SCSIPERR 1 PHASECHG 0 REQINIT | 7 OVERRUN 6 5 4 SFCNT(4) 3 SFCNT(3) 2 SFCNT(2) 1 SFCNT(1) 0 SFCNT(0) | 7 SCSICNT(3)<br>6 SCSICNT(2)<br>5 SCSICNT(1)<br>4 SCSICNT(0)<br>3 OFFCNT(3)<br>2 OFFCNT(2)<br>1 OFFCNT(1)<br>0 OFFCNT(0) |

| SIMODE0<br>R/W M/DS-10 (b) | SIMODE1<br>R/W M/DS-11 (b)                                             | SCSIBUSL<br>R M/DS-12 (b)                                                                                                                                                                                                                                                                                                        | SCSIBUSH<br>R M/DS-13 (b)                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SHADDRO<br>R M/DS-14 (bh)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7                          | 7 ENSELTIMO                                                            | 7 SDB(07)                                                                                                                                                                                                                                                                                                                        | 7 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 7 SHADDR(07)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6 ENSELDO                  | 6 ENATNTARG                                                            | 6 SDB(06)                                                                                                                                                                                                                                                                                                                        | 6 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 6 SHADDR(06)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5 ENSELDI                  | 5 ENSCSIRST                                                            | 5 SDB(05)                                                                                                                                                                                                                                                                                                                        | 5 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5 SHADDR(05)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4 ENSELINGO                | 4 ENPHASEMIS                                                           | 4 SDB(04)                                                                                                                                                                                                                                                                                                                        | 4 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 4 SHADDR(04)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3 ENSWRAP                  | 3 ENBUSFREE                                                            | 3 SDB(03)                                                                                                                                                                                                                                                                                                                        | 3 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3 SHADDR(03)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2 ENSDONE                  | 2 ENSCSIPERR                                                           | 2 SDB(02)                                                                                                                                                                                                                                                                                                                        | 2 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 2 SHADDR(02)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1 ENSPIORDY                | 1 ENPHASECHG                                                           | 1 SDB(01)                                                                                                                                                                                                                                                                                                                        | 1 RSVD                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 SHADDR(01)<br>0 SHADDR(00)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                            | R/W M/DS-10 (b)  7 6 ENSELDO 5 ENSELDI 4 ENSELINGO 3 ENSWRAP 2 ENSDONE | R/W M/DS-10 (b)         R/W M/DS-11 (b)           7         7 ENSELTIMO           6 ENSELDO         6 ENATNTARG           5 ENSCSIRST         4 ENSELINGO           4 ENSELINGO         4 ENPHASEMIS           3 ENSWRAP         3 ENBUSFREE           2 ENSDONE         2 ENSCSIPERR           1 ENSPIORDY         1 ENPHASECHG | R/W M/DS-10 (b)         R/W M/DS-11 (b)         R M/DS-12 (b)           7         7 ENSELTIMO         7 SDB(07)           6 ENSELDO         6 ENATNTARG         6 SDB(06)           5 ENSELDI         5 ENSCSIRST         5 SDB(05)           4 ENSELINGO         4 ENPHASEMIS         4 SDB(04)           3 ENSWRAP         3 ENBUSFREE         3 SDB(03)           2 ENSDONE         2 ENSCSIPERR         2 SDB(02)           1 ENSPIORDY         1 ENPHASECHG         1 SDB(01) | R/W M/DS-10 (b)         R/W M/DS-11 (b)         R M/DS-12 (b)         R M/DS-13 (b)           7         7 ENSELTIMO         7 SDB(07)         7 RSVD           6 ENSELDO         6 ENATNTARG         6 SDB(06)         6 RSVD           5 ENSELDI         5 ENSCSIRST         5 SDB(05)         5 RSVD           4 ENSELINGO         4 ENPHASEMIS         4 SDB(04)         4 RSVD           3 ENSWRAP         3 ENBUSFREE         3 SDB(03)         3 RSVD           2 ENSDONE         2 ENSCSIPERR         2 SDB(02)         2 RSVD           1 ENSPIORDY         1 ENPHASECHG         1 SDB(01)         1 RSVD |

| SHADDR1<br>R M/DS-15 (bh)                                                                                    | SHADDR2<br>R M/DS-16 (bh)                                                                                    | SHADDR3<br>R M/DS-17 (bh)                                                                                    | SELTIMER<br>R M/DS-18 (b)                                                      | SELID<br>R M/DS-19 (b)                                            | SBLKCTL<br>R/W M/DS-1F (b)                                         |
|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------|
| 7 SHADDR(15)<br>6 SHADDR(14)<br>5 SHADDR(13)<br>4 SHADDR(12)<br>3 SHADDR(11)<br>2 SHADDR(10)<br>1 SHADDR(09) | 7 SHADDR(23)<br>6 SHADDR(22)<br>5 SHADDR(21)<br>4 SHADDR(20)<br>3 SHADDR(19)<br>2 SHADDR(18)<br>1 SHADDR(17) | 7 SHADDR(31)<br>6 SHADDR(30)<br>5 SHADDR(29)<br>4 SHADDR(28)<br>3 SHADDR(27)<br>2 SHADDR(26)<br>1 SHADDR(25) | 7 CLKOUT<br>6<br>5 STAGE 6<br>4 STAGE 5<br>3 STAGE 4<br>2 STAGE 3<br>1 STAGE 2 | 7 RSVD<br>6 SELID(2)<br>5 SELID(1)<br>4 SELID(0)<br>3 ONEBIT<br>2 | 7 DIAGLEDEN 6 DIAGLEDON 5 AUTOFLUSHDIS 4 3 SELBUSB=0 2 1 SELWIDE=0 |
| 0 SHADDR(08)                                                                                                 | 0 SHADDR(16)                                                                                                 | 0 SHADDR(24)                                                                                                 | 0 STAGE 1                                                                      | 0                                                                 | 0                                                                  |

## **Sequencer Registers**

| SEQCTL<br>R/W M/DS-60 (b) | SEQRAM<br>R/W M/DS-61 (b) | SEQADDRO<br>R/W M/DS-62 (b) | SEQADDR1<br>R/W M/DS-63 (b) | ACCUM<br>R/W M/DS-64 (b) | SINDEX<br>R/W M/DS-65 (b) |
|---------------------------|---------------------------|-----------------------------|-----------------------------|--------------------------|---------------------------|
| 7 PERRORDIS               | 7 SEQRAM(7)               | 7 SEQADDR(07)               | 7                           | 7 ACCUM(7)               | 7 SINDEX(7)               |
| 6 PAUSEDIS                | 6 SEQRAM(6)               | 6 SEQADDR(06)               | 6                           | 6 ACCUM(6)               | 6 SINDEX(6)               |
| 5 FAILDIS                 | 5 SEQRAM(5)               | 5 SEQADDR(05)               | 5 RSVD                      | 5 ACCUM(5)               | 5 SINDEX(5)               |
| 4 FASTMODE                | 4 SEQRAM(4)               | 4 SEQADDR(04)               | 4 RSVD                      | 4 ACCUM(4)               | 4 SINDEX(4)               |
| 3 BRKADRINTEN             | 3 SEQRAM(3)               | 3 SEQADDR(03)               | 3 RSVD                      | 3 ACCUM(3)               | 3 SINDEX(3)               |
| 2 STEP                    | 2 SEQRAM(2)               | 2 SEQADDR(02)               | 2 RSVD                      | 2 ACCUM(2)               | 2 SINDEX(2)               |
| 1 SEQRESET                | 1 SEQRAM(1)               | 1 SEQADDR(01)               | 1 RSVD                      | 1 ACCUM(1)               | 1 SINDEX(1)               |
| 0 LOADRAM                 | 0 SEQRAM(0)               | 0 SEQADDR(00)               | 0 SEQADDR(08)               | 0 ACCUM(0)               | 0 SINDEX(0)               |

| DINDEX<br>R/W M/DS-66 (b) | BRKADDRO<br>R/W M/DS-67 (b) | BRKADDR1<br>R/W M/DS-68 (b) | ALLONES<br>R M/DS-69 (b) | ALLZEROS<br>R MVDS-6A (b) | NONE<br>W M/DS-6A (b) |
|---------------------------|-----------------------------|-----------------------------|--------------------------|---------------------------|-----------------------|
| 7 DINDEX(7)               | 7 BRKADDR(07)               | 7 BRKDIS                    | 7 (1)                    | 7 (0)                     | 7                     |
| 6 DINDEX(6)               | 6 BRKADDR(06)               | 6                           | 6 (1)                    | 6 (0)                     | 6                     |
| 5 DINDEX(5)               | 5 BRKADDR(05)               | 5 RSVD                      | 5 (1)                    | 5 (0)                     | 5                     |
| 4 DINDEX(4)               | 4 BRKADDR(04)               | 4 RSVD                      | 4 (1)                    | 4 (0)                     | 4                     |
| 3 DINDEX(3)               | 3 BRKADDR(03)               | 3 RSVD                      | 3 (1)                    | 3 (0)                     | 3                     |
| 2 DINDEX(2)               | 2 BRKADDR(02)               | 2 RSVD                      | 2 (1)                    | 2 (0)                     | 2                     |
| 1 DINDEX(1)               | 1 BRKADDR(01)               | 1 RSVD                      | 1 (1)                    | 1 (0)                     | 1                     |
| 0 DINDEX(0)               | 0 BRKADDR(00)               | 0 BRKADDR(08)               | 0 (1)                    | 0 (0)                     | 0                     |

| FLAGS<br>R M/DS-6B (b) | SINDIR<br>R DS-6C | DINDIR<br>W DS-6D | FUNCTION1<br>W M/DS-6E (b) | FUNCTION1<br>R M/DS-6E (b) | STACK<br>R M/DS-6F (b) |
|------------------------|-------------------|-------------------|----------------------------|----------------------------|------------------------|
| 7                      | CONTENTS          | CONTENTS          | 7 RSVD                     | 1 OF 8                     | 7 STACK(07)            |
| 6                      | POINTED TO BY     | POINTED TO BY     | 6 FUN1DAT(2)               | DECODED                    | 6 STACK(06)            |
| 5                      | SINDEX            | DINDEX            | 5 FUN1DAT(1)               | VALUE OF                   | 5 STACK(05)            |
| 4                      |                   |                   | 4 FUN1DAT(0)               | FUN1DAT2-0                 | 4 STACK(04)            |
| 3                      |                   |                   | 3 RSVD                     | {                          | 3 STACK(03)            |
| 2                      |                   |                   | 2 RSVD                     |                            | 2 STACK(02)            |
| 1 ZERO                 |                   |                   | 1 RSVD                     |                            | 1 STACK(01)            |
| 0 CARRY                |                   |                   | 0 RSVD                     | 1                          | 0 STACK(00)            |

## **Host Configuration Registers**

| DEVICEID1<br>R NOOh *+ | DEVICEIDO<br>R Nooh ** | VENDORID1<br>R N00h ** | VENDORIDO<br>R NOOh ** |
|------------------------|------------------------|------------------------|------------------------|
| 31 DID15≈0             | 23 DID07=0 \           | 15 VID15=1             | 07 VID07=0             |
| 30 DID14≈1             | 22 DID06=1 IMS         | 14 VID14=0             | 06 VID06=0             |
| 29 DID13=0             | 21 DID05=1             | 13 VID13=0             | 05 VID05=0             |
| 28 DID12=1             | 20 DID04=1 /           | 12 VID12=1             | 04 VID04=0             |
| 27 DID11=0 \           | 19 DID03=1             | 11 VID11=0             | 03 VID03=0             |
| 26 DID10=0   LS        | 18 DID02=0             | 10 VID10=0             | 02 VID02=1             |
| 25 DID09=0 I           | 17 DID01=0             | 09 VID09=0             | 01 VID01=0             |
| 24 DID08=0 /           | 16 DID00=0             | 08 VID08=0             | 00 VID00=0             |

| STATUS1<br>R/W N04h ** | STATUSO<br>R NO4h | COMMAND1<br>R/W N04h** | COMMANDO<br>R/W N04h ** |
|------------------------|-------------------|------------------------|-------------------------|
| 31 DPE                 | 23 TFBFBC=1       | 15 RSVD                | 07 WAITCTLEN=0          |
| 30 SSE                 | 22 RSVD           | 14 RSVD                | 06 PERRESPEN            |
| 29 RMA                 | 21 RSVD           | 13 RSVD                | 05 VSNOOPEN=0           |
| 28 RTA                 | 20 RSVD           | 12 RSVD                | 04 MWRICEN              |
| 27 STA                 | 19 RSVD           | 11 RSVD                | 03 SPCYCEN=0            |
| 26 DST1=0              | 18 RSVD           | 10 RSVD                | 02 MASTEREN             |
| 25 DST0=1              | 17 RSVD           | 09 MFBFEN=0            | 01 MSPACEEN             |
| 24 DPR                 | 16 RSVD           | 08 SERRESPEN           | 00 ISPACEEN             |

| BASECLASS<br>R N08h | SUBCLASS<br>R NO8h | PROGINFC<br>R N08h | DEVREVID<br>R NO8h ++ |
|---------------------|--------------------|--------------------|-----------------------|
| 31 BCLASS7=0        | 23 SCLASS7=0       | 15 PINFC7=0        | 07 DRID7=0            |
| 30 BCLASS6=0        | 22 SCLASS6=0       | 14 PINFC6=0        | 06 DRID6=0            |
| 29 BCLASS5=0        | 21 SCLASS5=0       | 13 PINFC5=0        | 05 DRID5=0            |
| 28 BCLASS4=0        | 20 SCLASS4=0       | 12 PINFC4=0        | 04 DRID4=0            |
| 27 BCLASS3=0        | 19 SCLASS3=0       | 11 PINFC3=0        | 03 DRID3=0            |
| 26 BCLASS2=0        | 18 SCLASS2=0       | 10 PINFC2=0        | 02 DRID2=0            |
| 25 BCLASS1=0        | 17 SCLASS1=0       | 09 PINFC1=0        | 01 DRID1=1            |
| 24 BCLASS0=1        | 16 SCLASS0=0       | 08 PINFC0=0        | 00 DRID0=0            |

| RSVD                                                                                 | HDRTYPE                                                                                                             | LATTIME                                                                     | CACHESIZE                                                                                         |
|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| R NOCh                                                                               | R NOCh                                                                                                              | R/W N0Ch **                                                                 | R/W Noch                                                                                          |
| 31 RSVD<br>30 RSVD<br>29 RSVD<br>28 RSVD<br>27 RSVD<br>26 RSVD<br>25 RSVD<br>24 RSVD | 23 MFDEV=0<br>22 HTYPE6=0<br>21 HTYPE5=0<br>20 HTYPE4=0<br>19 HTYPE3=0<br>18 HTYPE2=0<br>17 HTYPE1=0<br>16 HTYPE0=0 | 15 LATT7 14 LATT6 13 LATT5 12 LATT4 11 LATT3 10 LATT2 09 LATT1=0 08 LATT0=0 | 07 RSVD 06 RSVD 05 CDWDSIZE5 04 CDWDSIZE4 03 CDWDSIZE3 02 CDWDSIZE2 01 CDWDSIZE1=0 00 CDWDSIZE0=0 |

| BASEADRO<br>R/W N10h | BASEADRO<br>R/W N10h | BASEADRO<br>R/W N10h | BASEADRO<br>R/W N10h |
|----------------------|----------------------|----------------------|----------------------|
| 31 IBMADR29          | 23 IBMADR21          | 15 IBMADR13          | 07 IBMADR05=0        |
| 30 IBMADR28          | 22 IBMADR20          | 14 IBMADR12          | 06 IBMADR04=0        |
| 29 IBMADR27          | 21 IBMADR19          | 13 IBMADR11          | 05 IBMADR03=0        |
| 28 IBMADR26          | 20 IBMADR18          | 12 IBMADR10          | 04 IBMADR02=0        |
| 27 IBMADR25          | 19 IBMADR17          | 11 IBMADR09          | 03 IBMADR01≃0        |
| 26 IBMADR24          | 18 IBMADR16          | 10 IBMADR08          | 02 IBMADR00=0        |
| 25 IBMADR23          | 17 IBMADR15          | 09 IBMADR07          | 01 RSVD              |
| 24 IBMADR22          | 16 IBMADR14          | 08 IBMADR06          | 00 ISPACEIND=1       |

| BASEADR1<br>R/W N14h | BASEADR1<br>R/W N14h | BASEADR1<br>R/W N14h | BASEADR1<br>R/W N14h |
|----------------------|----------------------|----------------------|----------------------|
| 31 MBMADR27          | 23 MBMADR19          | 15 MBMADR11          | 07 MBMADR03=0        |
| 30 MBMADR26          | 22 MBMADR18          | 14 MBMADR10          | 06 MBMADR02=0        |
| 29 MBMADR25          | 21 MBMADR17          | 13 MBMADR09          | 05 MBMADR01=0        |
| 28 MBMADR24          | 20 MBMADR16          | 12 MBMADR08          | 04 MBMADR00=0        |
| 27 MBMADR23          | 19 MBMADR15          | 11 MBMADR07=0        | 03 PREFETCH=0        |
| 26 MBMADR22          | 18 MBMADR14          | 10 MBMADR06=0        | 02 MSPACTYP1=0       |
| 25 MBMADR21          | 17 MBMADR13          | 09 MBMADR05=0        | 01 MSPACTYP0=0       |
| 24 MBMADR20          | 16 MBMADR12          | 08 MBMADR04=0        | 00 MSPACEIND=0       |

| EXROMCTL<br>R/W N30h | EXROMCTL<br>R/W N30h | EXROMCTL<br>R/W N30h | EXROMCTL<br>R/W N30h |
|----------------------|----------------------|----------------------|----------------------|
| 31 MBAXROM20=0       | 23 MBAXROM12=0       | 15 MBAXROM04=0       | 07 RSVD              |
| 30 MBAXROM19=0       | 22 MBAXROM11=0       | 14 MBAXROM05=0       | 06 RSVD              |
| 29 MBAXROM18=0       | 21 MBAXROM10≈0       | 13 MBAXROM02=0       | 05 RSVD              |
| 28 MBAXROM17=0       | 20 MBAXROM09≈0       | 12 MBAXROM01=0       | 04 RSVD              |
| 27 MBAXROM16=0       | 19 MBAXROM08=0       | 11 MBAXROM00=0       | 03 RSVD              |
| 26 MBAXROM15=0       | 18 MBAXROM07≈0       | 10 RSVD              | 02 RSVD              |
| 25 MBAXROM14=0       | 17 MBAXROM06≈0       | 09 RSVD              | 01 RSVD              |
| 24 MBAXROM13=0       | 16 MBAXROM05≈0       | 08 RSVD              | 00 EXROMEN=0         |

| MAXLAT<br>R N3Ch | MINGNT<br>R N3Ch | INTPINSEL<br>R N3Ch | INTLINSEL<br>R/W N3Ch |
|------------------|------------------|---------------------|-----------------------|
| 31 MAXLAT7=0     | 23 MINGNT7=0     | 15 INTPS7=0         | 07 INTLS7             |
| 30 MAXLAT6=0     | 22 MINGNT6=0     | 14 INTPS6=0         | 06 INTLS6             |
| 29 MAXLAT5=0     | 21 MINGNT5=0     | 13 INTPS5=0         | 05 INTLS5             |
| 28 MAXLAT4=0     | 20 MINGNT4=0     | 12 INTPS4=0         | 04 INTLS4             |
| 27 MAXLAT3=0     | 19 MINGNT3=0     | 11 INTPS3=0         | 03 INTLS3             |
| 26 MAXLAT2=1     | 18 MINGNT2=1     | 10 INTPS2=0         | 02 INTLS2             |
| 25 MAXLAT1=0     | 17 MINGNT1=0     | 09 INTPS1=0         | 01 INTLS1             |
| 24 MAXLAT0=0     | 16 MINGNT0=0     | 08 INTPS0=1         | 00 INTLS0             |

| PCIERRGEN<br>R/W N40h | RSVD<br>R N40h | DEVSTATUS<br>R N 40h | DEVCONFIG<br>R/W N40h |
|-----------------------|----------------|----------------------|-----------------------|
| 31 PCIERRGENDIS       | 23 RSVD        | 15                   | 07 DEVCONFIG7         |
| 30 RSVD               | 22 RSVD        | 14                   | 06 MRDCEN             |
| 29 RSVD               | 21 RSVD        | 13                   | 05 RSVD               |
| 28 MADRSPARERR        | 20 RSVD        | 12                   | 04 RSVD               |
| 27 MWDATPARERR        | 19 RSVD        | 11                   | 03 BERREN             |
| 26 TRDATAPARERR       | 18 RSVD        | 10 RSVD              | 02 DACEN              |
| 25 MTDATAPARERR       | 17 RSVD        | 09 RSVD              | 01 STPWLEVEL          |
| 24 TADRSPARERR        | 16 RSVD        | 08 VOLSENSE          | 00 RSVD               |

# **Host Device Registers**

| DSVENDIDO<br>R M/DS-80 (ae) | DSVENDID1<br>R M/DS-81 (ae) | DSDEVIDO<br>R M/DS-82 (ae) | DSDEVID1<br>R M/DS-83 (ae) | DSCOMMAND<br>R/W M/DS-84 (be) | DSLATTIME<br>R M/DS-85 (be) |
|-----------------------------|-----------------------------|----------------------------|----------------------------|-------------------------------|-----------------------------|
| 7 DSVID07=0                 | 7 DSVID15=1                 | 7 DSDID07=0                | 7 DSDID15=0                | 7 CACHETHEN*                  | 7 DSLATT7                   |
| 6 DSVID06=0                 | 6 DSVID14=0                 | 6 DSDID06=1                | 6 DSDID14=1                | 6 DPARCKEN*                   | 6 DSLATT6                   |
| 5 DSVID05=0                 | 5 DSVID13=0                 | 5 DSDID05=1                | 5 DSDID13=0                | 5 MPARCKEN*                   | 5 DSLATT5                   |
| 4 DSVID04=0                 | 4 DSVID12=1                 | 4 DSDID04=1                | 4 DSDID12=1                | 4 RSVD                        | 4 DSLATT4                   |
| 3 DSVID03=0                 | 3 DSVID11=0                 | 3 DSDID03=1                | 3 DSDID11=0                | 3 DSSERRESPEN                 | 3 DSLATT3                   |
| 2 DSVID02=1                 | 2 DSVID10=0                 | 2 DSDID02=0                | 2 DSDID10=0                | 2 DSPERRESPEN                 | 2 DSLATT2                   |
| 1 DSVID01=0                 | 1 DSVID09=0                 | 1 DSDID01=0                | 1 DSDID09=0                | 1 DSMWICEN                    | 1 HADDLDSEL1 *              |
| 0 DSVID00=0                 | 0 DSVID08≃0                 | 0 DSDID00=0                | 0 DSDID08=0                | 0 DSMASTEREN                  | 0 HADDLDSEL0*               |

| PCISTATUS<br>R/W MADS-86 (be) | HCNTRL<br>R/W M/DS-87 (a) | LHADDRO<br>R/W M/DS-88 (bcdg) | LHADDR1<br>R/W M/DS-89 (bcg) | LHADDR2<br>R/W M/DS-8A (bcg) | LHADDR3<br>R/W M/DS-8B (bcg) |
|-------------------------------|---------------------------|-------------------------------|------------------------------|------------------------------|------------------------------|
| 7 DFTHRSH1 *                  | 7                         | 7 LHADDR07                    | 7 LHADDR15                   | 7 LHADDR23                   | 7 LHADDR31                   |
| 6 DFTHRSHO *                  | 6 POWRDN                  | 6 LHADDR06                    | 6 LHADDR14                   | 6 LHADDR22                   | 6 LHADDR30                   |
| 5 DSDPR                       | 5 RSVD                    | 5 LHADDR05                    | 5 LHADDR13                   | 5 LHADDR21                   | 5 LHADDR29                   |
| 4 DSDPE                       | 4 SWINT                   | 4 LHADDR04                    | 4 LHADDR12                   | 4 LHADDR20                   | 4 LHADDR28                   |
| 3 DSSSE                       | 3 HCNTRL3                 | 3 LHADDR03                    | 3 LHADDR11                   | 3 LHADDR19                   | 3 LHADDR27                   |
| 2 DSRMA                       | 2 PAUSE[ACK]              | 2 LHADDR02                    | 2 LHADDR10                   | 2 LHADDR18                   | 2 LHADDR26                   |
| 1 DSRTA                       | 1 INTEN                   | 1 LHADDR01                    | 1 LHADDR09                   | 1 LHADDR17                   | 1 LHADDR25                   |
| 0 DSSTA                       | 0 CHIPRST[ACK]            | 0 LHADDR00                    | 0 LHADDR08                   | 0 LHADDR16                   | 0 LHADDR24                   |
|                               |                           | 1                             |                              | 1                            |                              |

| HHADDRO          | HHADDR1          | HHADDR2          | HHADDR3          |
|------------------|------------------|------------------|------------------|
| R/W M/DS-88 (bc) | R/W M/DS-89 (bc) | R/W M/DS-8A (bc) | R/W M/DS-8B (bc) |
| 7 HHADDR07       | 7 HHADDR15       | 7 HHADDR23       | 7 HHADDR31       |
| 6 HHADDR06       | 6 HHADDR14       | 6 HHADDR22       | 6 HHADDR30       |
| 5 HHADDR05       | 5 HHADDR13       | 5 HHADDR21       | 5 HHADDR29       |
| 4 HHADDR04       | 4 HHADDR12       | 4 HHADDR20       | 4 HHADDR28       |
| 3 HHADDR03       | 3 HHADDR11       | 3 HHADDR19       | 3 HHADDR27       |
| 2 HHADDR02       | 2 HHADDR10       | 2 HHADDR18       | 2 HHADDR26       |
| 1 HHADDR01       | 1 HHADDR09       | 1 HHADDR17       | 1 HHADDR25       |
| 0 HHADDR00       | 0 HHADDR08       | 0 HHADDR16       | 0 HHADDR24       |

| HCNT0                                                                                        | HCNT1                                                                                        | HCNT2                                                                                        | RSVD                                                                         | INTSTAT                                                                            | CLRINT                                                                |
|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| R/W M/DS-8C (bg)                                                                             | R/W M/DS-8D (bg)                                                                             | R/W M/DS-8E (bg)                                                                             | R/W M/DS-8F (b)                                                              | R/W M/DS-91 (ij)                                                                   | W M/DS-92 (a)                                                         |
| 7 HCNT07<br>6 HCNT06<br>5 HCNT05<br>4 HCNT04<br>3 HCNT03<br>2 HCNT02<br>1 HCNT01<br>0 HCNT00 | 7 HCNT15<br>6 HCNT14<br>5 HCNT13<br>4 HCNT12<br>3 HCNT11<br>2 HCNT10<br>1 HCNT09<br>0 HCNT08 | 7 HCNT23<br>6 HCNT22<br>5 HCNT21<br>4 HCNT20<br>3 HCNT19<br>2 HCNT18<br>1 HCNT17<br>0 HCNT16 | 7 RSVD<br>6 RSVD<br>5 RSVD<br>4 RSVD<br>3 RSVD<br>2 RSVD<br>1 RSVD<br>0 RSVD | 7 INTCODE3 6 INTCODE2 5 INTCODE1 4 INTCODE0 3 BRKINT 2 SCSIINT 1 CMDCMPLT 0 SEQINT | 7 6 5 4 CLRPARERR 3 CLRBRKADRINT 2 CLRSCSIINT 1 CLRCMDINT 0 CLRSEQINT |

| ERROR                                                             | DFCNTRL                                                                                                   | DFSTATUS      | QOUTFIFO                                               | QOUTCNT                                                                                 | SFUNCT                                                                                                  |
|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| R M/DS-92 (a)                                                     | R/W M/DS-93 (b)                                                                                           | R M/DS-94 (b) | R M/DS-9D (ij)                                         | R W/DS-9E (i)                                                                           | R/W M/DS-9F (b)                                                                                         |
| 7 6 PCIERRSTAT (g) 5 MPARERR 4 DPARERR 3 SQPARERR 2 ILLOPCODE 1 0 | 7 6 WIDEODD=0 5 SCSIEN[ACK] 4 SDMAEN[ACK] 3 HDMAEN[ACK] 2 DIRECTION[ACK] 1 FIFOFLUSH[ACK] 0 FIFORESET(cd) |               | 7<br>6<br>5<br>4<br>3<br>2 QOUT2<br>1 QOUT1<br>0 QOUT0 | 7 QOUTCNT7 6 QOUTCNT6 5 QOUTCNT5 4 QOUTCNT4 3 QOUTCNT3 2 QOUTCNT2 1 QOUTCNT1 0 QOUTCNT0 | 7 SFUNCT2<br>6 SFUNCT1<br>5 SFUNCT0<br>4 TESTRAM<br>3 TESTHOST<br>2 TESTSEQ<br>1 TESTFIFO<br>0 TESTSCSI |

| SLEEPCTL<br>R/W M/DS-1C (b) |   |   |  |   |
|-----------------------------|---|---|--|---|
| 7 SLEEPDIS                  | _ |   |  |   |
| 6                           |   |   |  |   |
| 5                           |   |   |  |   |
| 4                           |   |   |  |   |
| 3                           |   |   |  |   |
| 2                           |   |   |  |   |
| 1 SLP1                      |   |   |  |   |
| 0 SLP0                      |   | _ |  | _ |

## **SCB Device Registers**

| SCBPTR<br>R/W M/DS-90 (b) | SCBCNT<br>R/W M/DS-9A (b) | QINFIFO<br>R/W M/DS-9B (b) | QINCNT<br>R M/DS-9C (b) | QOUTFIFO<br>W M/DS-9D (b) |  |
|---------------------------|---------------------------|----------------------------|-------------------------|---------------------------|--|
| 7 SCBVAL7                 | 7 SCBAUTO                 | 7                          | 7 QINCNT7               | 7                         |  |
| 6 SCBVAL6                 | 6 RSVD                    | 6                          | 6 QINCNT6               | 6                         |  |
| 5 SCBVAL5                 | 5 RSVD                    | 5                          | 5 QINCNT5               | 5                         |  |
| 4 SCBVAL4                 | 4 SCBCNT4                 | 4                          | 4 QINCNT4               | 4                         |  |
| 3 SCBVAL3                 | 3 SCBCNT3                 | 3                          | 3 QINCNT3               | 3                         |  |
| 2 SCBVAL2                 | 2 SCBCNT2                 | 2 QIN2                     | 2 QINCNT2               | 2 QOUT2                   |  |
| 1 SCBVAL1                 | 1 SCBCNT1                 | 1 QIN1                     | 1 QINCNT1               | 1 QOUT1                   |  |
| 0 SCBVAL0                 | 0 SCBCNT0                 | 0 QIN0                     | 0 QINCNT0               | 0 QOUTO                   |  |

| BRDCTL<br>R/W M/DS-1D (b) | SEECTL<br>R/W M/DS-1E (b) |   |  |  |
|---------------------------|---------------------------|---|--|--|
| 7 RSVD                    | 7 RSVD                    |   |  |  |
| 6 RSVD                    | 6 RSVD                    |   |  |  |
| 5 RSVD                    | 5 RSVD                    |   |  |  |
| 4 RSVD                    | 4 RSVD                    | 1 |  |  |
| 3 RSVD                    | 3 RSVD                    |   |  |  |
| 2 RSVD                    | 2 RSVD                    | 1 |  |  |
| 1 RSVD                    | 1 RSVD                    |   |  |  |
| 0 RSVD                    | 0 RSVD                    |   |  |  |

#### **Data FIFO Device Registers**

| DFWADDR0<br>R/W M/DS-95 (bh) | RSVD<br>R/W M/DS-96 (b) | DFRADDR0<br>R/W M/DS-97 (bh) | RSVD<br>R/W M/DS-98 (b) | DFDAT<br>R/W M/DS-99 (bh) |  |
|------------------------------|-------------------------|------------------------------|-------------------------|---------------------------|--|
| 7 DFCACHETHLA                | 7 RSVD                  | 7 DFSDH                      | 7 RSVD                  | 7 FDAT7                   |  |
| 6                            | 6 RSVD                  | 6                            | 6 RSVD                  | 6 FDAT6                   |  |
| 5 RSVD                       | 5 RSVD                  | 5 RSVD                       | 5 RSVD                  | 5 FDAT5                   |  |
| 4 DFWADDR04                  | 4 RSVD                  | 4 DFRADDR04                  | 4 RSVD                  | 4 FDAT4                   |  |
| 3 DFWADDR03                  | 3 RSVD                  | 3 DFRADDR03                  | 3 RSVD                  | 3 FDAT3                   |  |
| 2 DFWADDR02                  | 2 RSVD                  | 2 DFRADDR02                  | 2 RSVD                  | 2 FDAT2                   |  |
| 1 DFWADDR01                  | 1 RSVD                  | 1 DFRADDR01                  | 1 RSVD                  | 1 FDAT1                   |  |
| 0 DFWADDR00                  | 0 RSVD                  | 0 DFRADDR00                  | 0 RSVD                  | 0 FDAT0                   |  |

- a Register may be read or written by host driver without access or latch pausing the sequencer.
- b Register may only be read or written by host driver when sequencer is access or latch paused.
- c Access affected by the state of HADDLDSEL[1:0] value in the DSCOMMAND register.
- d Also used to load starting byte offsets to quad word boundary.
- e Allows dual access read of Configuration space registers or bits.
- f ORed status read only.
- g Register may only be accessed when the H/SDMAEN bits in the DFCNTRL register are not active.
- h Write access same as LHADDR[3:0].
- Register may be read by host driver without access or latch pausing the sequencer.
- j Register may be written by host driver only with access or latch pausing the sequencer.
- \* R/W bi

- \*\* Indicates dual read access to this register byte through the AIC-7850 Device register space.
- + Indicates this register byte read default value after RST# assertion may be changed.
- ++ Easy value update in metal.
- +++ AIC-7850-A = 0, AIC-7850-B = 2

Detailed Register Description

## **About This Chapter**

Read this chapter to find out

■ A detailed description of each of the registers in the AIC-7850

· · · · · 4

The following conventions are used throughout this section:

- set: Indicates that the bit was loaded with a 1
- cleared: Indicates that the bit was loaded with a 0
- is a one: Indicates a status of 1
- is a zero: Indicates a status of 0
- (0): Indicates that the bit is cleared when the reset pin is active
- (1): Indicates that the bit is set when the reset pin is active
- (x): Indicates that the bit is in an unknown state after the reset condition
- Mxxh: Indicates PCI address decode with address prefix stored in either BASEADR0 or BASEADR1 registers in the configuration space.
- Nxxh: Indicates PCI address decode with address prefix defined externally to the AIC-7850 by a connection to pin IDSEL, this is normally a single address line in the range of AD[31:11]. PCI convention for access will be to only have one address line active (=1) per device access.
- DS-xxh: Device space, internal address decode. It represents Mxxh without the M extension and is the value used by the internal sequencer (SCSI PhaseEngine).

## **SCSI Device Space Register Definition**

### SCSI Sequence Control (SCSISEQ)

Type: R/W

Address: M00h, DS-00h

Each bit, when set, enables the specified hardware sequence. The register is readable to allow bit manipulation instructions without saving a register image in scratch RAM. All bits except SCSIRSTO are cleared by SCSI bus reset.

| SCSISEQ<br>R/W |            |  |  |  |  |
|----------------|------------|--|--|--|--|
| 7              | TEMODEO    |  |  |  |  |
| 6              | ENSELO     |  |  |  |  |
| 5              | ENSELI     |  |  |  |  |
| 4              | ENRSELI    |  |  |  |  |
| 3              | ENAUTOATNO |  |  |  |  |
| 2              | ENAUTOATNI |  |  |  |  |
| 1              | ENAUTOATNP |  |  |  |  |
| 0              | SCSIRSTO   |  |  |  |  |

| Bit |     | Name       | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | TEMODEO    | Target Enable Mode Out. This bit is used to select whether ENSELO will start a Selection Out (TEMODEO = 0) or a Reselection Out (TEMODEO = 1) SCSI bus sequence.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6   | (0) | ENSELO     | Enable Selection Out. When this bit is set to one, it will allow the SCSI logic to perform a Selection sequence (TEMODEO = 0) as an Initiator (ID = OID field of SCSIID register) and select a Target (ID = TID field of the SCSIID register), or to perform a Reselection sequence (TEMODEO=one) as a Target (ID = OID field of SCSIID register) and reselect an Initiator (ID = TID field of the SCSIID Register). The SELINGO status (bit 4, SSTAT0) is one when the SCSI logic has entered the Selection/Reselection phase and is waiting for BSY back from the Target/Initiator. The sequencer must wait for SELDO status (bit 6, SSTAT0) to be one or SELTO (bit 7, SSTAT1) to be one if the hardware selection time-out is enabled (bit 2, SXFRCTL1 is set to one), or for the software selection time-out if the hardware time-out is not enabled. This control is set to zero by the sequencer, or by a hard reset. |
| 5   | (0) | ENSELI     | Enable Selection In. When this bit is set to one, it will allow the SCSI logic to respond to a valid Selection sequence. When selected, the SELDI status (bit 5, SSTAT0) is set to one and TARGET status (bit 7, SSTAT0) is set to one. This control is only set to zero by the sequencer when no more selections are wanted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4   | (0) | ENRSELI    | <b>Enable Reselection In.</b> When this bit is set to one, it will allow the SCSI logic to respond to a valid Reselection sequence. When reselected the SELDI status (bit 5, SSTATO) is one and TARGET status (bit 7, SSTATO) is set to zero. This control is reset to zero by writing a zero to this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3   | (0) | ENAUTOATNO | Enable Auto Attention Out. When this bit is set to one, SCSI ATN will be asserted when a Selection sequence (ENSELO=1, TEMODEO=0) is executed. This is used when you are an Initiator and want to follow the Selection with a Message Out. SCSI ATN may be cleared by the sequencer by writing one to CLRATNO (bit 6, CLRSINT1), or by a Bus Free state on the SCSI bus. Writing a zero to this bit does not clear ATN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2   | (0) | ENAUTOATNI | Enable Auto Attention In. When this bit is set to one, SCSI ATN will be asserted when you are reselected by a Target (ENRSELI=1). This is used when you are an Initiator and want to follow the Reselection with a Message Out (refer to SCSI-2 Spec). SCSI ATN may be cleared by the sequencer by writing one to CLRATNO (bit 6, CLRSINT1), or by a Bus Free state on the SCSI bus. Writing a zero to this bit does not clear ATN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | (0) | ENAUTOATNP | Enable Auto Attention Parity. When this bit is set to one with ENSPCHK (bit 5, SXFRCTL1) and you are an Initiator, SCSI ATN will be asserted during information transfer in phases (Data In, Message In, Status In) if a parity error is detected on SCD[7:0]. SCSI ATN may be cleared by the sequencer by writing one to CLRATNO (bit 6, CLRSINT1), or by a Bus Free state on the SCSI bus. Writing a zero to this bit does not clear ATN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0   | (0) | SCSIRSTO   | <b>SCSI Reset Out</b> . When this bit is set to one, SCSI RESET# is asserted on the SCSI bus. It must be cleared by the sequencer with a write of 0 to this bit. This control is not gated with the Target/Initiator mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## **SCSI Transfer Control 0 (SXFRCTL0)**

Type:

R/W

Address: M01h, DS-01h

This register together with SXFRCTL1 are used to control the SCSI module data path.

|   | SXFRCTL0<br>R/W |
|---|-----------------|
| 7 | DFON            |
| 6 | DFPEXP          |
| 5 |                 |
| 4 | CLRSTCNT        |
| 3 | SPIOEN          |
| 2 | SCAMEN          |
| 1 | CLRCHN          |
| 0 |                 |

| Bit |     | Name     | Definitio                                                                                                                                                                                                                                                     | n                                                                                                                       |                                                                                                                                                                                                                                 |                                                                                                                              |                                                                                   |  |
|-----|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| 7   | (0) | DFON     | Digital Filtering On. When this bit is set to one, digital filtering is enabled for the incoming REQ# and ACK# signals. The filter period is determined by the transfer rate stored in the SCSIRATE register and the DFPEXP bit (bit 6, SXFRCTL0) as follows: |                                                                                                                         |                                                                                                                                                                                                                                 |                                                                                                                              |                                                                                   |  |
|     |     |          | DFON                                                                                                                                                                                                                                                          | DFPEXP                                                                                                                  | Transfer Rate                                                                                                                                                                                                                   | Min. Filter<br>Period                                                                                                        | Max. Filter<br>Period                                                             |  |
|     |     |          | 0                                                                                                                                                                                                                                                             | X                                                                                                                       | _                                                                                                                                                                                                                               | 0 nsec                                                                                                                       | 0 nsec                                                                            |  |
|     |     |          | 1                                                                                                                                                                                                                                                             | Χ                                                                                                                       | > 5 MBytes/sec                                                                                                                                                                                                                  | 12.5 nsec                                                                                                                    | 25.0 nsec                                                                         |  |
|     |     |          | 1                                                                                                                                                                                                                                                             | 0                                                                                                                       | =< 5 MBytes/sec                                                                                                                                                                                                                 | 50.0 nsec                                                                                                                    | 62.5 nsec                                                                         |  |
|     |     |          | 1                                                                                                                                                                                                                                                             | 1                                                                                                                       | =< 5 MBytes/sec                                                                                                                                                                                                                 | 62.6 nsec                                                                                                                    | 75.0 nsec                                                                         |  |
| 5   | (0) | Not Used | rate is se                                                                                                                                                                                                                                                    | to =< 5 MBytes<br>s no effect on                                                                                        | od from 50.0 to 62.5 nse<br>es/sec. When the SCSI<br>the filter period.                                                                                                                                                         |                                                                                                                              |                                                                                   |  |
| 4   | (0) | CLRSTCNT | (STCNT)                                                                                                                                                                                                                                                       | and the host a                                                                                                          | count. When set to one address counter (SHAE need not be toggled. The                                                                                                                                                           | DDR) are reset to                                                                                                            | 000000h. This                                                                     |  |
| 3   | (0) | SPIOEN   | bus. This<br>transfers<br>on data d<br>any furthe<br>register. SDMAEN<br>Note: SC                                                                                                                                                                             | bit must rema<br>are triggered<br>lirection and T<br>er PIO transfe<br>This bit may b<br>I override this<br>SISIGO must | en set to one, automati<br>ain set for the entire Plot<br>by reading or writing to<br>arget/Initiator mode. We<br>rs without corrupting are<br>e left on even when in<br>bit.<br>be programmed with the<br>PHASEMIS, bit 4 SSTA | O transfer. The in<br>SCSIDATL regis<br>friting a zero to the<br>ny valid data in the<br>DMA mode since<br>the correct phase | dividual PIO<br>ster depending<br>nis bit will stop<br>ne SCSIDATL<br>s SCSIEN or |  |

#### (Continued)

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | (0) | SCAMEN   | SCSI Configured AutoMagically Enable. When active (=1), enables the AIC-7850 SCSI module to perform level 1 SCAM protocol by allowing full SCSI bus signal (BSY#, SEL#, CD#, IO#, MSG#, RST#, REQ# and SCD[7:0]#) control without going through the normal SCSI 1 or 2 protocol with devices connected to the AIC-7850 SCSI bus. When SCAMEN is active, a timer (CLKOUT in SELTIMER register) is enabled for timing events of the SCAM protocol and selection time-outs will not cause RST# to be asserted. |
| 1   | (0) | CLRCHIN  | Clear Channel In. When set to one, the SCSI FIFO and the Synchronous REQ/ACK offset counter will be cleared. The transfer control logic will also be initialized to a reset state. The SCSI transfer counters (STCNT and SHADDR) will not be changed. This is used to initialize the channel for a transfer. This bit is self-clearing.                                                                                                                                                                     |
| 0   | (0) | Not Used | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## **SCSI Transfer Control 1 (SXFRCTL1)**

R/W

Type: R/W Address: M02h, DS-02h

This register together with SXFRCTL0 are used to control the SCSI module data path.

| SXFRCTL1<br>R/W |           |  |  |  |
|-----------------|-----------|--|--|--|
| 7               | BITBUCKET |  |  |  |
| 6               | SWRAPEN   |  |  |  |
| 5 ENSPCHK       |           |  |  |  |
| 4 STIMESEL(1)   |           |  |  |  |
| 3 STIMESEL(0)   |           |  |  |  |
| 2               | ENSTIMER  |  |  |  |
| 1 ACTNEGEN      |           |  |  |  |
| 0 STPWEN        |           |  |  |  |

| Bit |     | Name          | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|-----|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7   | (0) | BITBUCKET     | SCSI Bit Bucket Mode. When this bit is set to one, it enables the SCSI logic to read data from the SCSI bus and throw it away or supply 00h write data. No data is saved and no transfer stops occur because of SCSI FIFO full/empty conditions. This only applies while in Initiator mode.                                                                                                                                                                                                                    |  |  |
| 6   | (0) | SWRAPEN       | SCSI Wrap Enable. When this bit is set to one, the STCNT register is allowed to wrap past zero to allow the transfer count to exceed a 24-bit value. The status SWRAP will be one when the wrap occurs. If it is not the last wrap, clear the SWRAP status by writing a one to CLRSWRAP control (bit 3, CLRSINTO) and wait for the next SWRAP interrupt. If it is the last wrap clear SWRAP by setting CLRSWRAP (bit 3, CLRSINTO) and clearing SWRAPEN, and then wait for the SDONE interrupt (bit 2, SSTATO). |  |  |
| 5   | (0) | ENSPCHK       | Enable SCSI Parity Checking. When set to one, parity checking is enabled on the SCSI bus during Selection, Reselection, and Information Transfer cycles. If a parity error is detected, SCSIPERR (bit 2, SSTAT1) is set and if ENAUTOATNP (bit 1, SCSISEQ) is set, then ATN is driven active on the SCSI bus. When set to a zero, SCSIPERR will always read as a zero.                                                                                                                                         |  |  |
| 4-3 | (0) | STIMESEL[1:0] | <b>SCSI Time-out Selection.</b> These bits define the selection time-out time used by the hardware selection timer. The selection time-out timer may be monitored via SELTIMER (bits 5-0).                                                                                                                                                                                                                                                                                                                     |  |  |
|     |     |               | 4 3 - Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|     |     |               | 0 0 - 256 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|     |     |               | 0 1 - 128 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|     |     |               | 1 0 - 64 ms<br>1 1 - 32 ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 2   | (0) | ENSTIMER      | Enable Selection Timer. When set to one, enables the hardware selection timer. During Selection or Reselection Out, if the timer times out, SEL will be turned off, and SELTO will be set to one in SSTAT1. If this bit is set to zero, SEL will remain on the bus until it is cleared by the sequencer.                                                                                                                                                                                                       |  |  |
| 1   | (0) | ACTNEGEN      | Active Negation Enable. When active (=1) allows the SCSI outputs (REQ#, ACK#, SCD[7:0]#, SCDPL#) to perform active negation when the output is switching from asserted (=0) to deasserted condition (=1) to improve the SCSI bus signal rising transition time during any Information Transfer phase.                                                                                                                                                                                                          |  |  |
| 0   | (0) | STPWEN        | SCSI Termination Power Enable. When in the active state (=1) will cause output STPWCTL to be asserted state selected by STPWLEVEL bit in the Configuration DEVCONFIG register. STPWCTL output may be used to enable or disable the external SCSI bus termination power source. When output STPWEN is inactive the external termination power device is expected to be off or disabled. STPWEN may also be used for a general purpose control bit for external logic.                                           |  |  |

## SCSI Control Signal Read Register (SCSISIGI)

Type: R Address: M03h, DS-03h

The SCSISIGI register reads the actual state of the signals on the SCSI bus pins.

| SCSISIGI<br>R |      |  |  |  |
|---------------|------|--|--|--|
| 7             | CDI  |  |  |  |
| 6             | 101  |  |  |  |
| 5 MSGI        |      |  |  |  |
| 4 ATNI        |      |  |  |  |
| 3 SELI        |      |  |  |  |
| 2             | BSYI |  |  |  |
| 1             | REQI |  |  |  |
| 0             | ACKI |  |  |  |

| Bit |     | Name | Definition                                          |
|-----|-----|------|-----------------------------------------------------|
| 7   | (x) | CDI  | Reads the state of the CD# signal on the SCSI bus.  |
| 6   | (x) | 101  | Reads the state of the IO# signal on the SCSI bus.  |
| 5   | (x) | MSGI | Reads the state of the MSG# signal on the SCSI bus. |
| 4   | (x) | ATNI | Reads the state of the ATN# signal on the SCSI bus. |
| 3   | (x) | SELI | Reads the state of the SEL# signal on the SCSI bus. |
| 2   | (x) | BSYI | Reads the state of the BSY# signal on the SCSI bus. |
| 1   | (x) | REQI | Reads the state of the REQ# signal on the SCSI bus. |
| 0   | (x) | ACKI | Reads the state of the ACK# signal on the SCSI bus. |

### SCSI Control Signal Write Register (SCSISIGO)

Type:

W

Address: M03h, DS-03h

The SCSISIGO write register lets the sequencer set the state of the SCSI bus control signals. However, only those control signals appropriate to the current mode (Target, Initiator or SCAM) are enabled onto the SCSI bus. The most significant three bits (CDO, IOO, and MSGO) are used for SCSI bus phase comparison in Initiator mode. All SCSISIGO write register bits are cleared by chip reset, SCSI bus reset, or SCSI bus free.

| SCSISIGO<br>W |      |  |  |  |
|---------------|------|--|--|--|
| 7             | CDO  |  |  |  |
| 6             | 100  |  |  |  |
| 5 MSGO        |      |  |  |  |
| 4 ATNO        |      |  |  |  |
| 3 SELO        |      |  |  |  |
| 2             | BSYO |  |  |  |
| 1             | REQO |  |  |  |
| 0             | ACKO |  |  |  |

| Bit   |     | Name | Definition                                                                                                                                                                                                                                                                                                      |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <br>7 | (0) | CDO  | CD Out. If in Target mode, sets CD# on SCSI bus. If in Initiator mode, sets the state of CD# expected on the next REQ# pulse. If in SCAM mode, sets CD# on the SCSI bus.                                                                                                                                        |
| 6     | (0) | 100  | IO Out. If in Target mode, sets IO# on SCSI bus. If in Initiator mode, sets the state of IO# expected on the next REQ# pulse. If in SCAM mode, sets IO# on the SCSI bus.                                                                                                                                        |
| 5     | (0) | MSGO | MSG Out. If in Target mode sets MSG# on SCSI bus. If in Initiator mode, sets the state of MSG# expected on the next REQ# pulse. If in SCAM mode, sets MSG# on the SCSI bus.                                                                                                                                     |
| 4     | (0) | ATNO | ATN Out. In Target mode, this bit is not used. In Initiator mode, writing one to this bit sets ATN# on the SCSI bus. Writing a zero to this bit has no effect. ATN# may be cleared by writing one to CLRATNO (bit 6 in CLRSINT1).                                                                               |
| 3     | (0) | SELO | SEL Out. When set to one, asserts SEL# on the SCSI bus. Can be used to negate SEL#. If in SCAM mode, sets SEL# on the SCSI bus.                                                                                                                                                                                 |
| 2     | (0) | BSYO | BSY Out. When set to one, asserts BSY# on the SCSI bus. May also be used to negate BSY#. When BSYO is set to one and the DIAGLEDEN bit in the Device SBLKCTL register is not active, LED# output is asserted to indicate the AIC-7850 is connected to the SCSI bus. If in SCAM mode, sets BSY# on the SCSI bus. |
| 1     | (0) | REQO | <b>REQ Out.</b> If in Target mode, sets REQ# on the SCSI bus. It is not functional in Initiator mode. If in SCAM mode, sets REQ# on the SCSI bus.                                                                                                                                                               |
| 0     | (0) | ACKO | <b>ACK Out.</b> If in Initiator mode, sets ACK# on the SCSI bus. It is not functional in Target mode.                                                                                                                                                                                                           |

### SCSI Rate (SCSIRATE)

Type: R/W

Address: M04h, DS-04h

The contents of this register determine the synchronous SCSI data transfer rate and the maximum synchronous REQ/ACK offset. An offset value of 0 in the SOFS [3:0] disables synchronous data transfers. Any offset value greater than 0 enables synchronous transfers.

| SCSIRATE<br>R/W |          |  |  |  |  |
|-----------------|----------|--|--|--|--|
| 7               | WIDEXFER |  |  |  |  |
| 6               | SXFR(2)  |  |  |  |  |
| 5 SXFR(1)       |          |  |  |  |  |
| 4 SXFR(0)       |          |  |  |  |  |
| 3 SOFS(3)       |          |  |  |  |  |
| 2               | SOFS(2)  |  |  |  |  |
| 1               | SOFS(1)  |  |  |  |  |
| 0               | SOFS(0)  |  |  |  |  |

| Bit     |     | Name      | Definition                                                     |                                                                                                                                                                 |                                                                                                                                                                                       |                                                                                             |  |  |
|---------|-----|-----------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|
| 7       | (0) | WIDEXFER  | Wide SCSI Transfer. This bit is read-only '0'.                 |                                                                                                                                                                 |                                                                                                                                                                                       |                                                                                             |  |  |
| 6-4 (0) | (0) | SXFR(2:0) | transfer rate                                                  | Synchronous SCSI Transfer Rate 2:0. These bits select the Data phase transfer rate per the table below. Times are shown for a 40 MHz clock with clock period T. |                                                                                                                                                                                       |                                                                                             |  |  |
|         |     |           | SXFR                                                           | REQ#/ACK#<br>Width                                                                                                                                              | REQ#/ACK#<br>Period                                                                                                                                                                   | Rate (MHz)                                                                                  |  |  |
|         |     |           | 000                                                            | 50 nsec (2T)                                                                                                                                                    | 100 nsec (4T)                                                                                                                                                                         | 10                                                                                          |  |  |
|         |     |           | 001                                                            | 50 nsec (2T)                                                                                                                                                    | 125 nsec (5T)                                                                                                                                                                         | 8.0                                                                                         |  |  |
|         |     |           | 010                                                            | 50 nsec (2T)                                                                                                                                                    | 150 nsec (6T)                                                                                                                                                                         | 6.7                                                                                         |  |  |
|         |     |           | 011                                                            | 50 nsec (2T)                                                                                                                                                    | 175 nsec (7T)                                                                                                                                                                         | 5.7                                                                                         |  |  |
|         |     |           | 100                                                            | 100 nsec (4T)                                                                                                                                                   | 200 nsec (8T)                                                                                                                                                                         | 5.0                                                                                         |  |  |
|         |     |           | 101                                                            | 100 nsec (4T)                                                                                                                                                   | 225 nsec (9T)                                                                                                                                                                         | 4.4                                                                                         |  |  |
|         |     |           | 110                                                            | 100 nsec (4T)                                                                                                                                                   | 250 nsec (10T)                                                                                                                                                                        | 4.0                                                                                         |  |  |
|         |     |           | 111                                                            | 100 nsec (4T)                                                                                                                                                   | 275 nsec (11T)                                                                                                                                                                        | 3.6                                                                                         |  |  |
|         |     |           | For transfers                                                  | below 3.6 MB/S use a                                                                                                                                            | asynchronous transfer me                                                                                                                                                              | ode.                                                                                        |  |  |
| 3-0     | (0) | SOFS(3:0) | nous. When indicated off SCSI transfe only applies synchronous | set to any other value<br>set. Valid ranges (besiders and 0001 through 1<br>to Data phases. It shows<br>a negotiation since the                                 | 00, the SCSI transfer mo the transfer mode is sync des 0000) are 0001 throu 1111 for normal 8-bit transuld be set up properly per target could force a Data expected. Refer to the SC | chronous with the<br>gh 1000 for Wide<br>sfers. This field<br>the SCSI device<br>phase even |  |  |

## SCSI ID (SCSIID)

Type: R/W

Address: M05h, DS-05h

This register contains the devices own ID of the selected channel (OID) and the ID of the SCSI device that you want to communicate with (TID).

| SCSIID<br>R/W |        |  |  |
|---------------|--------|--|--|
| 7             | TID(3) |  |  |
| 6             | TID(2) |  |  |
| 5             | TID(1) |  |  |
| 4             | TID(0) |  |  |
| 3             | OID(3) |  |  |
| 2             | OID(2) |  |  |
| 1             | OID(1) |  |  |
| 0             | OID(0) |  |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4 | (0) | TID(3:0) | Target (Other) ID. This is a binary representation of the other device ID on the SCSI bus during any Selection/Reselection sequence. It is the other Target ID during Selection Out (ENSELO=1, TEMODEO=0) and Reselection In (ENSELI). It is the other Initiator ID during Selection In (ENSELI) and Reselection Out (ENSELO, TEMODEO=1). In any case, it is the other ID.  |
| 3-0 | (0) | OID(3:0) | <b>Own ID.</b> This is a binary representation of your own device ID on the SCSI bus during any Selection/Reselection sequence. It is your own Initiator ID during Selection Out (ENSELO=1, TEMODEO=0) and Reselection In (ENRSELI). It is your own Target ID during Selection In (ENSELI) and Reselection Out (ENSELO, TEMODEO=1). In any case, it is <i>your own ID</i> . |

### SCSI Latched Data (SCSIDATL,[H])

Type: R/W

Address: M06/M07h, DS-06/07h

This is a read/write latch used to transfer data on the SCSI bus during Automatic or Manual SCSI PIO transfer. Bit 7 is the MSB. Transfer data is written to or read from SCSIDATL only. When Automatic SCSI PIO transfers are enabled (SPIOEN=1), the SCSI ACK (as Initiator) or REQ (as Target) is driven active when the write or read occurs. Direct access to the SCSI bus is provided via read of SCSIBUS register. The initial read value after a chip reset is unknown. Valid data will be loaded after the first REQ#/ACK# In. SCSIDATH register is reserved and always reads 0.

|   | SCSIDATL<br>R/W | SCSIDATH<br>R/W |      |  |
|---|-----------------|-----------------|------|--|
| 7 | DB(07)          | 7               | RSVD |  |
| 6 | DB(06)          | 6               | RSVD |  |
| 5 | DB(05)          | 5               | RSVD |  |
| 4 | DB(04)          | 4               | RSVD |  |
| 3 | DB(03)          | 3               | RSVD |  |
| 2 | DB(02)          | 2               | RSVD |  |
| 1 | DB(01)          | 1               | RSVD |  |
| 0 | DB(00)          | 0               | RSVD |  |

### SCSI Transfer Count (STCNT[n])

Type: R/W

Address: M08/M09/M0Ah, DS-08/09/0Ah

These registers contain the DMA or Automatic PIO byte transfer count on the SCSI interface. STCNT0 is the least significant byte, STCNT1 is the mid byte, and STCNT2 is the most significant byte. If Initiator mode is enabled, it is loaded with the number of ACKs to send out on the SCSI bus. If Target mode is enabled, it is loaded with the number of REQs to send out on the SCSI bus. In Automatic PIO mode, STCNT is used as a counter only and need not be initialized to transfer data with Automatic PIO handshakes. Loading 000000h will give a byte transfer count of 16777216 decimal (16M Hex) if SWRAPEN (bit 6, SXFRCTL1) is set, and a transfer count of 0 if SWRAPEN is cleared.

The counter counts down by one when a SCSI byte is transferred. When sending data to the bus, a byte is considered transferred when the appropriate handshake signal is received (REQ#/ACK#). When receiving data from the bus, a byte is considered transferred when it has been written to the data FIFO. Two counters are maintained for this purpose, and the sense of DIRECTION (bit 2, DFCNTRL) which is latched by the last positive edge of SCSIEN or SDMAEN determines which one is used.

SDONE (bit 2, SSTAT0) is set when the transfer count is zero, SWRAPEN is zero, and SDMAEN is one. SWRAP is set when SWRAPEN is set and the transfer counter counts from 000000h to FFFFFFh. SWRAP should then be cleared via CLRSWRAP (bit 3, CLRSINT0) before the next wrap (that time is 16M times the SCSI bus transfer period). The sequencer must keep track of the number of wraps. The count is set to zero on a chip reset.

|   | STCNT0<br>R/W |   |           |   |           | STCNT2<br>R/W |
|---|---------------|---|-----------|---|-----------|---------------|
| 7 | STCNT(07)     | 7 | STCNT(15) | 7 | STCNT(23) |               |
| 6 | STCNT(06)     | 6 | STCNT(14) | 6 | STCNT(22) |               |
| 5 | STCNT(05)     | 5 | STCNT(13) | 5 | STCNT(21) |               |
| 4 | STCNT(04)     | 4 | STCNT(12) | 4 | STCNT(20) |               |
| 3 | STCNT(03)     | 3 | STCNT(11) | 3 | STCNT(19) |               |
| 2 | STCNT(02)     | 2 | STCNT(10) | 2 | STCNT(18) |               |
| 1 | STCNT(01)     | 1 | STCNT(09) | 1 | STCNT(17) |               |
| 0 | STCNT(00)     | 0 | STCNT(08) | 0 | STCNT(16) |               |

#### Clear SCSI Interrupt 0 (CLRSINT0)

Type: W

Address: M0Bh, DS-0Bh

Writing a one to a bit in this register clears the associated SCSI interrupt bit in SSTAT0. Writing a zero to any bit in this register will have no effect. Each bit is self-clearing and writing a zero to any bit in this register will have no effect.

| CLRSINT0<br>W |            |  |
|---------------|------------|--|
| 7             |            |  |
| 6             | CLRSELDO   |  |
| 5             | CLRSELDI   |  |
| 4             | CLRSELINGO |  |
| 3             | CLRSWRAP   |  |
| 2             |            |  |
| 1             | CLRSPIORDY |  |
| 0             |            |  |

| Bit |     | Name       | Definition                               |
|-----|-----|------------|------------------------------------------|
| 7   | (0) | Not Used   |                                          |
| 6   | (0) | CLRSELDO   | Clears the SELDO interrupt and status.   |
| 5   | (0) | CLRSELDI   | Clears the SELDI interrupt and status.   |
| 4   | (0) | CLRSELINGO | Clears the SELINGO interrupt and status. |
| 3   | (0) | CLRSWRAP   | Clears SWRAP interrupt and status.       |
| 2   | (0) | Not Used   |                                          |
| 1   | (0) | CLRSPIORDY | Clears SPIORDY interrupt and status.     |
| 0   | (0) | Not Used   |                                          |

### SCSI Status 0 (SSTAT0)

Type:

R

Address: M0Bh, DS-0Bh

This register contains the status of SCSI interrupt bits. Any status bit may be read at any time whether or not it has been enabled in SIMODE0. If an interrupt bit is enabled and set to one, the SCSIINT interrupt line will be driven to the active state (except TARGET which is a status bit only).

| SSTATO<br>R |         |  |
|-------------|---------|--|
| 7           | TARGET  |  |
| 6           | SELDO   |  |
| 5           | SELDI   |  |
| 4           | SELINGO |  |
| 3           | SWRAP   |  |
| 2           | SDONE   |  |
| 1           | SPIORDY |  |
| 0           | DMADONE |  |

| Bit |     | Name    | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | TARGET  | Target. When this bit is one, it signals that you are a Target. It is only valid after a Selection or Reselection is completed and before bus free.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6   | (0) | SELDO   | Select Out. This bit is a one when you have successfully done a Select Out or Reselect Out sequence. TARGET will decide whether it was Select (TARGET=0) or Reselect (TARGET=1). It is cleared by a Bus Free condition or by setting CLRSELDO (bit 6,CLRSINTO). Interrupts may be enabled by setting ENSELDO (bit 6, SIMODE0)) to one. SELDO is a wake up condition, when enabled, for the sequencer SLEEP mode.                                                                                                                                                                                             |
| 5   | (0) | SELDI   | Select In. This bit is a one when you have been selected or reselected. If TARGET is a one, you have been selected, and if zero, you have been reselected. It is cleared by a Bus Free condition or by setting CLRSELDI (bit 5, CLRSINTO). Interrupts may be enabled by setting ENSELDI (bit 5, SIMOEDO) to one. SELDI is a wake up condition, when enabled, for the sequencer Sleep mode.                                                                                                                                                                                                                   |
| 4   | (0) | SELINGO | Selecting Out. After successful arbitration, this bit is set to one when you start the attempt to select or reselect another device. This interrupt is used to start looking for SELDO or bus time-out. When a successful selection has been completed (SELDO is one), this bit will be cleared. This bit may also be cleared by setting CLRSELINGO (bit 4, CLRSINTO).                                                                                                                                                                                                                                       |
| 3   | (0) | SWRAP   | SCSI Count Wrap. This bit is a one when STCNT counts from 000000h to FFFFFFh and SWRAPEN is set. SWRAPEN (bit 6, SZFRCTL1) must be set to enable the counter to count down past 000000h. SWRAP will also be set if SDMAEN is set to one, and both STCNT is equal to zero and SWRAPEN is one. This bit may be cleared by setting CLRSWRAP (bit 3, CLRSINT0).                                                                                                                                                                                                                                                  |
| 2   | (0) | SDONE   | SCSI Done. This bit is set to one when STCNT=000000h, SWRAPEN is cleared, SDMAEN or SPIOEN is set, and the last transfer has completed. It may also be set when SPIORDY is set. This bit may be cleared by writing a nonzero count to STCNT, setting SRAPEN, clearing SDMAEN, or if set by SPIORDY, it may be cleared by clearing SPIORDY, SCSIEN (bit 5, DFCNTRL) should be cleared before this bit is cleared in Target mode to prevent false transfers.                                                                                                                                                   |
| 1   | (0) | SPIORDY | SCSI PIO Ready. When this bit is one, the Automatic SCSI PIO function has been enabled and data is ready or needed by the SCSI data transfer logic. As an Initiator, this bit is set to one on the leading edge of REQ. In Target mode, this bit is set on the leading edge of ACK. In both Initiator and Target mode, during a transfer to SCSI, the bit is cleared on a write to SCSIDATL. During a transfer from SCSI, it is cleared on a read from SCSIDATL. It may also be cleared by setting CLRSPIORDY (bit 1, CLRSINT0) or by clearing SPIOEN (bit 3, SXFRCTL0). This bit sets SDONE when it is set. |
| 0   | (0) | DMADONE | <b>DMA Done.</b> This bit is the logical AND of HDONE (bit 3, DFSTATUS) and SDONE. It indicates the current transfer has completely finished. DMADONE is a wake up condition, when enabled, for the sequencer Sleep mode.                                                                                                                                                                                                                                                                                                                                                                                    |

### Clear SCSI interrupt 1 (CLRSINT1)

Type: W

Address: M0Ch, DS-0Ch

Writing a one to a bit in this register clears the associated SCSI interrupt bit in SSTAT1. Each bit is self-clearing and writing a zero to any bit in this register will have no effect.

| CLRSINT1<br>W |             |  |
|---------------|-------------|--|
| 7             | CLRSELTIMO  |  |
| 6             | CLRATNO     |  |
| 5             | CLRSCSIRSTI |  |
| 4             |             |  |
| 3             | CLRBUSFREE  |  |
| 2             | CLRSCSIPERR |  |
| 1             | CLRPHASECHG |  |
| 0             | CLRREQINIT  |  |

| Bit |     | Name        | Definition                                                                                                                                                                                    |
|-----|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | CLRSELTIMO  | Clears the SELTO interrupt and status.                                                                                                                                                        |
| 6   | (0) | CLRATNO     | In Initiator mode, clears the SCSI ATN bit if set by the sequencer or any automatic mode. ATN is also cleared by the Bus Free condition. In Target mode, clears ATNTARG interrupt and status. |
| 5   | (0) | CLRSCSIRSTI | Clears SCSIRSTI interrupt and status.                                                                                                                                                         |
| 4   | (0) | Not Used    |                                                                                                                                                                                               |
| 3   | (0) | CLRBUSFREE  | Clears BUSFREE interrupt and status.                                                                                                                                                          |
| 2   | (0) | CLRSCSIPERR | Clears SCSIPERR interrupt and status.                                                                                                                                                         |
| 1   | (0) | CLRPHASECHG | Clears PHASECHG interrupt and status.                                                                                                                                                         |
| 0   | (0) | CLRREQINIT  | Clears REQINIT interrupt and status.                                                                                                                                                          |

# SCSI Status 1 (SSTAT1)

Type: R

Address: M0Ch, DS-0Ch

This register contains the status of SCSI interrupt bits. Any interrupt bit may be read at any time whether or not it has been enabled in SIMODE1. If enabled and set to one, it will cause the interrupt line to go to the active state. All are cleared by the corresponding bits in CLRSINT1 register (except PHASEMIS and SCSIPERR).

| SSTAT1<br>R |          |  |
|-------------|----------|--|
| 7           | SELTO    |  |
| 6           | ATNTARG  |  |
| 5           | SCSIRSTI |  |
| 4           | PHASEMIS |  |
| 3           | BUSFREE  |  |
| 2           | SCSIPERR |  |
| 1           | PHASECHG |  |
| 0           | REQINIT  |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | SELTO    | Selection Time-out. This bit is set when the hardware selection timer is enabled and a Selection or Reselection time-out occurs. The timer is enabled by setting ENSTIMER (bit 2, SXFRCTL1) to one along with the time-out value in bits 3 and 4. The bit is cleared by setting CLRSELTIMO (bit 7, CLRSINT1) to one.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6   | (0) | ATNTARG  | Attention Target. This bit is set to one when you are a Target and the Initiator asserts ATN. It is latched and will be cleared when ATN is deasserted or when CLRATNO (bit 6, CLRSINT1) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5   | (0) | SCSIRSTI | SCSI Reset In. This bit is set to one when another device asserts RST# on the SCSI bus. It remains set until cleared by writing a one to CLRSCSIRSTI (bit 5, CLRSINT1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4   | (0) | PHASEMIS | Phase Mismatch. Initiator mode only. This bit is set to one when the last phase on the SCSI bus sampled by REQ does not match the expected phase which is in the SCSISIGO register. It is qualified with REQINIT (bit 0, SSTAT1) and is cleared by writing the matching phase in SCSISIGO or by clearing REQINIT. PHASEMIS is a wake up condition, when enabled, for the sequencer Sleep mode.                                                                                                                                                                                                                                                                                                                                   |
| 3   | (0) | BUSFREE  | <b>Bus Free.</b> This bit is set to one when the BSY and SEL signals have been negated on the SCSI bus for 400ns. This signal is latched and may be cleared by setting CLRBUSFREE in CLRSINT1 to one. This bit will be initially set to zero, but will reflect the state of the SCSI bus after 400ns.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2   | (0) | SCSIPERR | SCSI Parity Error. This bit is set to one when a parity error is detected on the incoming SCSI information transfer. Parity is sampled on the leading edge of REQ if in Initiator mode or the leading edge of ACK if in Target mode. If WIDEXFER in SXFRCTL0 is set, then parity will be checked on the upper byte of the SCSI bus during the Data phase only. If parity is enabled (ENSPCHK in SXFRCTL1 is set to one), a parity error will cause a one to be latched in this bit until cleared by writing one to CLRSCSIPERR in CLRSINT1. After writing to CLRSCSIPERR, this bit reflects the status of the parity of the last byte transferred on the bus. If ENSPCHK is set to zero, this bit will always be read as a zero. |
| 1   | (0) | PHASECHG | SCSI Phase Change. This bit is set to one when the phase on the SCSI bus changes to a phase that does not match the expected phase which is in the SCSISIGO register. It is not qualified with REQ. It can be cleared by writing a one to CLRPHASECHG in CLRSINT1.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0   | (0) | REQINIT  | Request Initialize. Initiator mode only. This bit is set to one in asynchronous transfer mode on the leading edge of a REQ being asserted on the SCSI bus or when in synchronous transfer mode and the offset count is greater than one. In asynchronous transfer mode it is cleared on the leading edge of any ACK sent out on the SCSI bus, or when in synchronous transfer mode the offset count is equal to zero, or with CLRREQINIT (bit 0, CLRSINT1).                                                                                                                                                                                                                                                                      |

# SCSI Status 2 (SSTAT2)

Type: R
Address: M0Dh, DS-0Dh

These bits are read only and give the status of the SCSI FIFOs.

| SSTAT2<br>R |          |  |
|-------------|----------|--|
| 7           | OVERRUN  |  |
| 6           |          |  |
| 5           |          |  |
| 4           | SFCNT(4) |  |
| 3           | SFCNT(3) |  |
| 2           | SFCNT(2) |  |
| 1           | SFCNT(1) |  |
| 0           | SFCNT(0) |  |

| Bit |     | Name       | Definition                                                                                                                                                                                                                                                                                                                                                                      |
|-----|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | OVERRUN    | Overrun Detect. During synchronous transfers, this bit is set to one when an offset overrun is detected in the read direction for Initiator mode only. An offset overrun is defined as the situation where the maximum offset has been reached and another REQ is detected before an ACK is asserted on the SCSI bus. This status bit is cleared with CLRCHN (bit 1, SXFRCTL0). |
| 6-5 | (0) | Not Used   | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                 |
| 4-0 | (0) | SFCNT(4:0) | <b>SCSI FIFO Byte Count.</b> Shows the count of bytes in the SCSI FIFO. A value of 0h means the SCSI FIFO is empty. A count of 16 means the SCSI FIFO is full.                                                                                                                                                                                                                  |

# SCSI Status 3 (SSTAT3)

Type: R Address: M0Eh, DS-0Eh

This register is the status of the current Synchronous SCSI Information Transfer phase.

| SSTAT3<br>R |            |  |
|-------------|------------|--|
| 7           | SCSICNT(3) |  |
| 6           | SCSICNT(2) |  |
| 5           | SCSICNT(1) |  |
| 4           | SCSICNT(0) |  |
| 3           | OFFCNT(3)  |  |
| 2           | OFFCNT(2)  |  |
| 1           | OFFCNT(1)  |  |
| 0           | OFFCNT(0)  |  |

| Bit |     | Name         | Definition                                                                                                                                                                                                                                        |
|-----|-----|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4 | (0) | SCSICNT(3:0) | SCSI Count (3:0). Gives the difference between what the offset count says is in the SCSI FIFO and what the OFFCNT says is in the SCSI FIFO. Used by hardware to prevent SCSI FIFO overrun. Do not read this counter unless transfers are stopped. |
| 3-0 | (0) | OFFCNT(3:0)  | <b>SCSI Offset Count (3:0).</b> Gives the current SCSI offset count. Do not read this counter unless transfers are stopped.                                                                                                                       |

# SCSI Test Control (SCSITEST)

Type: R/W Address: M0Fh, DS-0Fh

This register is used to force test modes in the SCSI Module Logic.

| SCSITEST<br>R/W |          |  |
|-----------------|----------|--|
| 7               |          |  |
| 6               |          |  |
| 5               |          |  |
| 4               | DATALOOP |  |
| 3               |          |  |
| 2               | RQAKCNT  |  |
| 1               | CNTRTEST |  |
| 0               | CMODE    |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5 | (0) | Not Used | Always read 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4   | (0) | DATALOOP | Data Loop. When active (=1) enables data to be transferred from the data FIFO through the SCSI FIFO to the SCSI output data registers (SCSIBUSH and SCSIBUSL) and then read out by the sequencer or software driver. Alternately, data may be written to the SCSI input data registers (SCSIDATH and SCSIDATL) by the sequencer or the software driver for transfer to the SCSI FIFO then to the data FIFO. In either direction the SCSI bus is isolated and unaware of this activity. |
| 3   | (0) | Not Used | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2   | (0) | RQAKCNT  | Request/Acknowledge Count. This bit inverts the meaning of the DIRECTION input signal for STCNT. If DIRECTION =1 (write) and this bit is set, then reading the STCNT register will access the STCNT counter instead of RQAKCNT. If DIRECTION=0 (read) and this bit is set, then reading the STCNT register will access the RQAKCNT counter instead of STCNT.                                                                                                                           |
| 1   | (0) | CNTRTEST | Counter Test. When set to one, the SCSI transfer counter STCNT and the Selection time-out counter SELTIMER are put into a mode where they count down at the input clock rate, and the SCSI host address counter SHADDR is put into a mode where it counts up at the input clock rate.                                                                                                                                                                                                  |
| 0   | (0) | CMODE    | Carry Mode. When set to one, forces a stage-to-stage carry true in STCNT, SHADDR, and SELTIMER. During the Transfer Count test, the counter contents can be monitored by reading the desired stage.                                                                                                                                                                                                                                                                                    |

# SCSI Interrupt Mode 0 (SIMODE0)

Type: R/W

Address: M10h, DS-10h

Setting any bit will enable the corresponding function in SSTAT0 to interrupt via the IRQA# pin.

| SIMODE0<br>R/W |           |  |
|----------------|-----------|--|
| 7              |           |  |
| 6              | ENSELDO   |  |
| 5              | ENSELDI   |  |
| 4              | ENSELINGO |  |
| 3              | ENSWRAP   |  |
| 2              | ENSDONE   |  |
| 1              | ENSPIORDY |  |
| 0              | ENDMADONE |  |

| Bit |     | Name      | Definition                                |
|-----|-----|-----------|-------------------------------------------|
| 7   | (0) | Not Used  | Always reads 0.                           |
| 6   | (0) | ENSELDO   | Enables SELDO status to assert SCSIINT.   |
| 5   | (0) | ENSELDI   | Enables SELDI status to assert SCSIINT.   |
| 4   | (0) | ENSELINGO | Enables SELINGO status to assert SCSIINT. |
| 3   | (0) | ENSWRAP   | Enables SWRAP status to assert SCSIINT.   |
| 2   | (0) | ENSDONE   | Enables SDONE status to assert SCSIINT.   |
| 1   | (0) | ENSPIORDY | Enables SPIORDY status to assert SCSIINT. |
| 0   | (0) | ENDMADONE | Enables DMADONE status to assert SCSIINT. |

# SCSI Interrupt Mode 1 (SIMODE1)

Type: R/W Address: M11h, DS-11h

Setting any bit will enable the corresponding function in SIMODE1 to interrupt via the IRQA# pin.

| SIMODE1<br>R/W |            |  |
|----------------|------------|--|
| 7              | ENSELTIMO  |  |
| 6              | ENATNTARG  |  |
| 5              | ENSCSIRST  |  |
| 4              | ENPHASEMIS |  |
| 3              | ENBUSFREE  |  |
| 2              | ENSCSIPERR |  |
| 1              | ENPHASECHG |  |
| 0              | ENREQINIT  |  |

| Bit |     | Name       | Definition                                             |
|-----|-----|------------|--------------------------------------------------------|
| 7   | (0) | ENSELTIMO  | Enables the SELTO status to assert SCSIINT.            |
| 6   | (0) | ENATNTARG  | Enables ATNTARG status to assert SCSIINT.              |
| 5   | (0) | ENSCSIRST  | Enables SCSIRST status to assert SCSIINT.              |
| 4   | (0) | ENPHASEMIS | Enables PHASEMIS status to assert SCSIINT.             |
| 3   | (0) | ENBUSFREE  | Enables BUSFREE status to assert SCSIINT.              |
| 2   | (0) | ENSCSIPERR | Enables the latched SCSIPERR status to assert SCSIINT. |
| 1   | (0) | ENPHASECHG | Enables PHASECHG status to assert SCSIINT.             |
| 0   | (0) | ENREQINIT  | Enables REQINIT status to assert SCSIINT.              |

## SCSI Data Bus (SCSIBUSL, [H])

Type: R

Address: M12/M13h, DS-12/13h

This register reads data on the SCSI data bus directly. Data is gated from the SCSI data bus to the internal data bus, it is not latched in the SCSI module.

| SCSIBUSL<br>R |         | SCSIBUSH<br>R |      |
|---------------|---------|---------------|------|
| 7             | SDB(07) | 7             | RSVD |
| 6             | SDB(06) | 6             | RSVD |
| 5             | SDB(05) | 5             | RSVD |
| 4             | SDB(04) | 4             | RSVD |
| 3             | SDB(03) | 3             | RSVD |
| 2             | SDB(02) | 2             | RSVD |
| 1             | SDB(01) | 1             | RSVD |
| 0             | SDB(00) | 0             | RSVD |

#### SCSI Count Host Address (SHADDR[0:3])

Type: F

Address: M14/M15/M16/M17h, DS-14/15/16/17h

These registers are written when the Host Address registers (M88h - M8Bh) are written and HADDLDSEL[1:0] value is 0. They are counted up in the same manner that STCNT is counted down. This value is saved when the Save Data Pointers message is received. The value is set to zero when reset.

| SHADDRO<br>R | SHADDR1<br>R | SHADDR2<br>R | SHADDR3<br>R |
|--------------|--------------|--------------|--------------|
| 7 SHADDR(07) | 7 SHADDR(15) | 7 SHADDR(23) | 7 SHADDR(31) |
| 6 SHADDR(06) | 6 SHADDR(14) | 6 SHADDR(22) | 6 SHADDR(30) |
| 5 SHADDR(05) | 5 SHADDR(13) | 5 SHADDR(21) | 5 SHADDR(29) |
| 4 SHADDR(04) | 4 SHADDR(12) | 4 SHADDR(20) | 4 SHADDR(28) |
| 3 SHADDR(03) | 3 SHADDR(11) | 3 SHADDR(19) | 3 SHADDR(27) |
| 2 SHADDR(02) | 2 SHADDR(10) | 2 SHADDR(18) | 2 SHADDR(26) |
| 1 SHADDR(01) | 1 SHADDR(09) | 1 SHADDR(17) | 1 SHADDR(25) |
| 0 SHADDR(00) | 0 SHADDR(08) | 0 SHADDR(16) | 0 SHADDR(24) |
|              | 1            | 1            | , , ,        |

# **Selection Time-out Timer (SELTIMER)**

Type:

R

Address: M18h, DS-18h

This register is used to monitor the state of the hardware selection time-out timer and the SCAM timer.

| SELTIMER<br>R/W |         |  |  |
|-----------------|---------|--|--|
| 7               | CLKOUT  |  |  |
| 6               |         |  |  |
| 5               | STAGE 6 |  |  |
| 4               | STAGE 5 |  |  |
| 3               | STAGE 4 |  |  |
| 2               | STAGE 3 |  |  |
| 1               | STAGE 2 |  |  |
| 0               | STAGE 1 |  |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                                                               |
|-----|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | CLKOUT   | Clock Out. A timer provided for the HIM driver to use when performing SCAM protocol. It is enabled to run whenever SCAMEN (SXFRCTL0 register) is active. The frequency is determined by the CLKIN source (40 MHz) divided to provide a 102.40 μs period. |
| 6   | (0) | Not Used | Always reads 0.                                                                                                                                                                                                                                          |
| 5   | (0) | STAGE 6  | (divide by 2, output)                                                                                                                                                                                                                                    |
| 4   | (0) | STAGE 5  | (divide by 2, output)                                                                                                                                                                                                                                    |
| 3   | (0) | STAGE 4  | (divide by 2, output)                                                                                                                                                                                                                                    |
| 2   | (0) | STAGE 3  | (divide by 10, output)                                                                                                                                                                                                                                   |
| 1   | (0) | STAGE 2  | (divide by 256, output)                                                                                                                                                                                                                                  |
| 0   | (0) | STAGE 1  | (divide by 256, output)                                                                                                                                                                                                                                  |

## Selection/Reselection ID (SELID)

Type: R

Address: M19h, DS-19h

This register contains the SCSI ID of the selecting or reselecting device which was asserted during the last Selection/Reselection SCSI bus phase. Hardware will remove the device ID and decode the remaining ID. After a Selection/Reselection in has taken place, the ID may be read from this register to determine the ID of the device which initiated the Selection/Reselection. If a selection occurred by a SCSI device which did not set its own ID, then ONEBIT will be set to indicate that condition. If ONEBIT is zero, then 2 bits were active on the SCSI bus.

| SELID<br>R |          |  |  |
|------------|----------|--|--|
| 7          | RSVD     |  |  |
| 6          | SELID(2) |  |  |
| 5          | SELID(1) |  |  |
| 4          | SELID(0) |  |  |
| 3          | ONEBIT   |  |  |
| 2          |          |  |  |
| 1          |          |  |  |
| 0          |          |  |  |

| Bit |     | Name       | Definition                                                                                                                                                   |
|-----|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | RSVD       | Always reads 0.                                                                                                                                              |
| 6-4 | (0) | SELID(2:0) | Selection ID. This is the ID of the selecting or reselecting SCSI device.                                                                                    |
| 3   | (0) | ONEBIT     | This bit is set when only one bit is detected on the lower 8 bits (if SELWIDE=0) during Selection. It is zero when two bits are detected during a Selection. |
| 2-0 | (0) | Not Used   | Always reads 0.                                                                                                                                              |

# **SCSI Block Control (SBLKCTL)**

Type: R/W Address: M1Fh, DS-1Fh

This register controls the hardware selection options outside of the SCSI cells. This control includes address decodes and data multiplexing.

| SBLKCTL<br>R/W |                |  |  |
|----------------|----------------|--|--|
| 7              | DIAGLEDEN      |  |  |
| 6              | DIAGLEDON      |  |  |
| 5              | 5 AUTOFLUSHDIS |  |  |
| 4              |                |  |  |
| 3              | SELBUSB        |  |  |
| 2              |                |  |  |
| 1              | SELWIDE        |  |  |
| 0              |                |  |  |

| Bit |     | Name         | Definition                                                                                                                                                                                                                                                                                |
|-----|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (1) | DIAGLEDEN    | <b>Diagnostic LED Enable.</b> The bit has no effect on AIC-7850 and is a reserved bit. This bit is read/writable.                                                                                                                                                                         |
| 6   | (1) | DIAGLEDON    | <b>Diagnostic LED On.</b> The bit has no effect on AIC-7850 and is a reserved bit. This bit is read/writable.                                                                                                                                                                             |
| 5   | (0) | AUTOFLUSHDIS | <b>Auto Flush Disable.</b> When active (=1) prevents the SCSI hardware activated autoflush action of the data FIFO to the PCI bus system memory due to SCSI PHASEMIS or SDONE becoming active. FIFOFLUSH in the DFCNTRL register may then be used to activate the flush action as needed. |
| 4   | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                           |
| 3   | (0) | SELBUSB      | This bit always read as 0 and writing to this bit has no effect.                                                                                                                                                                                                                          |
| 2   | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                           |
| 1   | (0) | SELWIDE      | Select Wide. Always reads 0.                                                                                                                                                                                                                                                              |
| 0   | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                           |

# **Sequencer Device Space Register Definition**

# **Sequencer Control (SEQCTL)**

Type:

R/W

Address: M60h, DS-60h

| SEQCTL<br>R/W |             |  |
|---------------|-------------|--|
| 7             | PERRORDIS   |  |
| 6             | PAUSEDIS .  |  |
| 5             | FAILDIS     |  |
| 4             | FASTMODE    |  |
| 3             | BRKADRINTEN |  |
| 2 STEP        |             |  |
| 1             | SEQRESET    |  |
| 0             | LOADRAM     |  |

| Bit |     | Name        | Definition                                                                                                                                                                                                                                                                                                   |
|-----|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (1) | PERRORDIS   | Parity Error Disable. When cleared, allows sequencer RAM parity errors to be detected. When set, disables Parity Error detection.                                                                                                                                                                            |
| 6   | (0) | PAUSEDIS    | <b>Pause Disable.</b> If set, disables the Pause function when PAUSE (bit 2, HCNTRL) is set. Pause due to interrupts or error conditions is still enabled. SCSI interrupts, an illegal opcode interrupt, or a sequencer RAM parity error interrupt resets this bit. Host software may not write to this bit. |
| 5   | (0) | FAILDIS     | Fail Disable. If set, disables parity and PCI error status interrupt feature. If cleared, the detection of an parity or PCI error status will cause a BRKADRINT to occur and will latch-pause the sequencer.                                                                                                 |
| 4   | (1) | FASTMODE    | Fast Mode. If set to one, then the clock to the sequencer is divided by four from the input clock. If set to zero, then the clock is divided by five.                                                                                                                                                        |
| 3   | (0) | BRKADRINTEN | Break Address Interrupt Enable. When set, the breakpoint status is enabled to drive the interrupt pin. When cleared and the breakpoint is enabled (clear BRKDIS in BRKADDR1), BRKADRINT (bit 3, INTSTAT) will be set, but IRQA# will not be asserted.                                                        |
| 2   | (0) | STEP        | <b>Step.</b> When set, the sequencer will execute one instruction and then self-pause. The sequencer should be paused before using this bit. This bit will remain set until cleared by the software driver. Multiple single steps may be done by clearing PAUSE (bit 2, HCNTRL) multiple times.              |
| 1   | (0) | SEQRESET    | Sequencer RAM Address Reset. When set, the address pointer for the sequencer RAM is cleared and program execution starts at location zero. This bit is self-clearing. The sequencer must be paused before setting this bit.                                                                                  |
| 0   | (0) | LOADRAM     | Load Sequencer RAM. When set, allows the sequencer RAM to be loaded or read by writing or reading a series of bytes to or from SEQRAM. This bit should be cleared for normal operation. When switching between reads and writes, this bit should be first cleared, then set again.                           |

#### **Sequencer RAM Data (SEQRAM)**

Type: R/W

Address: M61h, DS-61h

This register is a port to the sequencer RAM area. The RAM may be loaded by first writing a starting address in SEQADDR0 and SEQADDR1, then sending a stream of bytes to this register. The byte ordering should be from the least significant byte to the most significant. The address will be auto-incremented after the most significant byte is written to facilitate loading the program.

| SEQRAM<br>R/W |             |  |
|---------------|-------------|--|
| 7             | SEQRAM(7)   |  |
| 6             | SEQRAM(6)   |  |
| 5             | 5 SEQRAM(5) |  |
| 4             | 4 SEQRAM(4) |  |
| 3             | 3 SEQRAM(3) |  |
| 2             | SEQRAM(2)   |  |
| 1             | SEQRAM(1)   |  |
| 0             | SEQRAM(0)   |  |

#### Sequencer RAM Address (SEQADDR[1:0])

Type: R/W

Address: M62/63h, DS-62/63h

These registers contain the address of the sequencer RAM that will be executed on the next clock edge. They may be written to for the purpose of changing the execution location after first pausing the sequencer. They are also used to specify the starting location when loading the program. The address will automatically increment while loading the program after every fourth byte. The fourth byte index is cleared when this register is written. SEQADDR[1:0] are cleared to 0h by RST# or CHIPRST. See Sequencer Loading on page 5-7.

| ,  | SEQADDR0<br>R/W |   | SEQADDR1<br>R/W |  |
|----|-----------------|---|-----------------|--|
| 7  | SEQADDR(07)     | 7 |                 |  |
| 6  | SEQADDR(06)     | 6 |                 |  |
| 5  | SEQADDR(05)     | 5 | RSVD            |  |
| 4  | SEQADDR(04)     | 4 | RSVD            |  |
| 3  | SEQADDR(03)     | 3 | RSVD            |  |
| 2  | SEQADDR(02)     | 2 | RSVD            |  |
| 1  | SEQADDR(01)     | 1 | RSVD            |  |
| 0_ | SEQADDR(00)     | 0 | SEQADDR(08)     |  |

## Accumulator (ACCUM)

Type:

R/W

Address: M64h, DS-64h

This register is a temporary holding place for arithmetic or logical operations.

| ACCUM<br>R/W |          |  |
|--------------|----------|--|
| 7            | ACCUM(7) |  |
| 6            | ACCUM(6) |  |
| 5            | ACCUM(5) |  |
| 4            | ACCUM(4) |  |
| 3            | ACCUM(3) |  |
| 2            | ACCUM(2) |  |
| 1            | ACCUM(1) |  |
| 0            | ACCUM(0) |  |

# Source Index Register (SINDEX)

Type:

R/W

Address: M65h, DS-65h

This register is a temporary holding register or may be used as an indirect address for source operands for some ALU operations.

| SINDEX<br>R/W |           |  |
|---------------|-----------|--|
| 7             | SINDEX(7) |  |
| 6             | SINDEX(6) |  |
| 5             | SINDEX(5) |  |
| 4             | SINDEX(4) |  |
| 3             | SINDEX(3) |  |
| 2             | SINDEX(2) |  |
| 1             | SINDEX(1) |  |
| 0             | SINDEX(0) |  |

## **Destination Index Register (DINDEX)**

Type:

R/W

Address: M66h, DS-66h

This register is a temporary holding register or may be used as an indirect address for destination operands for some ALU operations.

| DINDEX<br>R/W |           |  |
|---------------|-----------|--|
| 7             | DINDEX(7) |  |
| 6             | DINDEX(6) |  |
| 5             | DINDEX(5) |  |
| 4             | DINDEX(4) |  |
| 3             | DINDEX(3) |  |
| 2             | DINDEX(2) |  |
| 1             | DINDEX(1) |  |
| 0             | DINDEX(0) |  |

#### **Break Address 0 (BRKADDR0)**

Type: R/W

Address: M67h, DS-67h

This register is used for diagnostic purposes to halt the sequencer at a specific address. It is loaded with the lower byte of the break address. BRKADDR0 is cleared to 0h by RST# or CHIPRST. See *Breakpoint* on page 5-7.

| BRKADDR0<br>R/W |             |  |
|-----------------|-------------|--|
| 7               | BRKADDR(07) |  |
| 6               | BRKADDR(06) |  |
| 5               | BRKADDR(05) |  |
| 4               | BRKADDR(04) |  |
| 3               | BRKADDR(03) |  |
| 2               | BRKADDR(02) |  |
| 1               | BRKADDR(01) |  |
| 0               | BRKADDR(00) |  |

## **Break Address 1 (BRKADDR1)**

Type: R/W

Address: M68h, DS-68h

This register is used for diagnostic purposes to halt the sequencer at a specific address. It is loaded with the upper byte of the break address. In addition, bit 7 is a break condition disable. See *Breakpoint* on page 5-7.

| BRKADDR1<br>R/W |             |  |
|-----------------|-------------|--|
| 7               | BRKDIS      |  |
| 6               |             |  |
| 5               | RSVD        |  |
| 4               | RSVD        |  |
| 3               | RSVD        |  |
| 2               | RSVD        |  |
| 1               | RSVD        |  |
| 0               | BRKADDR(08) |  |

| Bit |     | Name        | Definition                                                                                                                        |
|-----|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7   | (1) | BRKDIS      | <b>Break Disable.</b> When set, it disables the break on compare feature of the sequencer. When cleared, this feature is enabled. |
| 6   | (0) | Not Used    | Always reads 0.                                                                                                                   |
| 5   | (0) | RSVD        |                                                                                                                                   |
| 4   | (0) | RSVD        |                                                                                                                                   |
| 3   | (0) | RSVD        |                                                                                                                                   |
| 2   | (0) | RSVD        |                                                                                                                                   |
| 1   | (0) | RSVD        |                                                                                                                                   |
| 0   | (0) | BRKADDR(08) | Break Address. Address bit 08 used for comparison with BRKADDR0.                                                                  |

## All Ones (ALLONES)

Type:

R

Address: M69h, DS-69h

This port returns all ones when read. It may be used for certain logical and arithmetic functions.

## **All Zeros (ALLZEROS)**

Type:

R

Address: M6Ah, DS-6Ah

This port returns all zeros when read. It may be used for certain logical and arithmetic functions.

#### No Destination (NONE)

Type:

W

Address: M6Ah, DS-6Ah

When this port is selected as the destination, no change will be made to any location.

#### Flags (FLAGS)

Type:

R

Address: M6Bh, DS-6Bh

This register returns the flag values.

| FLAGS<br>R |       |  |
|------------|-------|--|
| 7          |       |  |
| 6          |       |  |
| 5          |       |  |
| 4          |       |  |
| 3          |       |  |
| 2          |       |  |
| 1          | ZERO  |  |
| 0          | CARRY |  |

## Source Index Indirect (SINDIR)

Type:

R

Address: DS-6Ch

When a transfer is done from this port, the contents of SINDEX is used as the source address. After the transfer is completed, SINDEX is incremented. This register is usable only by the sequencer.

| SINDIR<br>R |               |  |
|-------------|---------------|--|
|             | CONTENTS      |  |
|             | POINTED TO BY |  |
|             | SINDEX        |  |

## **Destination Index Indirect (DINDIR)**

Type: W Address: DS-6Dh

When a transfer is done to this port, the contents of DINDEX is used as the destination address. After the transfer is completed, DINDEX is incremented. This register is usable only by the sequencer.

| DINDIR<br>W |               |
|-------------|---------------|
|             | CONTENTS      |
|             | POINTED TO BY |
|             | DINDEX        |

## Function1 (FUNCTION1)

Type: R/W

Address: M6Eh, DS-6Eh

This register provides a specific function for use by the sequencer code to minimize the number of instructions. Data is written to FUNCT1 with valid data in bits 6-4. This octal value is decoded into a 1 of 8 bit position. A value of 0 gives a 1 in bit position 0, a value of 1 gives a 1 in bit position 1, etc. with all other bit positions having a value of 0.

| FUNCTION1<br>W |            | FUNCTION1<br>R          |
|----------------|------------|-------------------------|
| 7              |            | 1 of 8 decoded value of |
| 6              | FUN1DAT(2) | FUN1DAT(2:0)            |
| 5              | FUN1DAT(1) |                         |
| 4              | FUN1DAT(0) |                         |
| 3              |            |                         |
| 2              |            |                         |
| 1              |            |                         |
| 0              |            |                         |

## Stack (STACK)

Type: I

Address: M6Fh, DS-6Fh

The contents of the stack is reported one byte at a time starting from the last location pushed on the stack until all entries are reported. The stack entries are reported by consecutive reads alternating low byte then high byte. Location 0 points to the last pushed entry, location 1 points to the entry pushed before that, etc. The sequence of bytes returned is as follows:

| Byte<br>Number | Stack<br>Location | Low/High |
|----------------|-------------------|----------|
| 0              | 0                 | Low      |
| 1              | 0                 | High     |
| 2              | 1                 | Low      |
| 3              | 1                 | High     |
| 4              | 2                 | Low      |
| 5              | 2                 | High     |
| 6              | 3                 | Low      |
| 7              | 3                 | High     |

The stack pointer will be incremented after a read of the high byte, therefore eight reads must be made in order to restore the location of the stack pointer to the original value if it is intended to continue program execution.

| STACK<br>R |          |  |
|------------|----------|--|
| 7          | STACK(7) |  |
| 6          | STACK(6) |  |
| 5          | STACK(5) |  |
| 4          | STACK(4) |  |
| 3          | STACK(3) |  |
| 2          | STACK(2) |  |
| 1          | STACK(1) |  |
| 0          | STACK(0) |  |

# **Configuration Space Register Definition**

Registers in the Configuration Space (CS) may only be written to and/or read from the external interface when IDSEL is asserted AD[1:0]=0 and the PCI command on CBE[3:0]#= CFRC or CFWC. Selected CS register bytes are readable from AIC-7850 Device register space for access by the driver without entering Configuration space. The CS registers follow the PCI-32 bus format requirements and also provide control for some AIC-7850 located die requirements. All bytes of CS 32-bit registers (N18h:N2Ch, N34h:N38h, N41h:7Ch) are reserved and return 0h when read.

In addition, the following CS register bytes are reserved and return 0h when read (N0Ch byte 3, N40h byte 2). All reserved CS registers, bytes and bits ignore data when written to. All writable CS register bits are forced to the initialized state when RST# is asserted.

#### Vendor Identification (VENDOR ID[1:0])

Type:

Address: N00h bits 15-0 (dual access, see Device Register space)

VENDOR ID[1:0]. The PCI vendor identification registers contain product information for use by the host in initialization and configuration of the system. The Adaptec vendor ID contains two bytes of a compressed bit representation (9004h) of the vendor ID. The vendor ID characters for the AIC-7850 are

- the first ID character = A
- the second ID character = D
- the third ID character = P

VENDOR ID[1:0] may be read at any time in Configuration space, and may be read in Device space, without consideration of the state of the PAUSE bit, only when bit 0 or bit 1 is set in the Configuration Command register.

| VENDID1<br>R |         |   | VENDIDO<br>R |
|--------------|---------|---|--------------|
| 15           | VID15=1 | 7 | VID07=0      |
| 14           | VID14=0 | 6 | VID06=0      |
| 13           | VID13=0 | 5 | VID05=0      |
| 12           | VID12=1 | 4 | VID04=0      |
| 11           | VID11=0 | 3 | VID03=0      |
| 10           | VID10=0 | 2 | VID02=1      |
| 09           | VID09=0 | 1 | VID01=0      |
| 08           | VID08=0 | 0 | VID00=0      |

| Bit |     | Name  | Definition                                   |
|-----|-----|-------|----------------------------------------------|
| 15  | (1) | VID15 | Always reads 1, 2nd vendor ID character      |
| 14  | (0) | VID14 | Always reads 0, 2nd vendor ID character      |
| 13  | (0) | VID13 | Always reads 0, 2nd vendor ID character LSB. |
| 12  | (1) | VID12 | Always reads 1, 3rd vendor ID character      |
| 11  | (0) | VID11 | Always reads 0, 3rd vendor ID character      |
| 10  | (0) | VID10 | Always reads 0, 3rd vendor ID character      |
| 09  | (0) | VID09 | Always reads 0, 3rd vendor ID character.     |
| 08  | (0) | VID08 | Always reads 0, 3rd vendor ID character LSB. |
| 07  | (0) | VID07 | Always reads 0, (fill bit).                  |
| 06  | (0) | VID06 | Always reads 0, 1st vendor ID character MSB. |
| 05  | (0) | VID05 | Always reads 0, 1st vendor ID character.     |
| 04  | (0) | VID04 | Always reads 0, 1st vendor ID character.     |
| 03  | (0) | VID03 | Always reads 0, 1st vendor ID character.     |
| 02  | (1) | VID02 | Always reads 1, 1st vendor ID character LSB. |
| 01  | (0) | VID01 | Always reads 0, 2nd vendor ID character MSB. |
| 00  | (0) | VID00 | Always reads 0, 2nd vendor ID character.     |

## **Device Identification (DEVICE ID[1:0])**

Type: R

Address: N00h bits31:16 (dual access, see Device Register space)

DEVICE ID[1:0.] The PCI device identification registers contain product information for use by the host in initialization and configuration of the system. The two device ID bytes contain an Adaptec product code. The product code for the AIC-7850 is 78h for DEVICEID0 and 50 for DEVICEID1.

DEVICE ID[1:0] may be read at any time in Configuration space, and may be read in AIC-7850 Device register space without consideration of the state of the PAUSE bit, only when bit 0 or bit 1 is set in the Configuration Command register. The DEVICEID1 default register value is read only, but may be easily updated with only metal changes.

|    | DEVID1<br>R+ |    | DEVIDO<br>R  |
|----|--------------|----|--------------|
| 31 | DID15=0      | 23 | DID07=0 \    |
| 30 | DID14=1      | 22 | DID06=1   MS |
| 29 | DID13=0      | 21 | DID05=1      |
| 28 | DID12=1      | 20 | DID04=1 /    |
| 27 | DID11=0 \    | 19 | DID03=1      |
| 26 | DID10=0   LS | 18 | DID02=0      |
| 25 | DID09=0 I    | 17 | DID01=0      |
| 24 | DID08=0 /    | 16 | DID00=0      |

| Bit |     | Name  | Definition                                     |
|-----|-----|-------|------------------------------------------------|
| 31  | (0) | DID15 | Normally reads 0, 4th device ID character MSB. |
| 30  | (1) | DID14 | Normally reads 1, 4th device ID character.     |
| 29  | (0) | DID13 | Normally reads 0, 4th device ID character.     |
| 28  | (1) | DID12 | Normally reads 1, 4th device ID character LSB. |
| 27  | (0) | DID11 | Normally reads 0, 3rd device ID character MSB. |
| 26  | (0) | DID10 | Normally reads 0, 3rd device ID character.     |
| 25  | (0) | DID09 | Normally reads 0, 3rd device ID character.     |
| 24  | (0) | DID08 | Normally reads 0, 3rd device ID character LSB. |
| 23  | (0) | DID07 | Normally reads 0, 2nd device ID character MSB. |
| 22  | (1) | DID06 | Normally reads 1, 2nd device ID character.     |
| 21  | (1) | DID05 | Normally reads 1, 2nd device ID character.     |
| 20  | (1) | DID04 | Normally reads 1, 2nd device ID character LSB. |
| 19  | (1) | DID03 | Normally reads 1, 1st device ID character MSB. |
| 18  | (0) | DID02 | Normally reads 0, 1st device ID character.     |
| 17  | (0) | DID01 | Normally reads 0, 1st device ID character.     |
| 16  | (0) | DID00 | Normally reads 0, 1st device ID character LSB. |

## Command (COMMAND[1:0])

Type: R/W

Address: N04h bits15-0 (dual access, see Device Register space)

The COMMAND register provides coarse control over a PCI device's ability to generate and respond to PCI transactions. When a zero is written to this register, the AIC-7850 is logically disconnected from the PCI bus transactions except for Configuration Space transactions. The COMMAND register value should be 0h until the base offset registers are loaded with their operating values, none of which should be the same value. The COMMAND register may be read at any time in Configuration Space.

| COMMAND1<br>R/W |           |    | COMMANDO<br>R/W |
|-----------------|-----------|----|-----------------|
| 15              | RSVD      | 07 | WAITCTLEN=0     |
| 14              | RSVD      | 06 | PERRESPEN       |
| 13              | RSVD      | 05 | VSNOOPEN=0      |
| 12              | RSVD      | 04 | MWRICEN         |
| 11              | RSVD      | 03 | SPCYCEN=0       |
| 10              | RSVD      | 02 | MASTEREN        |
| 09              | MFBTBEN=0 | 01 | MSPACEEN        |
| 08              | SERRESPEN | 0  | ISPACEEN        |

| Bit   |     | Name      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | (0) | Reserved  | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 09    | (0) | MFBFEN    | Master Fast Back-to-back Enable. When active (=1), indicates a master can perform Fast Back-to-back transactions to different PCI targets. The AIC-7850 does not support this feature and MFBTBEN always reads as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 08    | (0) | SERRESPEN | System Error Response Enable. When active (=1) and PERRESPEN is also active, enables output SERR# to be asserted when a PCI 36-bit even parity error is detected by a target during the address phase(s) of transactions, Special Cycle Transaction Data phase and for other errors where the result will be a catastrophic error. The AIC-7850 as a target only asserts SERR# for detected address parity errors and as a master does not assert SERR#. SERRESPEN is set inactive during and after assertion of RST#.                                                                                                                                                                                     |
| 07    | (0) | WAITCTLEN | Wait Control Enable. Always reads 0. (May only be set to one by those devices that do not meet the PCI output specification of 33-10.) The AIC-7850 does not support WAITCLTEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 06    | (0) | PERRESPEN | Parity Error Response Enable. When active (=1), enables PERR# to be asserted when a PCI 36-bit even parity error is detected during Data phases of transactions, except for Special Cycle Transaction Data phase. PERRESPEN must also be active for an address parity error to be reported on SERR#. The AIC-7850 will assert PERR# when PERRESPEN is active and a data parity error is detected as a target for write accesses or as a master for read commands. PERRESPEN must also be active to allow DPE or DPR active conditions to cause IRQA# (when enabled) to be asserted. PERRESPEN is set inactive during and after assertion of RST#.                                                          |
| 05    | (0) | VSNOOPEN  | VGA Snoop Enable. Always reads 0. The AIC-7850 does not support VSNOOPEN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 04    | (0) | MWRICEN   | Memory Write and Invalidate Enable. When active (=1), enables a PCI master to issue Memory Write and Invalidate commands to more optimally transfer data to system memory. When inactive, the Memory Write and Invalidate command will be replaced with Memory Write command. The AIC-7850 as a master will issue MWRIC commands when MWRICEN is active, the data FIFO contains stored data or space to store data that is equal to the selected cache size (not zero), the address is on the cache line start location, a FIFO flush condition is not indicated, and the HCNT value is also equal to or greater than the selected cache size. MWRICEN is set inactive during and after assertion of RST#. |
| 03    | (0) | SPCYCEN   | Special Cycle Enable. Always reads 0. When active (=1), allows a target to monitor special cycle transactions broadcast on the PCI bus. The AIC-7850 does not support special cycles as a target or master.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 02    | (0) | MASTEREN  | Master Enable. When active (=1), enables the AIC-7850 to perform bus master transactions on the PCI bus. Additional transactions to the AIC-7850 Device registers must be performed before the AIC-7850 may request to be a bus master. When inactive, the AIC-7850 bus master transactions are inhibited. MASTEREN is set inactive during and after assertion of RST#.                                                                                                                                                                                                                                                                                                                                    |
| 01    | (0) | MSPACEEN  | Memory Space Enable. When active (=1), enables the AlC-7850 to respond to Device register transactions through mapped memory space (see BASEADR1 register) or external ROM transaction through mapped memory space (see EXROMCTL register). When MSPACEEN is inactive, the AlC-7850 will not respond to device space accesses from memory mapped addresses. MSPACEEN is set inactive during and after assertion of RST#.                                                                                                                                                                                                                                                                                   |
| 00    | (0) | ISPACEEN  | IO Space Enable. When active (=1), enables the AIC-7850 to respond to device register transactions through mapped IO space (see BASEADR0 register). When inactive, the AIC-7850 will not respond to device space accesses from IO mapped addresses. ISPACEEN is set inactive during and after assertion of RST#.                                                                                                                                                                                                                                                                                                                                                                                           |

#### PCI Status (STATUS[1:0])

Type:

R/W

Address: N04h bits 31-16 (dual access (STATUS1 only), see Device Register space)

The STATUS register is used to record status information for PCI bus related events. Read transactions of the STATUS register will access the currently stored status information. Write transactions to the STATUS register are not used to store data but to change selected active bits to be inactive (=0). To change a bit to be inactive, the data value written for that bit (=1) with all other bits not being changed inactive (=0). Any bit 30:27, 24 active and enabled in STATUS1 will cause the PCIERRSTAT bit in the ERROR register to be active and an interrupt to be generated unless FAILDIS or POWRDN is active, or INTEN is inactive. The STATUS[1:0] register is forced to be inactive when RST# is asserted. The STATUS[1:0] register may be read at any time in Configuration space.

|    | STATUS1<br>R/W |    | STATUSO<br>R |
|----|----------------|----|--------------|
| 31 | DPE            | 23 | TFBTBC       |
| 30 | SSE            | 22 | RSVD         |
| 29 | RMA            | 21 | RSVD         |
| 28 | RTA            | 20 | RSVD         |
| 27 | STA            | 19 | RSVD         |
| 26 | DST1           | 18 | RSVD         |
| 25 | DST0           | 17 | RSVD         |
| 24 | DPR            | 16 | RSVD         |

| Bit |     | Name | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | (0) | DPE  | Detected Parity Error. Set active (=1) when a 36-bit even-parity error is detected by a target during an Address phase or a Write Data phase (except for Special Cycles) and by the transaction master during a Read Data phase. DPE is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 31 (=1). When the AIC-7850 sets its DPE bit active with PERRESPEN active and FAILDIS inactive, it will cause an interrupt to be generated to the driver to handle the exception condition and assert PERR# for write accesses to the AIC-7850 as a target or for read transactions with the AIC-7850 as a master.                                                |
| 30  | (0) | SSE  | Signal System Error. Set active (=1) whenever an agent asserts SERR#. SSE is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 30 (=1). The AIC-7850 sets its SSE bit active only when PERRESPEN and SERRESPEN are active for detected address parity errors. When SSE is active and FAILDIS is inactive, it will cause an interrupt to be generated to the driver to handle the exception condition.                                                                                                                                                                                                                                                      |
| 29  | (0) | RMA  | Received Master Abort. Set active (=1) when an AIC-7850 bus master generated transaction is terminated by the AIC-7850 for no response from the intended target by the sixth (for SAC) or seventh (for DAC) PCLK after the AIC-7850 asserted FRAME#. The AIC-7850 will release the bus on the next PCLK and not retry the transaction. Software/firmware intervention is required for the AIC-7850 to continue master transactions. RMA is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 29 (=1). The AIC-7850 will also set RMA active should the addressed target deassert DEVSEL# while the AIC-7850 is asserting FRAME#, a PCI protocol violation. |

#### (Continued)

| Bit   |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |          | Note: Should RMA be cleared with the aborted master transaction still waiting to complete, the AIC-7850 will retry the transaction. To prevent this action, if desired, HDMAEN should be set inactive prior to clearing RMA.                                                                                                                                                                                                                                        |
|       |     |          | The interrupt will remain active till cleared with CLRPARERR.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28    | (0) | RTA      | Received Target Abort. Set active (=1) when the target of an AIC-7850 bus generated transaction is terminated by the target, with a target-abort indication. RTA is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 28 (=1). When a target-abort indication is received, the AIC-7850 will not retry the transaction and software/firmware intervention is required for the AIC-7850 to continue master transactions. |
|       |     |          | Note: Should RTA be cleared with the AIC-7850 still waiting to complete the aborted master transaction, the AIC-7850 will retry the transaction. To prevent this action, if desired, HDMAEN should be set inactive prior to clearing RTA.                                                                                                                                                                                                                           |
|       |     |          | The interrupt will remain active till cleared with CLRPARERR.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27    | (0) | STA      | <b>Signal Target Abort.</b> Set active (=1) by the target of a PCI bus transaction unable to respond due to a fatal error condition. STA is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 27 (=1). The AIC-7850 will indicate target-abort for                                                                                                                                                                      |
|       |     |          | <ul> <li>Incorrect data width. Must be 8 bits for Device space, except for SCI<br/>double word write</li> </ul>                                                                                                                                                                                                                                                                                                                                                     |
|       |     |          | <ul> <li>Value stored in base address registers for BASEADR1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                            |
|       |     |          | <ul> <li>Accesses with POWRDN active except for Host only registers and Configuration registers.</li> </ul>                                                                                                                                                                                                                                                                                                                                                         |
|       |     |          | <ul> <li>Address parity error detected with correct address compare (SERR#<br/>asserted) for current access.</li> </ul>                                                                                                                                                                                                                                                                                                                                             |
|       |     |          | Note: No valid data (CBE[3:0] value of Fh for a Data phase) is not an error condition.                                                                                                                                                                                                                                                                                                                                                                              |
| 26-25 | (1) | DST[1:0] | <b>Device Select Timing[1:0].</b> Value indicates the longest response time of a PCI device for assertion of DEVSEL# for any bus transaction with valid values of 0h for <i>fast</i> (1 PCLK), 1h for <i>medium</i> (2 PCLKs), 2h for <i>slow</i> (3 PCLKs) with value 3h <i>reserved</i> . Respond time for the AIC-7850 is <i>medium</i> . DST[1:0] are fixed value read only bits.                                                                               |
| 24    | (0) | DPR      | Data Parity Reported. When active (=1), indicates the master of a transaction, with its PERRESPEN bit active, has detected PERR# asserted or asserted PERR#. DPR is set inactive during and after assertion of RST# or by a write to the STATUS register with bit 24 (=1).                                                                                                                                                                                          |
| 23    | (1) | TFBTBC   | Target Fast Back-to-back Capable. When active (=1), indicates that the target is capable of accepting Fast PCI Back-to-back transactions even when the transactions are not to the same target. The AIC-7850 as a target supports Fast Back-to-back transactions. TFBTBC is a read only bit.                                                                                                                                                                        |
| 22-16 | (0) | RSVD     | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## **Device Revision ID (DEVREVID)**

Type: R Address: N08h

The Device Revision ID identifies the revision level of a PCI device. Part revision ID may be read at any time in Configuration space. Easy device revision value changes in metal only.

| PARTREVID<br>R |       |  |
|----------------|-------|--|
| 7              | DRID7 |  |
| 6              | DRID6 |  |
| 5              | DRID5 |  |
| 4              | DRID4 |  |
| 3              | DRID3 |  |
| 2              | DRID2 |  |
| 1              | DRID1 |  |
| 0              | DRID0 |  |

| Bit   |      | Name      | Definition                |
|-------|------|-----------|---------------------------|
| 07-00 | (0h) | DRID[7:0] | DRID[7:0] always reads 2. |

# **Programming Interface (PROGINFC)**

Type: R Address: N08h

The Programming Interface register value identifies the specific register-level programming interface the agent supports. The PROGINFC for the first version of the AIC-7850 will be identified as 00h (not VGA compatible). PROGINFC may be read at any time in Configuration space.

| PROGINFC<br>R |       |  |
|---------------|-------|--|
| 15            | PGFC7 |  |
| 14            | PGFC6 |  |
| 13            | PGFC5 |  |
| 12            | PGFC4 |  |
| 11            | PGFC3 |  |
| 10            | PGFC2 |  |
| 09            | PGFC1 |  |
| 08            | PGFC0 |  |

| Bit   |     | Name      | Definition      |  |
|-------|-----|-----------|-----------------|--|
| 15-08 | (0) | PGFC[7:0] | Always reads 0. |  |

#### **Sub Class (SUBCLASS)**

Type: R Address: N08h

The Sub Class register identifies the sub class the PCI device is assigned to. The SUBCLASS for the first version of the AIC-7850 will be identified as 00h (SCSI bus controller). SUBCLASS may be read at any time in Configuration space.

|    | SUBCLASS<br>R |  |  |  |  |  |
|----|---------------|--|--|--|--|--|
| 23 | SCLASS7       |  |  |  |  |  |
| 22 | SCLASS6       |  |  |  |  |  |
| 21 | SCLASS5       |  |  |  |  |  |
| 20 | SCLASS4       |  |  |  |  |  |
| 19 | SCLASS3       |  |  |  |  |  |
| 18 | SCLASS2       |  |  |  |  |  |
| 17 | SCLASS1       |  |  |  |  |  |
| 16 | SCLASS0       |  |  |  |  |  |

| Bit   |     | Name        | Definition      |  |
|-------|-----|-------------|-----------------|--|
| 23-16 | (0) | SCLASS[7:0] | Always reads 0. |  |

#### **Base Class (BASECLASS)**

Type: R Address: N08h

The Base Class register identifies the base class the PCI device has been assigned to. The BASECLASS for the first version of the AIC-7850 will be identified as 01h (mass storage controller). BASECLASS may be read at any time in Configuration space.

| BASECLASS<br>R |         |  |  |  |  |
|----------------|---------|--|--|--|--|
| 31             | BCLASS7 |  |  |  |  |
| 30             | BCLASS6 |  |  |  |  |
| 29             | BCLASS5 |  |  |  |  |
| 28             | BCLASS4 |  |  |  |  |
| 27             | BCLASS3 |  |  |  |  |
| 26             | BCLASS2 |  |  |  |  |
| 25             | BCLASS1 |  |  |  |  |
| 24             | BCLASS0 |  |  |  |  |

| Bit      | Name          | Definition           | <br>_ |  |
|----------|---------------|----------------------|-------|--|
| 31-24 (0 | 1h) BCLASS[7: | 0] Always reads 01h. |       |  |

#### Cache Line Size (CACHESIZE)

Type: R/W Address: N0Ch

The Cache Line Size register specifies the system cache line size in units of 32-bit DWDs. The value stored in the register defines the minimum data transfer size and associated cache starting boundary (and multiples thereof) that may be performed with cache line referenced PCI MWRIC, MRDLC or MRDMC commands.

The AIC-7850 initiated burst cycle transactions can last indefinitely as long as GNT# remains asserted, provided that data or space for data that is being transferred and its transfer byte count has not expired. However, if GNT# is deasserted after the burst cycle is initiated, the AIC-7850 further limits the duration of the burst cycle to the number of CLKs specified by the LATTIME register, plus completion of an in-process cache line transfer referenced command. When the stored value in the CASHESIZE register is 0h, the AIC-7850 will issue MWRC or MRDC instead of MWRIC, MRDLC or MRDMC for data transfer.

Note the effect of MRDCEN active state on command issued and stopping point. CACHESIZE register may be read at any time in Configuration space. CDWDSIZE[5:2] are reset to 0h during assertion of RST#.

| CACHESIZE<br>R-R/W |             |  |  |  |  |
|--------------------|-------------|--|--|--|--|
| 07                 | RSVD        |  |  |  |  |
| 06                 | RSVD        |  |  |  |  |
| 05                 | CDWDSIZE5   |  |  |  |  |
| 04                 | CDWDSIZE4   |  |  |  |  |
| 03                 | CDWDSIZE3   |  |  |  |  |
| 02                 | CDWDSIZE2   |  |  |  |  |
| 01                 | CDWDSIZE1=0 |  |  |  |  |
| 00                 | CDWDSIZE0=0 |  |  |  |  |

| Bit   |     | Name          | Definition       |                                                                                                            |
|-------|-----|---------------|------------------|------------------------------------------------------------------------------------------------------------|
| 07-06 | (0) | RSVD          | Always reads 0.  |                                                                                                            |
| 05-00 | (0) | CDWDSIZE[5:0] |                  | ord Size [5:0]. Define the cache line size that the AIC-7850 orts. Note that CDWDSIZE[1:0] always reads 0. |
|       |     |               | Cache Size Value | Action                                                                                                     |
|       |     |               | [7:0]            |                                                                                                            |
|       |     |               | 0                | Use of MWRIC, (MRDLC and MRDMC) are disabled and replaced with MWRC or MRDC respectively.                  |
|       |     |               | 1-3              | RSVD (default to value 0)                                                                                  |
|       |     |               | 4                | MWRIC, MRDLC and MRDMC use is enabled with a cache line size of 4 DWDs (16 Bytes).                         |
|       |     |               | 5-7              | RSVD (default to value 4)                                                                                  |
|       |     |               | 8                | MWRIC, MRDLC and MRDMC use is enabled with a cache line size of 8 DWDs (32 Bytes).                         |
|       |     |               | 9-15             | RSVD (default to value 8)                                                                                  |
|       |     |               | 16 - 255         | MWRIC, MRDLC and MRDMC use is enabled with a cache line size of 16 DWDs (64 Bytes).                        |

#### Latency Timer (LATTIME)

Type: R/W

Address: N0Ch (dual access, see Device Register space)

The AIC-7850's master latency timer is held initialized until the AIC-7850 asserts FRAME#, then it is enabled to count PCLKs. Whenever FRAME# is deasserted, the LATTIME timer is reinitialized. When the AIC-7850's latency timer expires with FRAME# still asserted, then the AIC-7850 will initiate transaction termination as soon as its GNT# is deasserted (unless a Cache Line Referenced command was issued and is in a process which must be completed before termination) and the target asserts TRDY# on the final Data phase. LATTIME register may be read/written at any time in Configuration space. The LATTIME register is cleared to 0h during RST# assertion.

When the LATTIME value is less than the CACHESIZE value and the GNT# assertion period is also less than the CACHESIZE value, each PREQ# period and data transferred will be the same as the cache size when Cache Line Referenced commands are issued. Providing that the data beginning and end addresses are cache line boundaries.

|    | LATTIME<br>R/W |  |  |  |  |
|----|----------------|--|--|--|--|
| 15 | LATT7          |  |  |  |  |
| 14 | LATT6          |  |  |  |  |
| 13 | LATT5          |  |  |  |  |
| 12 | LATT4          |  |  |  |  |
| 11 | LATT3          |  |  |  |  |
| 10 | LATT2          |  |  |  |  |
| 09 | LATT1=0        |  |  |  |  |
| 08 | LATT0=0        |  |  |  |  |

| Bit   |     | Name      | Definition                                                                                                                      |
|-------|-----|-----------|---------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | (0) | LATT[7:2] | Latency Timer [7:2] are read/write and their value determines the AIC-7850's bus master latency timer period (in PCLK periods). |
| 09-08 | (0) | LATT[1:0} | Latency Timer [1:0] always read 0 (sets granularity at four CLKs).                                                              |

# **Header Type (HDRTYPE)**

Type: R Address: N0Ch

The Header Type register specifies the PCI Configuration header type the device supports. HDRTYPE register may be read at any time in Configuration space. The AIC-7850 supports PCI Configuration header type 00h (with only one function).

| HDRTYPE<br>R |         |  |  |  |  |
|--------------|---------|--|--|--|--|
| 23           | MFDEV=0 |  |  |  |  |
| 22           | HTYPE6  |  |  |  |  |
| 21           | HTYPE5  |  |  |  |  |
| 20           | HTYPE4  |  |  |  |  |
| 19           | HTYPE3  |  |  |  |  |
| 18           | HTYPE2  |  |  |  |  |
| 17           | HTYPE1  |  |  |  |  |
| 16           | HTYPE0  |  |  |  |  |

| Bit   |     | Name       | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | (0) | MFDEV      | Multifunction Device. When active (=1), indicates the device is a device containing multiple independent functions, each of which contains a Configuration space containing device data and address mapping for its function. When MFDEV is active, PCI POST software scan for multiple functions by scanning for the multiple Configuration spaces using AD[10:8] with the same IDSEL active. When MFDEV is inactive, no scanning is required. The AIC-7850 is a single function device and MFDEV always read 0. |
| 22-16 | (0) | HTYPE[6:0] | Header Type. Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## Base Address 0 (BASEADR0)

Type: R/W Address: N10h

Base Address register 0 enables the AIC-7850 Device register space and HIM RAM to be relocated (mapped) within system IO address space to enable the system board device independent POST software to build a consistent IO address map. BASEADR0 may be read at any time in Configuration space. BASEADR0 value is reset to 1h during RST# assertion.

|    | BASEADRO<br>R/W |    |          |    | BASEADRO<br>R/W |    | BASEADRO<br>R |
|----|-----------------|----|----------|----|-----------------|----|---------------|
| 31 | IBMADR29        | 23 | IBMADR21 | 15 | IBMADR13        | 07 | IBMADR05=0    |
| 30 | IBMADR28        | 22 | IBMADR20 | 14 | IBMADR12        | 06 | IBMADR04=0    |
| 29 | IBMADR27        | 21 | IBMADR19 | 13 | IBMADR11        | 05 | IBMADR03=0    |
| 28 | IBMADR26        | 20 | IBMADR18 | 12 | IBMADR10        | 04 | IBMADR02=0    |
| 27 | IBMADR25        | 19 | IBMADR17 | 11 | IBMADR09        | 03 | IBMADR01=0    |
| 26 | IBMADR24        | 18 | IBMADR16 | 10 | IBMADR18        | 02 | IBMADR00=0    |
| 25 | IBMADR23        | 17 | IBMADR15 | 09 | IBMADR07        | 01 | RSVD          |
| 24 | IBMADR22        | 16 | IBMADR14 | 08 | IBMADR06        | 00 | ISPACEIND=1   |

| Bit   |     | Name          | Definition                                                                                                                                                                                                                                                                              |
|-------|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-08 | (0) | IBMADR[29:06] | IO Base Map Address [31:08]. Bits are read/write capable to provide the ability for device independent software on the system board to relocate the AIC-7850 Device register space on 256 byte IO command boundaries within the low 32-bit address segment of the 64-bit address space. |
| 07-02 | (0) | IBMADR[05:00] | IO Base Map Address [07:02]. Always reads 0.                                                                                                                                                                                                                                            |
| 01    | (0) | RSVD          | Always reads 0.                                                                                                                                                                                                                                                                         |
| 00    | (1) | ISPACEIND     | IO Space Indicator. Always reads 1.                                                                                                                                                                                                                                                     |
|       |     |               | Note: Bit [00] =1 indicates that BASEADR0 register is used for mapping into system IO address space.                                                                                                                                                                                    |

#### Base Address 1 (BASEADR1)

Type: R/W Address: N14h

Base Address register 1, enables the AIC-7850 Device register space to be relocated (mapped) within system Memory Address space to enable the system board device independent POST software to build a consistent system memory address map. The AIC-7850 Device register space, located in Memory Address space, improves throughput of the AIC-7850 Device register transactions. BASEADR1 may be read at any time in Configuration space. BASEADR1 value is reset to 0h during RST# assertion.

**Note:** Software when using BASEADR1 with MSPACEN active to access Device registers must ensure that instructions not allow data moves that bridge 32-bit boundaries to ensure that bytes are not transferred out of intended order. When an access is made to the AIC-7850 when BASEADR1 and EXROMCTL registers contain the same value and EXROMEN is active will result in a Target-Abort response.

|    | BASEADR1<br>R/W |    | BASEADR1<br>R/W |    | BASEADR1<br>R/W |    | BASEADR1<br>R |  |
|----|-----------------|----|-----------------|----|-----------------|----|---------------|--|
| 31 | MBMADR27        | 23 | MBMADR19        | 15 | MBMADR11        | 07 | MBMADR03=0    |  |
| 30 | MBMADR26        | 22 | MBMADR18        | 14 | MBMADR10        | 06 | MBMADR02=0    |  |
| 29 | MBMADR25        | 21 | MBMADR17        | 13 | MBMADR09        | 05 | MBMADR01=0    |  |
| 28 | MBMADR24        | 20 | MBMADR16        | 12 | MBMADR08        | 04 | MBMADR00=0    |  |
| 27 | MBMADR23        | 19 | MBMADR15        | 11 | MBMADR07=0      | 03 | PREFETCH=0    |  |
| 26 | MBMADR22        | 18 | MBMADR14        | 10 | MBMADR06=0      | 02 | MSPACTYP1=0   |  |
| 25 | MBMADR21        | 17 | MBMADR13        | 09 | MBMADR05=0      | 01 | MSPACTYP0=0   |  |
| 24 | MBMADR20        | 16 | MBMADR12        | 08 | MBMADR04=0      | 00 | MSPACEIND=0   |  |

| Bit   |     | Name          | Definition                                                                                                                                                                                                                                                                                                                      |
|-------|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | (0) | MEMADR[27:08] | Memory Base Map Address[27:08]. Bits are read/write capable to indicate a mapping increment capability of 4096 bytes of system memory space with the AIC-7850's 256 byte memory command range rolling over within the selected 4096 byte increment within the low 32-bit address segment of the 64-bit address space.           |
| 11-04 | (0) | MEMADR[07:00] | <b>Memory Base Map Address</b> [07:00]. Indicates address space requirement. Always reads 0.                                                                                                                                                                                                                                    |
| 03    | (0) | PREFETCH      | Prefetchable. Always reads 0. The AIC-7850 does not support this feature.                                                                                                                                                                                                                                                       |
| 02-01 | (0) | MSPACTYP[1:0] | Memory Space Access Type [1:0]. Always reads 0. The AIC-7850 as a target may be located anywhere in the low 32-bit address segment of the 64-bit address space.  MSPACETYPE[1:0]  00 = locate anywhere in 32-bit address space (AIC-7850)  01 = locate below 1 Meg  10 = locate anywhere in 64-bit address space  11 = PCI RSVD |
| 00    | (0) | MSPACEIND     | Memory Space Indicator. Always reads 0.                                                                                                                                                                                                                                                                                         |
|       |     |               | Note: Bit [00] =0 indicates that BASEADR1 register is used for mapping into system Memory Address space.                                                                                                                                                                                                                        |

#### **External ROM Control (EXROMCTL)**

Type: R/W Address: N30h

The External ROM Control Base Address register is used to define the base address, maximum size and access enable control of a local external ROM which may be used with a PCI device. The external ROM's data and address must pass through an additional interface Memory Port of the device and use its normal address/data path to the PCI bus so that no additional loading is presented to the PCI bus other than the device's loading without the external ROM. EXROMCTL may be read at any time in Configuration space. EXROMCTL value is reset to 0h during RST# assertion. The AIC-7850 does not support any external ROM/EEPROM.

| EXROMCTL<br>R/W |             | EXROMCTL<br>R/W |             | EXROMCTL<br>R/W |             | EXROMCTL<br>R/W |           |
|-----------------|-------------|-----------------|-------------|-----------------|-------------|-----------------|-----------|
| 31              | MBAXROM20=0 | 23              | MBAXROM12=0 | 15              | MBAXROM04=0 | 07              | RSVD      |
| 30              | MBAXROM19=0 | 22              | MBAXROM11=0 | 14              | MBAXROM03=0 | 06              | RSVD      |
| 29              | MBAXROM18=0 | 21              | MBAXROM10=0 | 13              | MBAXROM02=0 | 05              | RSVD      |
| 28              | MBAXROM17=0 | 20              | MBAXROM09=0 | 12              | MBAXROM01=0 | 04              | RSVD      |
| 27              | MBAXROM16=0 | 19              | MBAXROM08=0 | 11              | MBAXROM00=0 | 03              | RSVD      |
| 26              | MBAXROM15=0 | 18              | MBAXROM07=0 | 10              | RSVD        | 02              | RSVD      |
| 25              | MBAXROM14=0 | 17              | MBAXROM06=0 | 09              | RSVD        | 01              | RSVD      |
| 24              | MBAXROM13=0 | 16              | MBAXROM05≃0 | 80              | RSVD        | 00              | EXROMEN=0 |

| Bit   |     | Name           | Definition                                               |
|-------|-----|----------------|----------------------------------------------------------|
| 31-11 | (0) | MBAXROM[20:00] | Mapped Base Address External ROM[20:00]. Always reads 0. |
| 10-01 | (0) | RSVD           | Always reads 0.                                          |
| 00    | (0) | EXROMEN        | External ROM Enable. Always reads 0.                     |

## Interrupt Line Select (INTLINSEL)

**Type:** R/W **Address:** N3Ch

The Interrupt Line Select register provides the capability for the system to communicate to the device's software driver the system interrupt line that has been connected to the devices interrupt pin when one has been included in the devices design. When no interrupt pin is provided in the device's design, this register is RSVD and read only with a value of 0h.

| INTLINSEL<br>R/W |        |  |  |  |
|------------------|--------|--|--|--|
| 07               | INTLS7 |  |  |  |
| 06               | INTLS6 |  |  |  |
| 05               | INTLS5 |  |  |  |
| 04               | INTLS4 |  |  |  |
| 03               | INTLS3 |  |  |  |
| 02               | INTLS2 |  |  |  |
| 01               | INTLS1 |  |  |  |
| 00               | INTLS0 |  |  |  |

| Bit |     | Name       | Definition                                                                                                                                                                                                        |                                                                                         |  |
|-----|-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--|
| 7-0 | (0) | INTLS[7:0] | Interrupt Line Select [7:0]. Bits are read-write register bits in which are stored the interrupt line to which the devices interrupt output IRQA[D:A]# has been connected in the system in which it is installed. |                                                                                         |  |
|     |     |            | INTLS[7:0]                                                                                                                                                                                                        | Assignment                                                                              |  |
|     |     |            | 0-15                                                                                                                                                                                                              | Interrupt numbers (referenced to a standard dual 8259 configuration).                   |  |
|     |     |            | 16-254                                                                                                                                                                                                            | RSVD.                                                                                   |  |
|     |     |            | 255                                                                                                                                                                                                               | No connection or unknown. Note: The AIC-7850 driver does not operate with this setting. |  |

#### Interrupt Pin Select (INTPINSEL)

Type: R
Address: N3Ch

The Interrupt Pin register specifies the PCI interrupt pin the device (or device function) uses. A separate Configuration space is required for each function in a device and only one pin may be identified in each space. INTPINSEL register may be read at any time in Configuration space. The AIC-7850 supports PCI Configuration header type 00h (only one function) with IRQA#.

| INTPS[7:0] | <del>.</del>                         |
|------------|--------------------------------------|
| 0          | Device does not use an interrupt pin |
| 1          | Device uses interrupt pin IRQA#      |
| 2          | Device uses interrupt pin IRQB#      |
| 3          | Device uses interrupt pin IRQC#      |
| 4          | Device uses interrupt pin IRQD#      |

| INTPINSEL<br>R |          |  |  |
|----------------|----------|--|--|
| 15             | INTPS7=0 |  |  |
| 14             | INTPS6=0 |  |  |
| 13             | INTPS5=0 |  |  |
| 12             | INTPS4=0 |  |  |
| 11             | INTPS3=0 |  |  |
| 10             | INTPS2=0 |  |  |
| 09             | INTPS1=0 |  |  |
| 08             | INTPS0=1 |  |  |

## Min\_Gnt Status (MINGNT)

Type: R Address: N3Ch

The Minimum Grant register indicates the desired GNT# asserted burst period needed to complete transfer of a devices data buffer assuming that the intended target does not extend the transfer time by use of TRDY#. The value read from the register specifies a period of time in units of 0.25 microsecond. The AIC-7850's MINGNT register value is 4h which is the minimum time to burst out its 128-byte buffer. The AIC-7850 is able to operate with any size GNT# period from one clock to constant park condition. MINGNT register may be read at any time in Configuration space.

| MINGNT<br>R |           |  |
|-------------|-----------|--|
| 23          | MINGNT7=0 |  |
| 22          | MINGNT6=0 |  |
| 21          | MINGNT5=0 |  |
| 20          | MINGNT4=0 |  |
| 19          | MINGNT3=0 |  |
| 18          | MINGNT2=1 |  |
| 17          | MINGNT1=0 |  |
| 16          | MINGNT0=0 |  |

| Bit   |      | Name        | Definition       |  |
|-------|------|-------------|------------------|--|
| 23-16 | (4h) | MINGNT[7:0] | Always reads 4h. |  |

### Max\_Lat Status (MAXLAT)

**Type:** R **Address:** N3Ch

The Maximum Latency register indicates the desired LATTIME register value needed to complete transfer of a devices data buffer assuming that the intended target does not extend the transfer time by use of TRDY#. The value read from the register specifies a period of time in units of 0.25 microsecond. The AIC-7850's MAXLAT register value is 4h which is the minimum time to burst out its 128-byte buffer. *The AIC-7850 is able to operate with any size LATTIME register value*. MAXLAT register may be read at any time in Configuration space.

| MAXLAT<br>R |           |  |
|-------------|-----------|--|
| 31          | MAXLAT7=0 |  |
| 30          | MAXLAT6=0 |  |
| 29          | MAXLAT5=0 |  |
| 28          | MAXLAT4=0 |  |
| 27          | MAXLAT3=0 |  |
| 26          | MAXLAT2=1 |  |
| 25          | MAXLAT1=0 |  |
| 24          | MAXLAT0=0 |  |

| Bit   |      | Name        | Definition       |
|-------|------|-------------|------------------|
| 31-24 | (4h) | MAXLAT[7:0] | Always reads 4h. |

# **Device Configuration (DEVCONFIG)**

Type: R/W Address: N40h

Device Configuration register provides the AIC-7850 with mode selection control of features in the AIC-7850. DEVCONFIG may be read/written at any time in Configuration space. However, changing values in this register must be done with care due to the functional changes they control. DEVCONFIG value is reset to 0h only during RST# assertion.

| DEVCONFIG<br>R/W |           |  |
|------------------|-----------|--|
| 07               | DECONFIG7 |  |
| 06               | MRDCEN    |  |
| 05               | RSVD      |  |
| 04               | RSVD      |  |
| 03               | BERREN    |  |
| 02               | DACEN     |  |
| 01               | STPWLEVEL |  |
| 00               | RSVD      |  |

| 07 (0) DECONFIG Device Configuration. A read/write bit with no current to assignment.  06 (0) MRDCEN Memory Read Command Enable. When active (=1), encommand out generator to generate the MRDC command defined conditions. Enables master burst transfers being or MRDMC commands to release the bus after the current transfers are completed when the LATTIME register has not asserted. When inactive, causes the PCI master conto convert all MRDC commands to MRDLC commands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ables the PCI master and value for its grade with MRDLC ent and next data expired and GNT# is nmand out generator Enables master burst ds, when the      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| command out generator to generate the MRDC command defined conditions. Enables master burst transfers being or MRDMC commands to release the bus after the curre transfers are completed when the LATTIME register has not asserted. When inactive, causes the PCI master completed with the properties of t | nd value for its g made with MRDLC ent and next data expired and GNT# is nmand out generator Enables master burst ds, when the                           |
| transfers being made with MRDLC or MRDMC command LATTIME register has expired and GNT# is not asserted after completing the current cache line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | i, to release the bus                                                                                                                                    |
| 05 (0) RSVD Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                          |
| 04 (0) RSVD Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                          |
| 03 (0) BERREN Byte Parity Error Enable. When active (=1), forces the generators to create even-parity for the associated data BERREN is inactive normal odd-parity is generated. BEI capability to test this logic and the parity checking logic it to data FIFO, data FIFO and SCSI to data FIFO less the parity generator)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | byte and when RREN provides the n the data path (PCI                                                                                                     |
| Note: Data bytes being written to the data FIFO have od to them when they are from the PCI bus with the A from Device register DFDAT access (sequencer of target) or from SCSI reads. Bytes written to scratch QOUTFIFO or SCB RAM also have odd-parity bits. When reading bytes from the data FIFO, scratch FIFO and the SCB RAM the odd-parity is the be flagged when an improper value is accessed. A RAM byte locations that are to be used must be with parity bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | IC-7850 as a master,<br>r the AIC-7850 as a<br>h RAM, QINFIFO,<br>s attached to them.<br>RAM, QINFIFO,<br>isted and a error will<br>lifter power-up, all |
| 02 (0) DACEN  Dual Address Cycle Enable. When active, enables the Dual Address Cycle (DAC) master transactions of 32-bit page of a 64-bit range pointed to by the value stored in tisters. When HHADDR[3:0] stored value is zero, only Si (SAC) may be issued the same as when DACEN is not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | range within a 32-bit<br>he HHADDR[3:0] reg-<br>ngle Address Cycles                                                                                      |
| 01 (0) STPWLEVEL SCSI Termination Power Level. When inactive (=0), so for the active state of the STPWCTL output. When active level for the active state of output STPWCTL. STPWLEV inactive state by RST# assertion. Writing to the CHIPRS HCNTRL register has no effect on STPWLEVEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | e, selects the low<br>VEL is cleared to the                                                                                                              |
| 00 (0) RSVD Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                          |

# **Device Status (DEVSTATUS)**

Type: R Address: N40h

Device Status register provides read capability for selected internal conditions in the AIC-7850. DEVSTATUS may be read at any time in Configuration space.

| DEVSTATUS<br>R |          |  |
|----------------|----------|--|
| 15             |          |  |
| 14             |          |  |
| 13             |          |  |
| 12             |          |  |
| 11             |          |  |
| 10             | RSVD     |  |
| 09             | RSVD     |  |
| 08             | VOLSENSE |  |

| Bit  |     | Name     | Definition                                                                                                                                                                                                                                                                                               |
|------|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-9 | (0) | Not Used | Always reads 0.                                                                                                                                                                                                                                                                                          |
| 08   | (*) | VOLSENSE | Voltage Sense. Provides the capability to determine which PCI bus voltage level ((=0) for 3.3V and (=1) for 5V) that the AIC-7850's PCI interface has been connected to. The state of VOLSENSE adjusts the operation of the AIC-7850's PCI interface pin cells to account for the difference in voltage. |
|      |     |          | Note: (*) The reset state is determined by the external voltage present.                                                                                                                                                                                                                                 |

# PCI Error Generation (PCIERRGEN)

Type: R/W Address: N40h

This register provides the capability to generate PCI errors for testing conditions with diagnostic support.

| PCIERRGEN<br>R/W |              |  |
|------------------|--------------|--|
| 31               | PCIERRGENDIS |  |
| 30               | RSVD         |  |
| 29               | RSVD         |  |
| 28               | MADRSPARERR  |  |
| 27               | MWDATPARERR  |  |
| 26               | TRDATAPARERR |  |
| 25               | MTDATAPARERR |  |
| 24               | TADRSPARERR  |  |

| Bit | Name         | Definition                                                                                                                                                                                                                                                       |  |
|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31  | PCIERRGENDIS | When active (=1) prevents other active bits int his register from generating an error. When active, allows reading the active state of the other bits for test. Should an FFh value be accidentally written to this register, will disable all error generation. |  |
| 30  | RSVD         |                                                                                                                                                                                                                                                                  |  |
| 29  | RSVD         |                                                                                                                                                                                                                                                                  |  |
| 28  | MADRSPARERR  | When this bit is active (=1) and PCIERRGENDIS is not active, will cause a parity error on the next master address phase. Then, will automatically reset.                                                                                                         |  |
| 27  | MWDATPARERR  | When this bit is active (=1) and PCIERRGENDIS is not active, will cause a parity error on the next master write data phase that transfers data. Then, will automatically reset.                                                                                  |  |
| 26  | TRDATAPARERR | When this bit is active (=1) and PCIERRGENDIS is not active, will cause a parity error on the next target read data phase that transfers data. Then, will automatically reset.                                                                                   |  |
| 25  | MTDATAPARERR | When this bit is active (=1) and PCIERRGENDIS is not active, will cause a parity error on the next master read data phase or target write data phase. Then, will automatically reset.                                                                            |  |
| 24  | TADRSPARERR  | When this bit is active (=1) and PCIERRGENDIS is not active, will cause a parity error on the next target address phase. Then, will automatically reset.                                                                                                         |  |

# **Host Device Space Register Definition**

Registers in the host Device register space may be written and/or read through the AIC-7850 PCI bus interface, or through the host internal interface by the sequencer with time bases that may be asynchronous. For registers that are written by one source and read by another, the host register read data is latched at the beginning of the read to provide stable data for those reads. Users of direct register outputs need to consider their asynchronous nature. Also some registers in normal operation function as counters and data memories that may be constantly changing their contents. Reading from these registers should be restricted to certain operational states where their activity will be idle. Writing to some of these registers is restricted when HDMAENACK is active. Also some registers when written may have to be read multiple times to verify the desired action has occurred.

Register addresses shown for host Device registers refer to internal chip address values which have extended external address prefix values which must be mapped to the desired value in the system address map via BASEADR0 or BASEADR1 registers in the Configuration register space. Writing to CHIPRST bit (=1) affects only registers in the AIC-7850 Device register space, while assertion of RST# affects both Configuration and Device registers.

Defined Device register unused bits read as 0h. Undefined Device register addresses when read, will return the last value asserted on the CSDAT[7:0] bus except for device address 8Fh which will return 0h. Data written to the AIC-7850 Device register unused Device register bits and unassigned Device register addresses are not stored. The following conventions are used throughout this section:

- set or active: Indicates that the bit was loaded with or is a 1
- cleared or inactive: Indicates that the bit was loaded with or is a 0
- (0): Indicates that the bit is cleared when the reset POR is active
- (1): Indicates that the bit is set when the reset POR is active
- (x): Indicates that the bit is in an unknown state both during and after the reset POR condition
- Mxxh: Indicates PCI address decode with address prefix stored in either BASEADR0 or BASEADR1 registers in the Configuration space
- DS-xxh: Indicates Device space internal address decode. It represents Mxxh without the M prefix and is the value used by the internal sequencer block

Note: Only the AIC-7850 Device registers (DSVENDID[1:0], DSDEVID[1:0], HCNTRL, INTSTAT, CLRINT, QOUTFIFO(R), QOUTCNT(R) and ERROR) may be accessed from the PCI bus without regard for the state of PAUSEACK when ISPACEEN or MSPACEEN is active in the Configuration Command register. These Device registers are never accessible by the internal sequencer. Device registers that are used by the sequencer, when it is not paused may be accessed from the PCI bus when PAUSACK is not active with a delay in the access while automatic access PAUSE (AAP) action causes PAUSEACK to become active. No access delay will occur for accesses performed after the PAUSE bit in the Device HCNTRL register is first set and polled until PAUSEACK is active 2. When both ISPACEEN and MSPACEEN are inactive in the Configuration Command register, none of the AIC-7850 Device registers are accessible from the PCI bus.

## DSVendor Identification (DSVENDID[1:0])

Type: I

Address: M80h/81h Dual access DS-80h/81h

The PCI vendor identifier registers contain product information for use by the host system software when initializing and configuring the system. The Vendor ID contains two bytes of a compressed representation of the vendor code. The vendor characters for the AIC-7850, represented by the value 9004h, are

- the first ID character = A
- the second ID character = D
- the third ID character = P

DSVENDOR ID[1:0] may be read without consideration of the state of the PAUSE bit in the AIC-7850 Device register space, only when the ISPACEEN bit or the MSPACEEN bit is set in the Configuration Command register. For bit assignments see the VENDORID register in the Configuration register space.

| DSVENDID1<br>R 81h |           | DSVENDIDO<br>R 80h |           |
|--------------------|-----------|--------------------|-----------|
| 7                  | DSVID15=1 | 7                  | DSVID07=0 |
| 6                  | DSVID14=0 | 6                  | DSVID06=0 |
| 5                  | DSVID13=0 | 5                  | DSVID05=0 |
| 4                  | DSVID12=1 | 4                  | DSVID04=0 |
| 3                  | DSVID11=0 | 3                  | DSVID03=0 |
| 2                  | DSVID10=0 | 2                  | DSVID02=1 |
| 1                  | DSVID09=0 | 1                  | DSVID01=0 |
| 0                  | DSVID08=0 | 0                  | DSVID00=0 |

# DSDevice Identification (DSDEVID[1:0])

Type: F

Address: M82h/83h Dual access DS-82h/83h

The two Device ID bytes contain a product code 7850, in big-endian format. DSDEVICEID[1:0] may be accessed at any time without consideration of the state of PAUSEACK in the AIC-7850 Device register space only when the ISPACEEN bit or the MSPACEEN bit is active in the Configuration Command register. For bit assignments, see the DEVICEID register in the Configuration register space.

| DSDEVID1<br>R- |                |   | DSVEDIDO<br>R- |
|----------------|----------------|---|----------------|
| 7              | DSDID15=0      | 7 | DSDID07=0 \    |
| 6              | DSDID14=1      | 6 | DSDID06=1 IMS  |
| 5              | DSDID13=0      | 5 | DSDID05=1      |
| 4              | DSDID12=1      | 4 | DSDID04=1 /    |
| 3              | DSDID11=0 \    | 3 | DSDID03=1      |
| 2              | DSDID10=0 I LS | 2 | DSDID02=0      |
| 1              | DSDID09=0      | 1 | DSDID01=0      |
| 0              | DSDID08=0 /    | 0 | DSDID00=0      |

# **DSCommand (DSCOMMAND)**

Type: R/W

Address: M84h D-84h Dual access for read only bits [5:0]

The DSCOMMAND register access of bits [3:0] are read only for PCI command enable selections. This allows monitoring the Configuration COMMAND[1:0] registers stored values from the AIC-7850 Device register space without requesting access to the Configuration address space. Bits [7:4] are read/write and assigned to new functions in the AIC-7850.

The DSCOMMAND register may be accessed by the sequencer when not paused and by the software driver by using AAP access or setting PAUSE bit active, only when the ISPACEEN bit or the MSPACEEN bit is set in the Configuration Command register. See *Configuration Register Space* section for register bit [3:0] usage. Writing to register bits [3:0] in the Device space will have no effect, only writing to the Configuration space or assertion of RST# will effect these bits. Bits [7:4] may be changed by writing to the Device space DSCOMMAND register, CHIPRST bit or the assertion of RST#.

| DSCOMMAND<br>R/W |             |  |  |  |  |  |
|------------------|-------------|--|--|--|--|--|
| 7                | CACHETHEN   |  |  |  |  |  |
| 6                | DPARCKEN    |  |  |  |  |  |
| 5 MPARCKEN       |             |  |  |  |  |  |
| 4 RSVD           |             |  |  |  |  |  |
| 3                | DSSERRESPEN |  |  |  |  |  |
| 2                | DSPERRESPEN |  |  |  |  |  |
| 1                | DSMWRICEN   |  |  |  |  |  |
| 0                | DSMASTEREN  |  |  |  |  |  |

| Bit |     | Name      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | CACHETHEN | Cache Threshold Enable. When active (=1), will cause the PCI master to utilize signal DFCACHETH instead of DFTHRSH to determine when to request use of the PCI bus. Selecting the appropriate LATTIME and CACHESIZE register values when CACHETHEN is active will cause data transfers when the AIC-7850 is a master to match the selected cache size (deterministic transfer) using cache line referenced PCI commands. This use presumes that software has located buffers on cache line boundaries or a small transfer will be performed to reach the first cache line boundary. The final transfer indicated by FIFOFLUSH active, for system memory write direction, will be flushed even if not a full cache size. |
| 6   | (0) | DPARCKEN  | Data Parity Check Enable. When inactive (=0), disables the AIC-7850 byte parity checking being performed as follows on internal data path byte accesses. For PIO read operations from the SCSI bus, the SCSI bus parity check control is controlled by the Device SIMODE1 register and is independent of DPARCKEN.                                                                                                                                                                                                                                                                                                                                                                                                      |

### (Continued)

| Bit |     | Name      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |           | 1 Odd byte parity generated internally in the AIC-7850 block at the PCI bus interface, passed through the data FIFO and SCSI FIFO then checked internally in the SCSI block at the SCSI bus interface, then sent to the SCSI bus, and again checked by the SCSI device connected on the SCSI bus. Data with detected internal parity errors will PAUSE the sequencer and generate an interrupt if enabled.                                                                                                                                               |
|     |     |           | 2 Odd byte parity generated by the active SCSI device connected to the<br>SCSI bus, checked in the SCSI block internally at the SCSI bus interface,<br>passed through the SCSI FIFO and the data FIFO, then checked in the<br>AIC-7850 block internally at the PCI bus interface. Data with detected<br>internal parity errors will PAUSE the sequencer and generate an interrupt<br>if enabled.                                                                                                                                                         |
|     |     |           | 3 Odd byte parity generated internally in the AIC-7850 block at the PCI bus interface, passed through the data FIFO, then checked internally in the data FIFO block at the CIOBUS-CSDAT interface for sequencer or software driver read accesses. These errors will cause the sequencer to be paused.                                                                                                                                                                                                                                                    |
|     |     |           | 4 Odd byte parity generated by the active SCSI device connected to the<br>SCSI bus, checked in the SCSI block internally at the SCSI bus interface,<br>passed through the SCSI FIFO and the data FIFO then checked internally<br>in the data FIFO block at the CIOBUS-CSDAT interface for sequencer or<br>software driver read accesses. These errors will cause the sequencer to<br>be paused.                                                                                                                                                          |
|     |     |           | 5 Odd byte parity generated in the data FIFO block at the CIOBUS-CDDAT interface for sequencer or software driver write accesses, passed through the data FIFO, then checked as in 1 - 4 above.                                                                                                                                                                                                                                                                                                                                                          |
|     |     |           | When DPARCKEN is active, byte parity checking is performed and parity errors will cause DPARERR to be active in the ERROR register, BRKADRINT to be active in the INTSTAT register and (if INTEN is active and POWRDN is inactive) in the HCNTRL register the IRQA# output will become active. Internal byte parity is always generated.                                                                                                                                                                                                                 |
| 5   | (0) | MPARCKEN  | Memory Parity Check Enable. When inactive (=0), disables the AIC-7850 parity checking on scratch RAM, QINFIFO, QOUTFIFO and SCB Array (internal, or external when EXSCBPEN is active) byte read accesses. When MPARCKEN is active, byte odd-parity checking is performed and parity errors will cause MPARERR to be active in the ERROR register, BRKADRINT to be active in the INTSTAT register and (if INTEN is active and POWRDN is inactive) in the HCNTRL register the IRQA# output will become active. Memory byte odd-parity is always generated. |
| 4   | (0) | EXTREQLCK | <b>External Request Lock.</b> Always reads 0. A read/write bit with no current logic control assignment.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3-0 | (0) |           | These bits are read only. See Configuration COMMAND[1:0] registers for use of these bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

# **DSLatency Timer (DSLATTIME)**

Type: I

Address: M85H, dual access DS-85h

The DSLATTIME register provides two functions:

- The ability to monitor the Configuration LATTIME[7:2] register stored values from the AIC-7850 Device register space without requesting access to the Configuration address space. See Configuration register space section for register bit usage.
- The ability to select host address Device register pages. Writing to DSLATTIME register will only affect HADDLDSEL[1:0] bits.

|           | DSLATTIME<br>R |  |  |  |  |  |  |
|-----------|----------------|--|--|--|--|--|--|
| 7         | DSLATT7        |  |  |  |  |  |  |
| 6         | DSLATT6        |  |  |  |  |  |  |
| 5         | DSLATT5        |  |  |  |  |  |  |
| 4 DSLATT4 |                |  |  |  |  |  |  |
| 3         | DSLATT3        |  |  |  |  |  |  |
| 2         | DSLATT2        |  |  |  |  |  |  |
| 1         | HADDLDSEL1     |  |  |  |  |  |  |
| 0         | HADDLDSEL0     |  |  |  |  |  |  |

| Bit |     | Name           | Definitio                                                                                                                                  | n                                                                                                                                  |  |  |  |
|-----|-----|----------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7-2 | (0) | DSLATT[7:2]    | <b>Device Space Latency Timer.</b> (R). See Configuration register space section for register bit usage. LATT[1:0] are always 0.           |                                                                                                                                    |  |  |  |
| 1-0 | (0) | HADDLDSEL[1:0] | <b>Host Address Load Select [1:0].</b> (R/W). Enable page expansion of the Host Address register addresses M/DS-88h - M/DS-8Bh as follows: |                                                                                                                                    |  |  |  |
|     |     | -              | [1:0]                                                                                                                                      | Bit Value Assignment                                                                                                               |  |  |  |
|     |     | -              | 0                                                                                                                                          | Enables the low four bytes of a 64-bit address to be loaded into LHADDR[3:0] and SHADDR[3:0] registers.                            |  |  |  |
|     |     |                | 1                                                                                                                                          | Enables the high four bytes of a 64-bit address (or alternately a general purpose storage register) to be loaded into HHADDR[3:0]. |  |  |  |
|     |     |                | 3, 2                                                                                                                                       | Values are reserved. Note reading M88h - M8Bh with these values will access the last data value asserted on the CSDAT[7:0] bus.    |  |  |  |

## **DSPCI Status (DSPCISTATUS)**

Type: R/W

Address: M86h, dual access DS-86h

The DS PCI STATUS register provides two functions:

- The ability to select the data FIFO data threshold level that will initiate a bus master cycle.
- The ability to monitor PCI exception status bits in the Configuration STATUS register. DFTHRSH[1:0] are R/W and are forced to the default value of 0 when POR is active. Writing to this register will have no effect for bits [5:0].

|   | PCISTATUS<br>R/W-R |  |  |  |  |  |  |
|---|--------------------|--|--|--|--|--|--|
| 7 | DFTHRSH1           |  |  |  |  |  |  |
| 6 | DFTHRSH0           |  |  |  |  |  |  |
| 5 | DSDPR              |  |  |  |  |  |  |
| 4 | DSDPE              |  |  |  |  |  |  |
| 3 | DSSSE              |  |  |  |  |  |  |
| 2 | DSRMA              |  |  |  |  |  |  |
| 1 | DSRTA              |  |  |  |  |  |  |
| 0 | DSSTA              |  |  |  |  |  |  |

| Bit |     | Name         | Definition                                                |                                                       |                                            |                                                                                                                           |                                           |  |
|-----|-----|--------------|-----------------------------------------------------------|-------------------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|
| 7-6 | (0) | DFTHRSH[1:0] | bits determin                                             | nes at what qual                                      | ntity of 64-bit d                          | value stored in the DF<br>lata words stored in the<br>the DFSTATUS regist                                                 | ne data FIFO                              |  |
|     |     |              |                                                           | Transfer Data FIFO to System                          |                                            |                                                                                                                           | FIFO                                      |  |
|     |     |              | DFTHRSH<br>[1:0]                                          | Start                                                 | Stop <sup>1</sup>                          | Start <sup>2</sup>                                                                                                        | Stop <sup>3</sup>                         |  |
|     |     |              | 00                                                        | 16 Bytes <sup>4</sup>                                 | Empty                                      | Full-24 Bytes <sup>4</sup>                                                                                                | Full                                      |  |
|     |     |              | 01                                                        | 50% Full <sup>4</sup>                                 | Empty                                      | 50% Empty <sup>4</sup>                                                                                                    | Full                                      |  |
|     |     |              | 10                                                        | 75% Full <sup>4</sup>                                 | Empty                                      | 75% Empty <sup>4</sup>                                                                                                    | Full                                      |  |
|     |     |              | 11                                                        | 100% Full <sup>4</sup>                                | Empty                                      | 100% Empty <sup>4</sup>                                                                                                   | Full                                      |  |
|     |     |              | 64-bit Quad-<br>levels of (2,<br>stored QWD               | -Words (QWD):<br>8 12 and 16) for<br>levels of (12, 8 | Status DFTHR data FIFO to , 4 and 0) for s | a 64-bit data FIFO cor<br>SH will be active at s<br>system memory trans<br>system memory to dat<br>mple) is active only w | tored QWD<br>fers and at<br>a FIFO trans- |  |
| 5-0 | (0) |              | Also see De<br>The leading<br>cause IRQA<br>by writing Cl |                                                       |                                            |                                                                                                                           |                                           |  |

<sup>&</sup>lt;sup>1</sup> Status FIFOEMP or HCNT[2:0] value =0h, control HDMAEN inactive or bus-on time expired.

<sup>&</sup>lt;sup>2</sup> Initial start is when HDMAEN becomes active and EMPTY is active.

 $<sup>^3</sup>$  Status FIFOFULL, DFSDH or HCNT[2:0] value =0h, control HDMAEN inactive or bus-on time expired.

<sup>&</sup>lt;sup>4</sup> Status DFTHRSH active.

### **Host Control (HCNTRL)**

Type:

R/W

Address: M87H, DS-87h

The HCNTRL register provides the capability for the software driver to gain latched PAUSE access to registers located on the CIOBUS and normally used by the sequencer. HCNTRL also provides control features that only the software driver may access. HCNTRL may be written to at any time without consideration of the state of the PAUSEACK bit. The HCNTRL register is cleared to 05 when RST# is asserted or CHIPRST is written to (=1).

Writes to HCNTRL that change the state of PAUSE bit followed by a read of HCNTRL will extend the read access until the read value matches the written value (HCNTRL register for this condition is included in the AAP logic timing cycle).

Writes to HCNTRL will cause all active SLP[1:0] bits in the SLEEPCTL register to become inactive.

| HCNTRL<br>R/W |              |  |  |  |  |  |
|---------------|--------------|--|--|--|--|--|
| 7             |              |  |  |  |  |  |
| 6             | POWRDN       |  |  |  |  |  |
| 5             |              |  |  |  |  |  |
| 4             | SWINT        |  |  |  |  |  |
| 3             | HCNTRL3      |  |  |  |  |  |
| 2             | PAUSE[ACK]   |  |  |  |  |  |
| 1             | INTEN        |  |  |  |  |  |
| 0             | CHIPRST[ACK] |  |  |  |  |  |

| Bit |     | Name         | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6   | (0) | POWRDN       | Power Down. When active (=1), delegates the use of clock input CLKIN and selected PCLK input tree elements. Disables the SCSI bus inputs from external input levels. POWRDN also disables IRQA# from being asserted and limits Device register access to PCI Host only registers. Prior to placing POWRDN in the active state, software must ensure that SCSIENACK, SDMAENACK and HDMAENACK are in the inactive state and PAUSEACK is in the active state from a latched PAUSE condition to prevent errors from being transferred to the SCSI bus, System board, or System memory. Additionally a hardware interlock prevents writing a 0 to the PAUSE bit while writing a 1 to the POWRDN bit.                                                                                                                         |
| 5   | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4   | (0) | SWINT        | Software Interrupt. When active (=1) will cause the selected IRQA# to be active independent of other interrupt conditions, providing INTEN, MASTEREN and (MSPACEEN and/or ISPACEEN) are active and POWRDN is inactive. SWINT when active does not cause any changes to the INTSTAT register and its state must be monitored by reading the HCNTRL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3   | (0) | HCNTRL3      | A spare R/W capable bit with no current hardware control assignment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2   | (1) | PAUSE[ACK]   | Pause (located in the write portion of the PAUSE[ACK] bit). When active, requests the sequencer to be paused in an latched condition. When this bit is read, it gives the pause acknowledge status and should be polled to be sure that the sequencer is paused. The driver may start at the address that was paused or at this time change the sequencer program counter (SEQADDR). Clearing this bit will release the sequencer and it will continue at the current value of the program counter. When PAUSEACK is active, access is enabled for the host to Device registers normally restricted when it is not (also see POWRDN bit). This bit also becomes active due to certain hardware conditions, RST# assertion, or writing to CHIPRST. For other conditions, see INTSTAT register and the sequencer section. |
|     |     |              | Note: Software accesses attempted to Device registers normally used by the sequencer will cause an Automatic Access PAUSE (AAP) of the sequencer which is not latched, with the sequencer continuing its operation automatically after the access is completed. The duration of the AAP is affected by the asynchronous relationship of the software driver access to the internal sequencer cycle, and whether it is to a Device register. For internal Device register access when multiple accesses are required latched PAUSE may be faster.                                                                                                                                                                                                                                                                        |
| 1   | (0) | INTEN        | Interrupt Enable. The interrupt enable bit when active will allow active interrupt conditions stored in the AIC-7850 to assert the IRQA# pin, providing that the MASTEREN bit in the Configuration Command register is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0   | (1) | CHIPRST[ACK] | Chip Reset (located in the write portion of the CHIPRST[ACK]) This bit when written (=1) will produce the same condition as when RST# is asserted to cause the device (except for the Configuration register space) to enter an initialized state. Following a write to CHIPRST or the desertion of RST#, POR (the internal device reset condition) will remain active for 2-3 CLKIN periods before becoming inactive.                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |     | CHIPRSTACK   | Chip Reset Acknowledge (located in the read portion of the CHIPRST[ACK] bit). This status bit when active (=1) indicates a write to CHIPRST has occurred or that RST# has been asserted. CHIPRSTACK will remain active until explicitly writing to CHIPRST (=0) (provided that POR has clocked off).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### Low Host Address (LHADDR[3:0])

Type: R/W

**Address**: (HADDLDSEL[1:0] = 0) and M88/89/8A/8Bh, DS-88/89/8A/8Bh

LHADDR[3:0]. The Low Host Address registers contain the low 32-bits of system memory address of the data that will transfer to or from the data FIFO as an active bus master. They perform as count up counters and count up by one for each byte transferred between the device and system memory. LHADDR[3:0] values are issued on the AD[31:00] lines during the PCLK cycle that FRAME# is asserted on for either SAC or DAC transactions. LHADDR[3:0] initialize to zero by CHIPRST or RST#.

Note, after LHADDR[3:0] and HCNT[2:0] have been loaded with the desired values, HDMAEN is placed in the active state allowing transfers to commence. Then, at a later time, should HDMAEN be placed in the inactive state prior to HCNT[2:0] reaching a count of zero, it is disallowed to reload LHADDR[3:0] with new values, placing HDMAEN back in the active state for the same disrupted transfer, unless the data FIFO is reinitialized.

| LHADDR0<br>R/W |          | LHADDR1<br>R/W |          | LHADDR2<br>R/W |          | LHADDR3<br>R/W |          |
|----------------|----------|----------------|----------|----------------|----------|----------------|----------|
| 7              | LHADDR07 | 7              | LHADDR15 | 7              | LHADDR23 | 7              | LHADDR31 |
| 6              | LHADDR06 | 6              | LHADDR14 | 6              | LHADDR22 | 6              | LHADDR30 |
| 5              | LHADDR05 | 5              | LHADDR13 | 5              | LHADDR21 | 5              | LHADDR29 |
| 4              | LHADDR04 | 4              | LHADDR12 | 4              | LHADDR20 | 4              | LHADDR28 |
| 3              | LHADDR03 | 3              | LHADDR11 | 3              | LHADDR19 | 3              | LHADDR27 |
| 2              | LHADDR02 | 2              | LHADDR10 | 2              | LHADDR18 | 2              | LHADDR26 |
| 1              | LHADDR01 | 1              | LHADDR09 | 1              | LHADDR17 | 1              | LHADDR25 |
| 0              | LHADDR00 | 0              | LHADDR08 | 0              | LHADDR16 | 0              | LHADDR24 |

# **High Host Address (HHADDR[3:0])**

Type: R/W

Address: (HADDLDSEL[1:0] = 1) and M88/89/8A/8Bh, DS-88/89/8A/8Bh

HHADDR[3:0]. The High Host Address registers contain the high 32-bits of a system memory 64-bit address of the data that will transfer to or from the data FIFO as an active bus master. They perform only as 32-bit page registers.

When HHADDR[3:0] contain only the value of zero, the AIC-7850 as a PCI master will only issue SACs. When HHADDR[3:0] contain some value other than zero and DACEN is active in the Configuration DEVCONFIG register, the AIC-7850 as a PCI master will issue DACs using the HHADDR[3:0] values in the PCLK cycle following the PCLK cycle that asserted FRAME#. The AIC-7850 as a target does not support DACs. HHADDR[3:0] initialize to zero by CHIPRST or RST#. When DACEN is not active HHADDR[3:0] registers may be used for general-purpose storage if desired.

| HHADDRO<br>R/W |          | HHADDR1<br>R/W |          |   | HHADDR2<br>R/W |   | HHADDR3<br>R/W |  |
|----------------|----------|----------------|----------|---|----------------|---|----------------|--|
| 7              | HHADDR07 | 7              | HHADDR15 | 7 | HHADDR23       | 7 | HHADDR31       |  |
| 6              | HHADDR06 | 6              | HHADDR14 | 6 | HHADDR22       | 6 | HHADDR30       |  |
| 5              | HHADDR05 | 5              | HHADDR13 | 5 | HHADDR21       | 5 | HHADDR29       |  |
| 4              | HHADDR04 | 4              | HHADDR12 | 4 | HHADDR20       | 4 | HHADDR28       |  |
| 3              | HHADDR03 | 3              | HHADDR11 | 3 | HHADDR19       | 3 | HHADDR27       |  |
| 2              | HHADDR02 | 2              | HHADDR10 | 2 | HHADDR18       | 2 | HHADDR26       |  |
| 1              | HHADDR01 | 1              | HHADDR09 | 1 | HHADDR17       | 1 | HHADDR25       |  |
| 0              | HHADDR00 | 0              | HHADDR08 | 0 | HHADDR16       | 0 | HHADDR24       |  |

# **Host Count (HCNT(n))**

Type: R/W

Address: M8C/8D/8E/8Fh, DS-8C/8D/8E/8Fh

HCNT[2:0]. The Host Count registers contain a count of the number of bytes to be transferred between system memory and the data FIFO when the AIC-7850 is an active bus master. HCNT[2:0] perform as count down counters and count down by one for each byte transferred between system memory and data FIFO. Transfers are inhibited when the count value of HCNT[2:0] is zero.

**Note:** Address M/DS-8Fh is reserved for future expansion. Always reads as 0h and writes are ignored.

|   | HCNT0<br>R/W |   |        |   | HCNT2<br>R/W |   | W W  |
|---|--------------|---|--------|---|--------------|---|------|
| 7 | HCNT07       | 7 | HCNT15 | 7 | HCNT23       | 7 | RSVD |
| 6 | HCNT06       | 6 | HCNT14 | 6 | HCNT22       | 6 | RSVD |
| 5 | HCNT05       | 5 | HCNT13 | 5 | HCNT21       | 5 | RSVD |
| 4 | HCNT04       | 4 | HCNT12 | 4 | HCNT20       | 4 | RSVD |
| 3 | HCNT03       | 3 | HCNT11 | 3 | HCNT19       | 3 | RSVD |
| 2 | HCNT02       | 2 | HCNT10 | 2 | HCNT18       | 2 | RSVD |
| 1 | HCNT01       | 1 | HCNT09 | 1 | HCNT17       | 1 | RSVD |
| 0 | HCNT00       | 0 | HCNT08 | 0 | HCNT16       | 0 | RSVD |

### Interrupt Status (INTSTAT)

Type: R/W

Address: M91hDS-91h

INTSTAT register provides device interrupt status for the driver when an interrupt condition occurs. The INTSTAT register is written to by the sequencer, and may be read from the PCI bus without pausing the sequencer. The sequencer is automatically paused when the SEQINT, SCSIINT or BRKADRINT bit(s) are active. The INTCODE is only valid when SEQINT bit is active. Bits [3:0] may also be individually reset by use of the CLRINT register.

When IRQA# is asserted, the software driver must check both the INTSTAT register values and the PCIERRSTAT bit in the ERROR register to determine the cause(s) of the interrupt. Status bits (DPE, DPR) become active as a result of a PCI master or target transaction and cause an interrupt, provided that PERRESPEN is active and FAILDIS is inactive. Status bits (STA, RTA, RMA, SSI) become active as a result of a PCI master or target transaction and cause an interrupt, provided that FAILDIS is inactive.

| INSTAT<br>R/W |           |  |
|---------------|-----------|--|
| 7             | INTCODE3  |  |
| 6             | INTCODE2  |  |
| 5             | INTCODE1  |  |
| 4             | INTCODE0  |  |
| 3             | BRKADRINT |  |
| 2             | SCSIINT   |  |
| 1             | CMDCMPLT  |  |
| 0             | SEQINT    |  |

| Bit |       | Name         | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4 | (0)   | INTCODE(3:0) | Interrupt Code. These bits enable a code to be stored to identify the condition causing the SEQINT bit to be active. By convention the INTCODE[3:0] bits are only considered valid when the SEQINT bit is active and should be written in the same write operation that activates SEQINT. See the discussion on interrupts for a definition of this code.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3   | 3 (0) | BRKADRINT    | Break Address Interrupt. This bit becomes active (=1) when using the sequencer firmware breakpoint feature (see registers BRKADDR[1:0] in the sequencer section). Note when the current sequencer instruction breakpoint is an access to an SCB Array address with RAMPSM active (external SRAM). In this case, the sequencer instruction may be stretched while arbitration is being performed for the external SRAM, and a PAUSE request due to an active BRKADRINT will be delayed until arbitration is completed. BRKADRINT is also used for selected error conditions as follows:                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |       |              | 1 When the program counter of the sequencer and the break address are<br>equal and the Breakpoint feature is enabled (BRKDIS=0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |       |              | When ILLOPCODE becomes active (FAILDIS=0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |       |              | 3 When SQPARERR becomes active (FAILDIS and PERRORDIS=0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |       |              | 4 When DPARERR becomes active (DPARCKEN=1 and FAILDIS=0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |       |              | 5 When MPARERR becomes active (MPARCKEN=1 and FAILDIS=0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |       |              | While the BRKADRINT bit is active it forces the PAUSE bit in HCNTRL register to be active and IRQA# to be asserted when INTEN and MASTEREN are active and POWRDN is inactive. When BRKADRINT is active due to source 1, it may be set inactive by a write to the CLRINT register with CLRBRKADRINT bit 3 (=1). When BRKADRINT is active due to source 2, it may be set inactive by a write to CHIPRST (=1) in the HCNTRL register. When BRKADRINT is active due to source 3-5, it may be set inactive by a write to CLRPARERR (=1) in the CLRINT register. This action will also clear any PCIERRSTAT latched interrupt conditions that may exist, but will not clear the Configuration STATUS1 register bits.                                                                                                                                                                                                                                                                           |
| 2   | (0)   | SCSIINT      | SCSI Interrupt. This bit is latched in the INTSTAT register and is active when there is a catastrophic SCSI event. Causes are SCSI Reset, Parity Error, Selection Time-out, or Unexpected Bus Free. Any interrupt condition in the SCSI section may cause this interrupt if the corresponding interrupt is enabled in SIMODE0 or SIMODE1. When this bit is set, the sequencer is paused immediately. Except when the current sequencer instruction is a access to an SCB Array address with RAMPSM active (external SRAM). In this case the sequencer instruction may be stretched while arbitration is being performed for the external SRAM, and a PAUSE request due to an active SCSIINT will be delayed until arbitration is completed. IRQA# is also asserted when INTEN and MASTEREN are active and POWRDN is inactive. The cause of SCSIINT being active must be cleared, then a write to CLRSCSIINT =1 in the CLRINT register to cause SCSIINT to be read in the inactive state. |
| 1   | (0)   | CMDCMPLT     | Command Complete Interrupt. This bit is set active by the sequencer writing to the INTSTAT register with CMDCMPLT (=1) during normal operation after a SCSI command has been completed and the SCB pointer has been loaded on the QOUTFIFO. The sequencer will continue running while this bit is active. While the CMDCMPLT bit is active IRQA# is asserted when INTEN and MASTEREN is active. CMDCMPLT is inactive after a write to the CLRINT register with CLRCMDINT bit (=1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| (Continued | ) |
|------------|---|
|------------|---|

| Bit |     | Name   | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | (0) | SEQINT | Sequencer Interrupt. This bit is set active by the sequencer writing to the INTSTAT register with SEQINT (=1) when the sequencer requires driver intervention to complete a command or to handle an exception condition. The sequencer is paused by this interrupt immediately (no instruction is performed following the write to set this bit). While SEQINT is active IRQA# is also asserted when INTEN and MASTEREN is active and POWRDN is inactive. SEQINT is inactive after a write to the CLRINT register with CLRSEQINT bit (=1). |

# Clear Interrupt (CLRINT)

Type: W

Address: M92h, DS-92h

The CLRINT register allows the driver to clear the cause of the interrupt from the device. Selected interrupts are cleared by writing with the desired bit pattern =1. The bits in this register are self-clearing. The sequencer cannot write to this register and the driver may write to it without pausing the sequencer.

**Note:** When POR and/or RST# is active it also forces CLRPARERR, CLRBRKADRINT, CLRSCSIINT, CLRCMDINT and CLRSEQINT to also be active.

| CLRINT<br>W |              |  |
|-------------|--------------|--|
| 7           |              |  |
| 6           |              |  |
| 5           |              |  |
| 4           | CLRPARERR    |  |
| 3           | CLRBRKADRINT |  |
| 2           | CLRSCSIINT   |  |
| 1           | CLRCMDINT    |  |
| 0           | CLRSEQINT    |  |

| В  | it |     | Name         | Definition                                                                                                                                                                                                                                                                                                                                                                                                |
|----|----|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7- | -5 | (0) | Not Used     | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                           |
| 4  | 4  | (0) | CLRPARERR    | Clear Parity Errors. When this bit is written (=1), the SQPARERR, MPARERR and DPARERR bits are cleared if set in the ERROR register. Latched interrupts caused by active PCISTATUS register bits [5:0] will also be cleared, but the PCI Configuration STATUS register bits themselves will not be cleared. To clear these bits, see the Configuration Status Register section. This bit will self-clear. |
| ;  | 3  | (0) | CLRBRKADRINT | Clear Break Address Interrupt. When this bit is written (=1), the BRKADRINT bit is cleared in the INTSTAT register. CLRBRKADRINT bit will self-clear and always reads 0. See the INTSTAT register for causes of BRKADRINT being active which may have to be cleared prior to clearing the BRKADRINT bit. ILLOPCODE may only be cleared by writing CHIPRST (=1) or asserting RST#.                         |
| 2  | 2  | (0) | CLRSCSIINT   | Clear SCSI Interrupt. When this bit is written (=1), the SCSIINT bit is cleared in the INTSTAT register. This bit will self-clear.                                                                                                                                                                                                                                                                        |
| •  | 1  | (0) | CLRCMDINT    | Clear Command Complete Interrupt. When this bit is written (=1), the CMDCMPLT bit is cleared in the INTSTAT register. This bit will self-clear.                                                                                                                                                                                                                                                           |
| (  | 0  | (0) | CLRSEQINT    | Clear Sequencer Interrupt. When this bit is written (=1), the SEQINT bit is cleared in the INTSTAT register. This bit will self-clear.                                                                                                                                                                                                                                                                    |

## **Error (ERROR)**

Type:

R

Address: M92h, DS-92h

This register reports errors that are catastrophic in nature due to (software/firmware/hardware) error conditions that must be corrected for the device to operate properly. These errors will cause BRKADRINT to be active (except PCI errors) and the sequencer to be paused. Clearing of these bits (except for PCIERRSTAT and ILLOPCODE) requires writing to CLRPARERR for (SQPARERR, MPARERR, DPARERR). Writing to CHIPRST (=1) will clear ILLOPCODE, and asserting input RST# will clear all latched bits.

| ERROR<br>R |            |  |
|------------|------------|--|
| 7          |            |  |
| 6          | PCIERRSTAT |  |
| 5          | MPARERR    |  |
| 4          | DPARERR    |  |
| 3          | SQPARERR   |  |
| 2          | ILLOPCODE  |  |
| 1          |            |  |
| 0          |            |  |

| Bit |     | Name       | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | Not Used   | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6   | (0) | PCIERRSTAT | PCI Error Status. When active (=1), indicates a PCI error has been detected by the AIC-7850 and is stored in the Configuration STATUS1 register. PCIERRSTAT is the OR of any bit [5:0] active in the Device PCISTATUS register. PCIERRSTAT will become inactive when the PCI errors are inactive. This bit is read only, writing to this register or the CHIPRST bit has no effect. Writing to the Configuration STATUS registers or asserting RST# is required to clear it. |
| 5   | (0) | MPARERR    | Memory Parity Error. When active (=1), indicates an odd-parity error has been detected in the QINFIFO, QOUTFIFO, SCRATCH or SCB Array (internal or external) RAM cells. The MPARCKEN bit in the Device space COMMAND register must be active to enable MPARERR to be become active.                                                                                                                                                                                          |
| 4   | (0) | DPARERR    | Data-path Parity Error. When active (=1), indicates an odd-parity error has been detected in the device internal data path (check logic is located in the PHOST, data FIFO and the SCSI blocks) byte parity. The DPARCKEN bit in the Device space command register must be active to enable DPARERR to be become active.                                                                                                                                                     |
| 3   | (0) | SQPARERR   | Sequencer Parity Error. When active (=1), indicates a parity error has been detected in the sequencer control store RAM. PERRORDIS in the Sequencer SEQCTL register must be inactive for SQPARERR to become active.                                                                                                                                                                                                                                                          |
| 2   | (0) | ILLOPCODE  | <b>Illegal Opcode Error.</b> When active (=1), indicates a nondefined sequencer instruction has been detected in the sequencer's firmware fetch from its control store RAM.                                                                                                                                                                                                                                                                                                  |
| 1-0 | (0) | Not Used   | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## **Data FIFO Control (DFCNTRL)**

Type: R/W

Address: M93h, DS-93h

The DFCNTRL register provides data path hardware control. DIRECTIONACK, HDMAENACK, SDMAENACK, SCSIENACK and FIFOFLUSH bits have hardware enforced state changes to ensure proper control of the data path. This control allows several hardware functions to be combined into a single write to the DFCNTRL register. Some bits are self-clearing and some must be cleared by the driver. When RST# or CHIPRST is active all DFCNTRL register bits are forced to zero. Data FIFO data path access is determined by the state selections of DIRECTIONACK, HDMAENACK and SDMAENACK bits in the DFCNTRL register.

| DFCNTRL<br>R/W |                |  |
|----------------|----------------|--|
| 7              |                |  |
| 6              | WIDEODD        |  |
| 5              | SCSIEN[ACK]    |  |
| 4              | SDMAEN[ACK]    |  |
| 3              | HDMAEN[ACK]    |  |
| 2              | DIRECTION[ACK] |  |
| 1              | FIFOFLUSH[ACK] |  |
| 0              | FIFORESET      |  |

| E | Bit |     | Name        | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---|-----|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 7   | (0) | Not Used    | Always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1 | 6   | (0) | WIDEODD     | Wide Odd control. A read/write bit with no current logic control assignment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|   | 5   | (0) | SCSIEN[ACK] | SCSI Transfer Enable/SCSI Transfer Enable Acknowledge. When this bit is active (≈1) it enables transfers between a SCSI bus and a SCSI FIFO. Clearing this bit will cleanly halt the transfer by preventing another ACK to the SCSI bus. Reading this bit (SCSIENACK) provides status which indicates the state of the hardware. When this bit is cleared, it must be read back as zero before the transfer is guaranteed to have halted. Synchronous data-in transfers to the SCSI FIFO will always be enabled when the synchronous offset value programmed in SCSIRATE is nonzero and the SCSI bus is in Data-in phase. |
| , | 4   | (0) | SDMAEN[ACK] | SCSI DMA Enable/SCSI DMA Enable Acknowledge. When this bit is active (=1) it enables transfers between the SCSI block and the data FIFO. Reading this bit (SDMAENACK) provides status which indicates the state of the hardware. When this bit is cleared it must be read back as zero before the transfer is guaranteed to have halted.                                                                                                                                                                                                                                                                                  |
| ; | 3   | (0) | HDMAEN[ACK] | Data FIFO DMA Enable/Data FIFO DMA Enable Acknowledge. When this bit is active it enables the PCI host interface to transfer data to or from system memory. The Host Address and Host Count registers must be set up and the data FIFO initialized prior to activating this bit. Clearing this bit will halt transfers without losing data, status, or byte count. Transfers may be continued after halting. Reading this bit (HDMAENACK) provides status which indicates the state of the hardware. When this bit is cleared it must be read back as zero before the transfer is guaranteed to have halted.              |

### (Continued)

| Bit |     | Name           | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | (0) | DIRECTION[ACK] | Data Path Direction Acknowledge. This bit when active (=1) will condition data transfers to be from the PCI bus (system memory) or from the (sequencer cell for DFDAT write), to the data FIFO and from the data FIFO to the (SCSI cell) or to the (sequencer cell for DFDAT read). The Direction bit when not active (=0) will condition data transfers to be from the SCSI cell or from the (sequencer cell for DFDAT write), to the data FIFO and from the data FIFO to the PCI bus (system memory) or to the (sequencer cell for DFDAT read). When both HDMAENACK and SDMAENACK are inactive, the sequencer cell may both read and write DFDAT without regard for the state of the DIRECTION bit. The state of DIRECTIONACK will not change unless the enable bits (bits 3, 4 and 5) are cleared.                                                                                                                                                                                                                                                                                                                                                                       |
| 1   | (0) | FIFOFLUSH[ACK] | Data FIFO Flush. During a SCSI bus to PCI bus transfer (a read operation as initiator), FIFOFLUSH may be set (manual flush) to force the remaining bytes in the data FIFO to be sent to the PCI host memory. If FIFOEMP is active, attempts to set this bit active will have no effect. This bit is self-clearing and has no effect during a PCI bus to SCSI bus operation. An Autoflush to force the remaining bytes to be transferred will occur by the hardware when STCNT counts down to zero or a SCSI phase change occurs (providing AUTOFLUSHDIS=0 in the SBLKCTL register). When this bit is read as a one, it indicates a flush operation is pending or in operation due to either a firmware or hardware flush. It will read as a zero when the flush operation is completed. During sequencer writes to the data FIFO, setting this bit will force the host or SCSI blocks to recognize a partial quad word load made by the sequencer. This feature allows any number of bytes to be loaded by the sequencer without considering byte alignment in the data FIFO. Note, manual flush using the FIFOFLUSH write bit should not be used if WIDEODD bit is active. |
| 0   | (0) | FIFORESET      | Data FIFO Reset. This bit when written (=1) will force the data FIFO status to reflect that the data FIFO is empty. This bit is self-clearing. FIFORESET must be written to after loading LHADDR0 register in order to load the data path byte offset pointers in the (data FIFO, PHOST and SCSI blocks) which are determined from LHADDR[02:00] in preparation for a new data transfer operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# **Data FIFO Status (DFSTATUS)**

Type:

R

Address: M94h, DS-94h

The DFSTATUS register contains data path status.

| DFSTATUS<br>R |            |  |
|---------------|------------|--|
| 7             |            |  |
| 6             | DFCACHETH  |  |
| 5             | FIFOQWDEMP |  |
| 4             | MREQPEND   |  |
| 3             | HDONE      |  |
| 2             | DFTHRSH    |  |
| 1             | FIFOFULL   |  |
| 0             | FIFOEMP    |  |

| Bit |     | Name      | Definition                                                               |                                         |                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|-----|-----|-----------|--------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7   | (0) | Not Used  | Always reads 0.                                                          |                                         |                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 6   | 1   | DFCACHETH | cient space ex<br>size transfer for<br>sufficient data<br>cache size tra | ists in<br>or data<br>is ava<br>nsfer v | the Threshold Status. This is active (≈1) to indicate that sufficts in the data FIFO to store at least one more selected cacher data path direction from PCI bus to the data FIFO, or that is available in the data FIFO for at least one more selected insfer when the data path direction is from the data FIFO to the Configuration CACHESIZE register for additional |  |  |
|     |     |           | Cache Size Value DFCACHETH Action                                        |                                         |                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|     |     |           | [7:0]                                                                    |                                         |                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|     |     |           | 0 - 7                                                                    | = 1                                     | DIRECTION bit =1 (space for 8 DWDs (32 Bytes) or greater exists) or DIRECTION bit =0 (4 DWDs (16 Bytes) or more are stored)                                                                                                                                                                                                                                              |  |  |
|     |     |           | 8 - 15                                                                   | = 1                                     | DIRECTION bit =1 (space for 8 DWDs (32 Bytes) or greater exists) or DIRECTION bit =0 (8 DWDs (32 Bytes) or more are stored)                                                                                                                                                                                                                                              |  |  |
|     |     |           | 16 - 255                                                                 | = 1                                     | DIRECTION bit =1 (space for 16 DWDs (64 Bytes) or greater exists) or DIRECTION bit =0 (16 DWDs (64 Bytes) or more are stored)                                                                                                                                                                                                                                            |  |  |

5 (1) FIFOQWDEMP

Data FIFO Quad Word Empty. This is active (=1) when the data FIFO does not contain a complete quad word of 64-bits (QWD). Partially stored QWD (one to seven bytes) will not cause FIFOQWDEMP to become inactive. FIFOQWDEMP status is used by the SCSI and host blocks to determine when to read or write data FIFO data. When the FIFORESET bit is active or CHIPRST is written (=1) or RST# is asserted, this bit is forced to be active.

### (Continued)

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 4   | (0) | MREQPEND | Memory Request Pending. This bit is active when the host block has reached a condition (a master transfer has been set up and the proper data FIFO status becomes active, or FIFOFLUSHACK becomes active for SCSI reads) which requires a data transfer on the PCI bus. The actual request for the bus (PREQ# asserted) is still subject to other conditions and may not be asserted at the time MREQPEND becomes active. MREQPEND is cleared when there is no requirement for a host transfer, when HDONE is active, when FIFORESET is active, when CHIPRST is written (=1), or RST# is asserted. Status MREQPEND is set active by the DFTHRSH[1:0] selected start condition (DFTHRSH status) or DFSXDONE (SXFERDONE from the SCSI block, or FIFOFLUSH in DFCNTRL register) active with FIFOQWDEMP inactive. MREQPEND is set inactive by the selected stop condition (HCNT, data FIFO empty for system memory writes, data FIFO full for system memory read, HDMAEN set inactive). |  |
| 3   | (0) | HDONE    | Host Done status bit. When active (=1), indicates that the count previously stored in HCNT[2:0] has expired (count=0) and the last transfer between system memory and the data FIFO has completed, including any temporary storage in the AIC-7850 host block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 2   | (0) | DFTHRSH  | Data FIFO Threshold Status bit. When active (=1), indicates that the quantity of quad data words stored in the data FIFO equals the value selected by DFTHRSH[1:0] located in the PCISTATUS register. When DFTHRSH becomes active, MREQPEND is set active to enable the device to request PCI bus master status (providing HDMAEN is active, HCNT is not zero, MASTEREN is active in the Configuration Command register and PCI status bits RMA and RTA are not active) to either empty the data FIFO by transfers to system memory or to fill the data FIFO by transfers from system memory.                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 1   | (0) | FIFOFULL | Data FIFO Full Status bit. When active (=1) indicates that all byte locations in the data FIFO contain data. Data must not be written to the data FIFO when FIFOFULL is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|     |     |          | Note: The current full position for normal operation in the data FIFO will change depending on the number of data bytes read from the data FIFO prior to writing it. FIFOFULL will be forced to be inactive when FIFORESET is active, CHIPRST is written (=1), or RST# is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 0   | (1) | FIFOEMP  | <b>Data FIFO Empty Status</b> bit. When active (=1) indicates that no data bytes are stored in the data FIFO. The data FIFO must not be read from when FIFOEMP is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|     |     |          | Note: The current empty position for normal operation in the data FIFO will change depending on the number of data bytes written to the data FIFO prior to reading it. FIFOEMP will be forced to be active when FIFORESET is active, CHIPRST is written (=1) or RST# is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |

<sup>&</sup>lt;sup>1</sup> When RST# is asserted or CHIPRST is written (=1), DFCACHETH is forced to be inactive. When the FIFORESET bit is written to and DIRECTION is inactive, DFCACHETH will be forced to be inactive. When the FIFORESET bit is written to and DIRECTION is active, DFCACHETH will be forced to be active.

# **Special Function (SFUNCT)**

Type: R/W

Address: M9Fh, DS-9Fh

This register provides selection of certain sections of the chip for test purposes. The pins in some cases are redefined to provide ample I/O for chip test. Identified selections in this register may also be used for diagnostics prior to starting normal operation. Redefining of pins that would affect system operation is prevented by nonnormal use of certain pins.

|   | SFUNCT<br>R/W |
|---|---------------|
| 7 | SFUNCT2       |
| 6 | SFUNCT1       |
| 5 | SFUNCT0       |
| 4 | TESTRAM       |
| 3 | TESTHOST      |
| 2 | TESTSEQ       |
| 1 | TESTFIFO      |
| 0 | TESTSCSI      |

| Bit |     | Name        | Definition                                                                                                                                                                                                                                                                                    |
|-----|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5 | (0) | SFUNCT[2:0] | Special Function. Used to select hardware test features. See SFUNCT register bits 4:0 for usage. Currently SFUNCT[2:0] states only have meaning when defined with a SFUNCT register bit 4:0 in the active state. These bits may be used for software flags when bits [4:0] are equal to zero. |
| 4   | (0) | TESTRAM     | When active (=1) enables stress testing of the sequencer RAM.                                                                                                                                                                                                                                 |
| 3   | (0) | TESTHOST    | When active (=1) selects the host block for testing.                                                                                                                                                                                                                                          |
| 2   | (0) | TESTSEQ     | When active (=1) selects the sequencer block for testing.                                                                                                                                                                                                                                     |
| 1   | (0) | TESTFIFO    | When active (=1) selects the data FIFO block for testing.                                                                                                                                                                                                                                     |
| 0   | (0) | TESTSCSI    | When active (=1) selects the SCSI block for testing.                                                                                                                                                                                                                                          |

### Sleep Control (SLEEPCTL)

Type: R/W

Address: M1Ch DS-1Ch

The SLEEPCTL register provides the control for the Host driver to disable the SLEEP mode from becoming active. It also provides control for the sequencer to activate the SLEEP mode when it desires to wait for one of the selected wake up status to become active. The SLEEP mode is similar to the PAUSE mode and reduces the power utilized by the AIC-7850 when the sequencer is running (i.e., sequencer logic and RAM is not being clocked and the CIOBUS is idle).

The SLP[1:0] bits are enable bits that allow selection of wake up status that are desired for the current sleep period. As a result of the sequencer writing to make an SLP[1:0] bit active, it will cause the sequencer to go to sleep, provided that the SLEEP mode has not been disabled by SLEEPDIS. When one of the selected statuses becomes active, the sequencer will wake up and automatically begin to process the next instruction. When SLEEPDIS is active, the sequencer will not go to sleep and will continue with the next instruction without delay. When the selected status becomes active, the SLP[1:0] bits will be set inactive. SLP[1:0] will also be set inactive whenever the Host driver writes to set the PAUSE bit inactive. Thus, no additional Host driver access is required to clear possible sleep conditions of the sequencer when a new SCB has been loaded in the QINFIFO. This action will occur even when the PAUSE bit is not active.

| SLEEPCTL<br>R/W |          |  |  |
|-----------------|----------|--|--|
| 7               | SLEEPDIS |  |  |
| 6               |          |  |  |
| 5               |          |  |  |
| 4               |          |  |  |
| 3               |          |  |  |
| 2               |          |  |  |
| 1               | SLP1     |  |  |
| 0               | SLP0     |  |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                             |
|-----|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | (0) | SLEEPDIS | Sleep Disable. When active (=1), prevents the SLP[1:0] bits from being set active by the sequencer. In this case, the sequencer will continue the next instruction without delay, the same as if it was just woken up. |
| 6-2 | (0) | Not Used | Always reads 0.                                                                                                                                                                                                        |
| 1   | (0) | SLP1     | When active (=1), enables an active DMADONE or PHASEMIS status to wake up the sequencer.                                                                                                                               |
| 0   | (0) | SLP0     | When active (=1), enables an active SELDO or SELDI status to wake up the sequencer.                                                                                                                                    |

# SCB Array Device Space Register Definition

## **SCB Pointer (SCBPTR)**

Type:

R/W

Address: M90h, DS-90h

The SCB Pointer register provides the page address to the SCB Array. The data value loaded in this register selects a page of 32 registers, within the SCB address range, which contain a description of an executable command. Changing this value during execution will not alter any data, but will address a different page of the array. Only bit SCBVAL1 and SCBVAL0 are used to address the real SCB address. Any read/write to SCBVAL<1:0> with value 11 will address to the same SCB as the value of 00. This is because the AIC-7850 has only three SCBs and address 3 is an alias of address 0. When FFh is written to the SCBPTR register the value returned upon reading it will be FFh.

| SCBPTR<br>R/W |         |  |  |  |
|---------------|---------|--|--|--|
| 7             | SCBVAL7 |  |  |  |
| 6             | SCBVAL6 |  |  |  |
| 5             | SCBVAL5 |  |  |  |
| 4             | SCBVAL4 |  |  |  |
| 3             | SCBVAL3 |  |  |  |
| 2             | SCBVAL2 |  |  |  |
| 1             | SCBVAL1 |  |  |  |
| 0             | SCBVALO |  |  |  |

| Bit |     | Name        | Definition                                                                                                                                         |
|-----|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-2 | (0) | SCBVAL[7:2] | These read/write bits have no other functions.                                                                                                     |
| 1-0 | (0) | SCBVAL[1:0] | These read/write bits are used for SCB (32-byte) page selection. The decoder is 00 for SCB0, 01 for SCB1, 10 for SCB2, and 11 is an alias of SCB0. |

# Functional Description

# **About This Chapter**

Read this chapter to find out

- A description of SCSI transfer control logic
- Features of the sequencer (SCSI PhaseEngine)
- Descriptions of the PCI Bus Commands

• • • • • 5

## SCSI

### 8-bit Data Bus

The AIC-7850 contains one SCSI bus which may perform 8-bit data transfers in Single-ended mode at rates up to 10 Mtransfers/sec.

### **SCSI Termination Power Control**

This feature provides the capability to enable or disable the external SCSI bus termination power source by use of the STPWDN output pin.

The STPWLEVEL bit (bit 1, DEVCONFIG register) selects the active/inactive polarity of the STPWDN output pin.

- If STPWLEVEL=0, then a high-level is selected for the active state of output pin STPWCTL.
- If STPWLEVEL=1, then a low-level is selected for the active state of output pin STPWDN. If a low-level active state is desired for output pin STPWDN, then STPWLEVEL should always be written before writing to STPWEN bit after a RST# assertion.

The STPWEN bit (bit 0, SXFRCTL1 register) selects the actual active/inactive state of the STPWDN output pin. If STPWEN=1, then the STPWDN output pin will be asserted to the level selected by STPWLEVEL.

| RST3<br>Input Pin      | CHIPRST<br>Bit         | STPWLEVEL<br>Bit | STPWEN<br>Bit  | STPWDN<br>Output Pin   | Comments                        |
|------------------------|------------------------|------------------|----------------|------------------------|---------------------------------|
| 0<br>note <sup>1</sup> | 0                      | 0<br>(cleared)   | 0<br>cleared   | Z<br>note <sup>2</sup> | Output is tri-stated            |
| 1                      | 0                      | 0                | 0              | 0                      | SCSI term power source disabled |
| 1                      | 0                      | 0                | 1              | 1                      | SCSI term power source enabled  |
| 1                      | 1<br>note <sup>3</sup> | 0<br>(no effect) | 0<br>(cleared) | 0                      | SCSI term power source disabled |
| 1                      | 0                      | 1                | 0              | 1                      | SCSI term power source disabled |
| 1                      | 0                      | 1                | 1              | 0                      | SCSI term power source enabled  |
| 1                      | 1<br>note <sup>3</sup> | 1<br>(no effect) | 0<br>(cleared) | 1                      | SCSI term power source disabled |

Table 5-1. SCSI Termination Power Control

### Initializing the SCSI Section

When the device is reset at power on, the sequencer (SCSI PhaseEngine) is held in the paused state. This allows the driver to access the SCSI registers directly. The SCSI section may be initialized by writing the OID. All interrupts are disabled, and all automatic functions are turned off. The Bus Free status bit will be set after reset if the SCSI bus is in the Bus Free state.

### Manual Mode Data Transfer

In Manual PIO mode, the SCSI block is used essentially as a bus buffer having no control functions. The host transfers data directly to and from the SCSI bus via the SCSI data latch registers SCSIDATL and SCSIDATH, and processes the SCSI control signals via the SCSI signal registers SCSISIGI and SCSISIGO. This mode only supports asynchronous transfers and is usually used during the Message and Status phases. Care should be taken to ensure that data is stable while ACK or REQ is asserted.

### Automatic Mode Data Transfer

Automatic PIO transfers on the SCSI bus are enabled by setting SPIOEN (bit 3, SXFRCTL0). In Automatic PIO mode, the sequencer transfers data directly to and from the SCSI bus via the SCSI data latch register SCSIDATL, while the hardware performs SCSI bus control automatically. Transfer complete can be signaled by an interrupt or by polling the status bit SPIORDY. This mode only supports asynchronous transfers and is usually used during the Message and Status phases. SCSI data may be read directly using SCSIBUSL.

<sup>&</sup>lt;sup>1</sup> When RST# is asserted (low-level), then both bits (STPWLEVEL and STPWEN) are forced to be inactive and STPWDN output pin is tri-stated.

<sup>&</sup>lt;sup>2</sup> The STPWDN output pin will remain tri-stated until the STPWEN bit is first written to the active state. Then output pin STPWDN will remain driven at the selected level controlled by STPWEN until the next RST# assertion.

<sup>&</sup>lt;sup>3</sup> When the software driver writes a one to the CHIPRST bit in HCNTRL register, the STPWEN bit is forced to be inactive. Writing to CHIPRST has no effect on the state of STPWLEVEL. Thus, CHIPRST forces STPWDN to the selected inactive level.

**Note:** Automatic PIO transfers will be performed only if the contents of SCSISIGO match the current phase on the SCSI bus (i.e., PHASEMIS, bit 4 SSTAT1 is set to 0).

The following Initiator and Target discussions assume an 8-bit transfer.

In Initiator mode, when the SCSI I/O signal indicates the Out direction with REQ active, SPIORDY (bit 1, SSTAT0) is a one and data may be written to SCSIDATL. Writing the data to SCSIDATL clears SPIORDY, the written data is presented on the SCSI bus, then ACK is driven active. REQ will be driven inactive by the Target, which will clear the ACK. When the SCSI I/O signal indicates the In direction and REQ is active, then valid data has been latched in the SCSIDATL register and SPIORDY (bit 1, SSTAT0) will be a one. When SCSIDATL is read, ACK is driven active on the SCSI bus and SPIORDY is cleared. Automatic mode may be left on during normal transfers without adverse effect. This allows handshake of Message In bytes with no additional bit manipulation.

In Target mode, when SCSI I/O indicates an Out direction and data is read from SCSIDATL, REQ will be driven. The Initiator will drive data onto the SCSI data lines and drive ACK active. The data will be latched on the leading edge of ACK in SCSIDATL and SPIORDY (bit 1, SSTATO) will be set. Reading this byte with SPIOEN set will cause another REQ to be driven on the bus and will clear SPIORDY. When SCSI I/O indicates the In direction and data is written to SCSIDATL, the data is driven onto the SCSI bus, REQ is driven active and SPIORDY is cleared. When the Initiator reads the data it will drive ACK active. This will cause REQ to go inactive and will set SPIORDY.

### Normal (DMA) Mode Data Transfer

In Normal (DMA) mode, the hardware performs the SCSI transfers and bus control automatically. Data is transferred automatically between the SCSI bus and the data FIFO through the SCSI FIFO. This transfer can be monitored via interrupts or by polling status bits. Wide, DMA transfers which are of the odd length and/or odd boundary type are handled automatically. Normal mode supports asynchronous transfers for Command and Data phase, and synchronous transfers which may be Wide and which are used during Data phase only. A DMA data transfer is enabled by setting up the SCSI and host sections with regard to direction, pointers and count values, then setting the appropriate enable bits in DFCNTRL. The data transfer rate for the Data phase is set up in the SCSIRATE register. This register chooses asynchronous or synchronous transfers, and may be set up beforehand. It has no effect on the Command phase.

# **SCSI Interrupts**

The SCSI module has one interrupt signal, SCSIINT, which is always routed to the active channel. The SCSI interrupt logic provides for the masking, generation, and clearing of all interrupts. This logic includes the interrupt mask (SIMODE), interrupt clear (CLRSINT) and interrupt status (SSTAT) registers. A SCSI interrupt is caused by some significant event occurring such as Selection/Reselection Successful, SCSI Reset, Transfer Done, Unexpected Bus Free, or Selection Time-out. SCSIINT is generated only when an interrupt condition occurs and the bit associated with the condition is set in the mask register SIMODE0 or SIMODE1. When an interrupt is generated, the status registers SSTAT0 and SSTAT1 will contain the cause of the interrupt. The source of the interrupt is cleared by writing to the associated bit in the appropriate clear register CLRSINT0 or CLRSINT1, or by the condition that caused the interrupt going away. Upon receiving an interrupt, the host may want to examine all bits in the status registers since the occurrence of another interrupt causing event before the host services the original

interrupt will cause another bit to be set in the status register but will not cause another SCSIINT. Once the source is cleared, SCSIINT can be cleared by writing a one to CLRSCSINT (bit2, CLRINT).

### **Counters**

SHADDR(0-3) and STCNT(0-2) are the two counters used in Normal (DMA) mode and Automatic PIO transfers to regulate the flow of data and provide status information regarding the current transfer in progress.

The address pointer which is contained in counter SHADDR0-3 is loaded when the host address pointer LHADDR0-3 (088-08Bh) is loaded. The current value of the address pointer can be read by reading SHADDR0-3. This counter will contain the next starting address when a disconnect occurs. In DMA mode, both SDMAEN and SCSIEN must be disabled prior to reading or loading these counters. The counters are enabled when either SDMAEN, SPIOEN or SCSIEN is set and there is either a nonzero transfer count or a zero transfer count with SWRAPEN set. The event that both counters rely on is a SCSI byte being successfully transferred. A SCSI byte is considered transferred when writing to the SCSI bus when the handshake associated with this byte has occurred on the SCSI Bus (REQ/ACK). A SCSI byte is considered transferred when reading from the SCSI bus when the byte has been written to the data FIFO. Two counters are maintained for this purpose, and the sense of DIRECTION (bit 2, DFCNTRL) determines which one is used. This definition applies also to Wide transfers.

STCNT0-3 is the 24-bit counter that contains the DMA SCSI transfer count, which is the number of bytes remaining to be transferred. STCNT decremented by SCSI FIFO reads in the same manner that SHADDR is incremented. This counter can be made to wrap past 0 by setting SWRAPEN in SXFRCTL1. If SWRAPEN is 0 and STCNT counts from 1 to 0, transfers will stop and SDONE will be set.

### **SCSI FIFO**

The SCSI FIFO exists to catch data during the Synchronous Data In phase as an Initiator. The FIFO may be reset under several conditions listed below after which no data will be in the FIFO.

- CHIPRST
- Setting CLRCHN (bit 1, SXFRCTL0)
- Clearing SDMAEN and DIRECTION=1 and STCNT=0 and Initiator mode

### **SCSI** Reset

The SCSI bus may be reset by setting SCSIRSTO (bit 0, SCSISEQ), waiting for the reset time and then clearing SCSIRSTO. SCSIRSTI (bit 5, SSTAT1) will be set only when receiving a reset from some other device on the SCSI bus. If the reset originates from SCSIRSTO only, then SCSIRSTI will not be set.

### **SHADDR Address Pointer**

The address pointer SHADDR(3:0) is loaded when the host low address pointer LHADDR(3:0) is loaded. LHADDR counts the number of bytes transferred on the Host bus and SHADDR counts the number of bytes that have been transferred on the SCSI bus. SHADDR will contain the next starting address when a disconnect occurs.

# Sequencer

### Loading

The sequencer is ready for loading after being reset or paused. The sequencer is loaded by first setting the LOADRAM bit in SEQCTL. The starting sequencer address should then be loaded in SEQADDR, with the low order address written first. The sequencer map should then be loaded sequentially into SEQRAM. The bytes are loaded into the RAM starting with the least significant byte at the address in SEQADDR. Subsequent bytes will load in the same word until the word is complete, and then SEQADDR is incremented and the next word is loaded. Parity should be disabled when loaded.

### **Pause**

The sequencer may be paused at anytime without adverse effect by setting PAUSE in HCNTRL, by Automatic Access Pause (AAP) action from a host request without setting the PAUSE bit, or by the sequencer entering the SLEEP mode. When the access that caused the AAP is complete, or the status that has been enabled for sleep wake up is active, the sequencer will continue the same as when the PAUSE bit is reset. The sequencer will hold at the current address and all internal address and data paths will be gated to the host interface. The sequencer logic will set PAUSEACK in HCNTRL when the hardware is in this state. This state is used by the driver to gain access to any of the internal registers or RAM. When the driver is finished, the PAUSE bit is cleared and the sequencer will continue with its program. When PAUSE is cleared, the sequencer will always execute at least one instruction, even if some other event is active to pause the sequencer. When changing the address of the sequencer to start execution at a different location, SEQADDR0 should be written first, followed by SEQADDR1.

**Note:** Sequencer reaction to a pause request when the current instruction is to SCB address will be delayed when RAMPSM is asserted and arbitration is required to gain access to the external SRAM as the sequencer instruction time is being stretched until the arbitration is completed.

Pause must be set before setting POWRDN (bit 6, HCNTRL).

# **Breakpoint**

The sequencer has a diagnostic feature which allows a driver to stop the sequencer at a predetermined address. The address is loaded in BRKADDR0 and BRKADDR1 with BRKDIS (bit 7, BRKADDR1) cleared. When the program counter of the sequencer equals the value loaded in BRKADDR then the sequencer will be paused, and BRKADRINT (bit 3, INTSTAT) will be set. If BRKADRINTEN (bit 3, SEQCTL) is set, the IRQA# pin will also be driven active. BRKADRINT and the interrupt may be cleared by setting CLRBRKADRINT (bit 3, CLRINT). A driver may do any of the following:

- The driver may start execution from the current address and break on the next occurrence by clearing PAUSE.
- The driver may change the break address and clear PAUSE. This will start execution from the current address and break on the new one.
- The driver may single-step the sequencer.

■ The driver may change the break address and the program counter, and clear PAUSE. The sequencer will start at a new address and break on a new address.

### Single Step

The sequencer may be single-stepped after PAUSE (bit 2, HCNTRL) is set or a breakpoint has been reached. This is done by setting STEP in SEQCTL. The software driver should then clear PAUSE. The sequencer will execute one cycle and set PAUSE again. For consecutive single steps, PAUSE should be cleared consecutive times. To continue executing from the current location, clear STEP and then clear PAUSE.

### Reset

The sequencer may be reset by writing to SEQRESET in SEQCTL. Setting this bit will cause the sequencer to start executing at address zero.

### Restart

The sequencer may be restarted at any location by first setting PAUSE (bit 2, HCNTRL) and then loading SEQADDRL and SEQADDRH with the starting address. When the sequencer is unpaused by clearing PAUSE, the sequencer will start executing at the address that was loaded.

### **Indirect Jump**

The sequencer may jump indirect to any location within the same 256 instruction page by writing the new address to SEQADDR0. The new address is moved from some general RAM location. A bank switch may be performed by setting SEQADDR1.

### **Hardware Failure Detect**

The device has hardware failure detection mechanisms. MPARERR, DPARERR and sequencer RAM parity errors will be detected and causes a BRKADRINT interrupt which pauses the sequencer and drives the IRQA# pin when enabled. The cause of the interrupt may be read from the ERROR register. If this condition occurs, BRKADRINT may be cleared by setting CLRPARERR or CHIPRST (bit 0, HCNTRL). This feature may be disabled by setting FAILDIS (bit 5, SEQCTL).

# **Writing Hardware Control Bits**

Due to the single-cycle operation of the sequencer, it is possible to set a hardware control bit and read a status bit which is affected by the control bit with the next instruction and not see the effect of the control bit. In these cases, one or more NOPS should be executed between the control write and the status read of the bit in interest. Table 5-2 is a list of status bits that fall into this category and the number of NOPs required.

Table 5-2. Writing Hardware Control Bits

| Status Bit   | Control Causing Change                                                                                                                                                                                                                                                                                                              |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDONE        | Goes active after loading a nonzero value into STCNT, or changing SWRAPEN.                                                                                                                                                                                                                                                          |
| DMADONE      | Goes active after loading a nonzero into STCNT, or changing SWRAPEN, or after loading a nonzero value into HCNT.                                                                                                                                                                                                                    |
| SCSIPERR     | Goes active after setting ENSPCHK (bit 5, SXFRCTL1). Goes inactive after setting CLRSCSIPERR (bit 2, CLRSINT1).                                                                                                                                                                                                                     |
| SCSIENACK    | Goes active after setting SCSIEN (bit 5, DFCNTRL).                                                                                                                                                                                                                                                                                  |
| SDMAENACK    | Goes active after setting SDMAEN (bit 4, DFCNTRL).                                                                                                                                                                                                                                                                                  |
| HDMAENACK    | Goes active after setting HDMAEN (bit 3, DFCNTRL).                                                                                                                                                                                                                                                                                  |
| DIRECTIONACK | Goes active or inactive after setting or resetting DIRECTION (bit 2 DFCNTRL), if SCSIEN, SDMAEN, and HDMAEN are inactive.                                                                                                                                                                                                           |
| FIFOFLUSHACK | Goes active after setting (bit 1, DFCNTRL), unless or until FIFOQWDEMP is active.                                                                                                                                                                                                                                                   |
| DWORDEMP     | Goes active after setting FIFORESET, or reading DFDAT and less than 8 bytes remain in the data FIFO.                                                                                                                                                                                                                                |
| MREQPEND     | Goes active when HDMAEN is active (with DIRECTION active and FIFOQWDEMP goes active), (with DIRECTION inactive and FIFOFULL or FIFOFLUSH goes active), or (CACHETHEN inactive and DFTHRSH goes active), or (CACHETHEN active and DFCACHETH goes active).                                                                            |
|              | Goes inactive when HDMAEN is active (with DIRECTION active and FIFOFULL or DFSDH goes active), (with DIRECTION inactive and FIFOQWDEMP or goes active), or HCNT value is zero, FIFORESET is written =1.                                                                                                                             |
| HDONE        | Goes active when HCNT value is zero and final master data transfer is completed. Goes inactive after loading a nonzero value in HCNT.                                                                                                                                                                                               |
| DFTHRSH      | Goes active or inactive with a write to or a read from DFDAT that causes the data FIFO stores data level to be at the selected DFTHRSH level.                                                                                                                                                                                       |
| FIFOFULL     | Goes active when a write to DFDAT causes the data level stored in the data FIFO to be at maximum capacity (128 bytes), or writing to FIFORESET≈1.                                                                                                                                                                                   |
| FIFOEMP      | Goes active when a read from DFDAT causes the data level stored in the data FIFO to be at minimum capacity. (0 bytes) or writing to FIFORESET=1.                                                                                                                                                                                    |
| DFCACHETH    | Goes active when DIRECTION is active and writing to FIFORESET=1, or when DFDAT is read so that space is available to store data to match or exceed the selected cache line size, or when DIRECTION is inactive and DFDAT is written to so that available stored data in the data FIFO match or exceed the selected cache line size. |
|              | Goes inactive when DIRECTION is active and data is written to DFDAT so that space available is less than the selected cache line size, or when DIRECTION is inactive and DFDAT is read so that available stored data is less than the selected cache line size.                                                                     |

## **Host PCI Interface**

## Configuration

The configuration VENDERID will be hard-wired registers with a value of (9004h) representing ADP for Adaptec. The configuration DEVICEID will be hard-wired register with a value of 7850 following RST# assertion, however the value may be changed, see IDDAT. All chip setup will take place by the controlling BIOS or driver at initialization time.

#### **Data Transfer**

Data transfer is enabled by setting up the SCSI and host sections with regard to direction, pointers and count values. The data FIFO should be cleared, and then the HDMAEN, SDMAEN, and SCSIEN bits in DFCNTRL should be set to one. Transfers may be disabled by clearing any of these bits, but they should be polled for zero before the transfers are guaranteed to have stopped. In addition to these bits, HDONE and SDONE have been implemented to indicate the end of the transfer. DMADONE is also implemented and is the logical AND of HDONE and SDONE. DMADONE is intended to be one bit which will determine the end of transfer in either direction.

#### **PCI Bus Commands**

PCI bus commands indicate to the target the type of transaction the master is requesting. Bus commands are encoded on signals CBE[3:0]# during the Address phase of the transaction. The sense of values present on CBE[3:0]# for Bus commands during the Address phase is the same as that used on AD[31:00] (i.e., one = high level and zero = low level). This is the reverse of when CBE[3:0]# are used for valid byte indicators (=0) during Data phases the AIC-7850 support of PCI Bus commands follows:

Interrupt Acknowledge Command (IAC) CBE[3:0]#=0000: is a Read command implicitly addressed to the system Interrupt controller. The command is defined only by the CBE[3:0]# value. The ADn value during Address phase value is not used and the CBE[3:0] value in the Data phase determines the requested valid data width response expected on ADn.

- The AIC-7850 as Target: ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

Special Cycle Command (SCC) CBE[3:0]#=0001: is a Message Broadcast command to pass status to all PCI agents on the PCI bus or for logical side-band signaling between PCI agents on the bus that recognize the passed message. The SCC contains no explicit destination address. Each agent on the PCI bus that accepts an SCC must determine whether the message is applicable to it. DEVSEL# and TRDY# are never asserted to an SCC. Command timing is controlled by FRAME# and IRDY# during the Address phase ADn are stable, with don't care value, with correct parity. During the single Data phase AD[07:00] encode 64 specified fixed messages, AD[23:08] are 128 reserved message values (reserved value is 00h and must not be aliased or used) and AD[31:24] encode 64 optional soft messages that are agent dependent (=00h when not used).

The current specified messages are

| AD[07:00] | Message  |
|-----------|----------|
| 00h       | Shutdown |
| 01h       | Halt     |
| 02h       | RSVD     |
| 03h - 3Fh | RSVD     |

- The AIC-7850 as Target: ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

IO Read Command (IORDC) CBE[3:0]#≈0010: is a command to read data from an addressed Target's Device register space, which has been mapped into system IO Address space and enabled for access with ISPACEEN active.

- The AIC-7850 as Target: supports IORDC only for 8-bit transfers for all registers in its Device register space. Note, Disconnect will be returned when a data burst is indicated for all registers. When more than one CBE[3:0]# is asserted, a target-abort condition will be returned. When no CBE[3:0]# signal is asserted, the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. TRDY# will not be asserted until the addressed register access and data is valid. The period before TRDY# is asserted will vary depending on the address (internal/external) and state of PAUSEACK.
- The AIC-7850 as Master: not generated.

IO Write Command (IOWRC) CBE[3:0]#=0011: is a command to write data to a Device register space, which has been mapped into system IO address space and enabled for access with ISPACEEN active.

- The AIC-7850 as Target: supports IOWRC only for 8-bit transfers for all registers (except for SCB Array which may be either 8-bit or 32-bit) in its Device register space. Note, Disconnect will be returned when a data burst is indicated for all registers (except for linear burst order, 32-bit transfers to the internal SCB Array). When more than one CBE[3:0]# is asserted (except for the SCB Array where they must be one or all), a target-abort condition will be returned. When no CBE[3:0]# signal is asserted the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. TRDY# will not be asserted until the addressed register access is valid. The period before TRDY# is asserted and will vary depending on the address (internal/external) and state of PAUSEACK.
- The AIC-7850 as Master: not generated.

#### RSVD CBE[3:0]#=0100

- The AIC-7850 as Target: ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

#### RSVD CBE[3:0]#=0101

- The AIC-7850 as Target: ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

Memory Read Command (MRDC) CBE[3:0]#=0110: is a command used to read data from an addressed target mapped in the system Memory Address space with its MSPACEEN active in the Configuration Command register. MRDC is not cache line referenced and may contain any length of Data phases. MRDC may be used for transfers not starting on cache line boundaries to reach a boundary after which the MRDC command could be continued or either a MRDLC or MRDMC could be used to improve system memory performance.

- The AIC-7850 as Target: supports MRDC only for 8-bit transfers for all registers in its Device register space. Note, Disconnect will be returned when a data burst is indicated for all registers. When more than one CBE[3:0]# signal is asserted, a target-abort condition will be returned. When no CBE[3:0]# signal is asserted, the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. TRDY# will not be asserted until the addressed register access and data is valid. The period before TRDY# is asserted will vary depending on the address (internal/external) and state of PAUSEACK.
- The AIC-7850 as Master: supports MRDC for transfers from system memory. It will be issued whenever the starting address is not on the selected cache line boundary, when DFCACHETH is not active, a byte offset condition exists, or remaining count is less than the cache line size. Also see MRDCEN.

Memory Write Command (MWRC) CBE[3:0]#=0111: is a command used to write data to a target mapped in the system Memory Address space with its MSPACEEN active in the Configuration Command register. MWRC is not cache line referenced and may contain any length of Data phases. MWRC must be used for transfers not starting on cache line boundaries to reach a boundary after which the MWRC command could be continued or a MWRIC could be used to improve system memory performance.

■ The AIC-7850 as Target: supports MWRC only for 8-bit transfers for all registers (except for SCB Array which may be 8-bit or 32-bit, see SCBAUTO) in its Device register. Note, Disconnect will be returned when a data burst is indicated for all registers (except for linear burst order, 32-bit transfers to the internal SCB Array). When more than one CBE[3:0]# is asserted (except for the SCB Array where they must be one or all), a target-abort condition will be returned. When no CBE[3:0]# signal is asserted, the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. TRDY# will not be asserted until the addressed register access is valid. The period before TRDY# is asserted and will vary depending on the address (internal/external) and state of PAUSEACK.

■ The AIC-7850 as Master: supports MWRC for transfers to system memory. It will be issued whenever the starting address is not on the selected cache line boundary, when DFCACHETH is not active, a byte offset condition exists, remaining count is less than the cache line size, or FIFOFLUSH is active.

#### RSVD CBE[3:0]#=1000

- The AIC-7850 as Target: is ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

#### RSVD CBE[3:0]#=1001

- The AIC-7850 as Target: ignored after checking the address parity.
- The AIC-7850 as Master: not generated.

Configuration Read Command (CRDC) CBE[3:0]#=1010: is a command used to read data from a device's Configuration space or spaces mapped into the system Memory Address space by connecting one of AD[31:11] address lines to the device IDSEL input. All devices are required to support this command.

- The AIC-7850 as Target: supports CRDC access for all registers in its single function Configuration register space. Note, Disconnect will be returned when a data burst is indicated for all registers. All 32-bits are always provided without regard for the CBE[3:0]# value. When no CBE[3:0]# signal is asserted, the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. For valid accesses TRDY# is asserted one PCLK following DEVSEL# assertion.
- The AIC-7850 as Master: not generated.

Configuration Write Command (CWRC) CBE[3:0]#≈1011: is a command used to write data to a device's Configuration space or spaces mapped into the system Memory Address space by connecting one of AD[31:11] address lines to the device IDSEL input. All devices are required to support this command.

- The AIC-7850 as Target:supports CWRC for all registers in its single function Configuration register space. Note, Disconnect will be returned when a data burst is indicated for all registers. Any combination of CBE[3:0]# value assertion is acceptable for writing bytes and when none is asserted, the data cycle will be treated as a NOP. DEVSEL# is asserted using medium speed target response timing. For valid accesses TRDY# is asserted one PCLK following DEVSEL# assertion.
- The AIC-7850 as Master: not generated.

Memory Read Multiple (MRDMC) CBE[3:0]#=1100: is a command used to read data from a target mapped in the system Memory Address space with its MSPACEEN active in the Configuration COMMAND register. MRDMC is cache line referenced and when used indicates that multiple cache lines are expected to be required for the transaction, but do not have to be used.

- The AIC-7850 as Target: defaults to MRDC.
- The AIC-7850 as Master: supports MRDMC for transfers from system memory. It will be issued whenever the starting address is on the selected cache line boundary, no byte offset condition exists, remaining count is greater than/or equal to the cache line size, and DFCACHETH is active, with CACHETHEN not active. Cache line streaming is supported.

**Dual Address Cycle (DAC)** CBE[3:0]#=1101: is a command used to transfer 32-bit data anywhere in a 32-bit address space segment of a 64-bit address space. The 64-bit address is indicated on AD[31:00] with two address phases of one PCLK each. The low 32- bits are transferred in the first PCLK and the high 32-bits in the second PCLK with the data on the following PCLKs. The CBE[3:0]# value supplied in the second address PCLK period identifies the type of data command the same as when only a single address cycle occurs.

- The AIC-7850 as Target: is ignored after checking address parity on both address phases.
- The AIC-7850 as Master: supports DAC for transfers to and from system memory. It will be issued in the first address phase whenever DACEN is active in the Configuration DEVCONFIG register and HHADDR[3:0] register contents are not zero. In the second address phase, the AIC-7850 will issue a MRDC, MRDLC, MRDMC, MWRC or MWRIC command followed by Data phases of the transaction. Transfers across 4 GByte boundaries are not allowed.

Memory Read Line (MRDLC) CBE[3:0]#=1110: is a command used to read data from a target mapped in the system memory address space with MSPACEEN active in the Configuration Command register. MRDLC is cache line referenced and when used indicates that a single cache line is expected to be required for the transaction, but does not have to be used.

- The AIC-7850 as Target: defaults to MRDC.
- The AIC-7850 as Master: supports MRDLC for transfers from system memory. It will be issued whenever the starting address is on the selected cache line boundary, no byte offset condition exists, remaining count is greater than/or equal to the cache line size, and DFCACHETH and CACHETHEN are active (note DFTHRSH is not used). Control of data transfer size to only cache line size may be obtained when the CACHSIZE, LATTIME registers and the GNT# assertion time have appropriate values, except for the last transfer which may be less. Also see MRDCEN. Cache line streaming is supported.

Memory Write and Invalidate (MWRIC) CBE[3:0]#=1111: is a command used to write data to a target mapped in the system Memory Address space with MSPACEEN active in the Configuration Command register. MWRIC is cache line size referenced and when used to improve system memory performance indicates that complete cache lines are to be transferred in the transaction.

- The AIC-7850 as Target: defaults to MWRC.
- The AIC-7850 as Master: supports MWRIC for transfers to and from system memory. It will be issued whenever the starting address is on the selected cache line boundary, no byte offset condition exists, remaining count is greater than/or equal to the cache line size, and DFCACHETH and DFTHRSH (DFTHRSH is not used when CACHETHEN is active) are active. When CACHETHEN is active, control of data transfers to only cache line size when the CACHESIZE, LATTIME registers and GNT# assertion time have appropriate values. When FIFOFLUSH is active, a MWRC command will be used instead of MWRIC. Should the Target signal Disconnect in the middle of a MWRIC cache line command, the AIC-7850 will terminate the MWRIC command and release the bus. The AIC-7850 will then request the bus to complete the cache line using MWRC. Cache line streaming is supported.

# Reading and Writing the Data FIFO

The data FIFO may be read at any time or written when no other DMA activity is writing to the FIFO. Any attempt to enable two sources to write to the FIFO will result in a BRKADRINT interrupt. There are three sources which may read or write the FIFO; the SCSI Data Transfer port, the Host Data Transfer port, and the I/O port DFDAT. Read data is pointed to by DFRADDR0 and Write data is pointed to by DFWADDR0. These pointers point to 64-bit quad-words. Data is properly aligned in conjunction with the state of bits LHADDR(02:00). When set, FIFORESET (bit 0, DFCNTRL) clears the FIFO address counters (DFRADDR0, and DFWADDR0) and loads the byte offset pointers. The byte offset is decoded from LHADDR(02:00). Normal data transfer does not require any intervention from the sequencer. The correct offset is set up automatically when the Low Host Address is loaded in LHADDR and the FIFORESET bit is set. DFWADDR is incremented by writes to the FIFO from whatever source is active, and DFRADDR is incremented by reads from any source.

Data may be written to any location in the FIFO by first setting up LHADDR, then setting FIFORESET. The byte offset pointers will be pointing to the correct offset for the first byte transferred. DFWADDR may be changed to point to any starting location in the FIFO while maintaining the same byte offset. Consecutive writes will load consecutive FIFO locations. Data may be sent to system memory by setting up LHADDR and HCNT, resetting the FIFO, writing the data to DFDAT, and setting DIRECTION with HDMAEN in DFCNTRL. When HDONE is set, the contents of the FIFO have been written to system memory.

Data may be read from any location in the FIFO by first setting up LHADDR, then setting FIFORESET. The byte offset pointers will be pointing to the correct offset for the first byte transferred. DFRADDR may be changed to point to any starting location in the FIFO while maintaining the same byte offset. Consecutive reads will return consecutive FIFO locations. Data may be read from system memory by setting up LHADDR and HCNT, resetting the FIFO, and clearing DIRECTION and setting HDMAEN in DFCNTRL. When HDONE is set, the contents of the FIFO have been read from system memory, and the data may be read from DFDAT.

Table 5-3 shows which port is active and in which direction with respect to the data FIFO

Table 5-3. Data Flow Control

| Direction | HDMAEN | SDMAEN | Read FIFO | Write FIFO |
|-----------|--------|--------|-----------|------------|
| 0         | 1      | 1      | Host      | SCSI       |
| 0         | 0      | 1      | Sequencer | SCSI       |
| 0         | 1      | 0      | Host      | Sequencer  |
| X         | 0      | 0      | Sequencer | Sequencer  |
| 1         | 1      | 1      | SCSI      | Host       |
| 1         | 0      | 1      | SCSI      | Sequencer  |
| 1         | 1      | 0      | Sequencer | Host       |

Data is aligned in the data FIFO and the SCSI FIFO according to the offset of the starting address from a quad-word boundary. The alignments in the data FIFO and SCSI FIFO are summarized in Table 5-4.

Table 5-4. Data FIFO and SCSI FIFO Alignments

| L    | HADDE | ?    | PCI Bus     | Host Block  | D        | ata FIFO Bl |           | SCSI Block  |
|------|-------|------|-------------|-------------|----------|-------------|-----------|-------------|
| (02) | (01)  | (00) | Byte Offset | Byte Offset | SEQ Port |             | HOST Port | Byte Offset |
| 0    | 0     | 0    | 0           | 0           | 0        | 0           | 0         | 0           |
| 0    | 0     | 1    | 1           | 0           | 1        | 0           | 0         | 1           |
| 0    | 1     | 0    | 2           | 0           | 2        | 2           | 0         | 0           |
| 0    | 1     | 1    | 3           | 0           | 3        | 2           | 0         | 1           |
| 1    | 0     | 0    | 0           | 4           | 4        | 4           | 0         | 0           |
| 1    | 0     | 1    | 1           | 4           | 5        | 4           | 0         | 1           |
| 1    | 1     | 0    | 2           | 4           | 6        | 6           | 0         | 0           |
| 1    | 1     | 1    | 3           | 4           | 7        | 6           | 0         | 1           |

# Writing to the SCB Array

The SCB Array may be written to by the driver after the sequencer is paused. The SCB Array is divided up into sections which are addressed by the value in SCBPTR. Only one 32-byte area of the array may be accessed at a time. Each area is mapped to the same address location no matter which area is selected. The device contains an Auto Increment feature where many or all the locations may be loaded with a minimum of overhead. The starting address is loaded in SCBCNT with SCBAUTO set. Each write to or read from any SCB Array address increments the address to the next location. This feature may be used with the REP OUTSB instruction or one of the memory MOV instructions to quickly load an SCB in the Array. The REP INSB instruction may be used to read the contents of an SCB. The contents of the SCB are application specific. SCBAUTO must be cleared to allow random access to the SCB Array.

# **Executing a Command**

An operation is started by first pausing the sequencer by setting PAUSE in HCNTRL. This prevents the sequencer and controlling driver from colliding on the internal control bus. The driver should then wait for PAUSEACK (bit 2, HCNTRL) to become one. The driver should then save SCBVAL in SCBPTR so it may be restored later. The driver loads SCBPTR with the value of the empty SCB that it wishes to load. The SCB information is then loaded and the value that was written in SCBPTR is written to the QINFIFO. SCBPTR is then restored to the value that was previously set and the sequencer is then unpaused, and allowed to resume its program. The sequencer will initially be scanning the QINFIFO and if something is there, will read the pointer and attempt to execute that SCB if it does not conflict with an already open SCB. If it does conflict with an open command, then the SCB ID will be written back to the QINFIFO.

Once a command is started, the Target may disconnect. The sequencer will then save data pointers and mark a command as disconnected. The sequencer will then enter an idle loop and look for the next command to execute from the QINFIFO. If the sequencer needs driver assistance to execute a SCB, it will interrupt with the appropriate code in the INTSTAT with SEQINT set.

When the sequencer is finished with the command, it will write the SCB pointer value in the QOUTFIFO and will interrupt the driver with CMDCMPLT (bit 1, INTSTAT) set. The driver will then read the QOUTFIFO to get the value of the SCB that has just finished. If an error occurred, the driver should then save the SCBPTR value and load the SCB pointer of the finished SCB and read the SCB information. All status to report will be in the SCB area. The driver should then restore the SCB Pointer and clear PAUSE (bit 2, HCNTRL) to continue processing.

## Interrupts

Interrupts fall into four basic classes: normal operation, driver intervention, error, and diagnostic. Interrupt status is given in INTSTAT. The sequencer does not have to be paused to read INTSTAT. The CMDCMPLT bit is set by the sequencer to indicate that a command has been completed and its location has been written to the QOUTFIFO. The sequencer will still be running and executing any other commands that have been loaded. Sequencer interrupts are interrupts that require the driver to intervene in the normal operation in order to provide a lengthy or difficult calculation. Sequencer interrupts are caused by the sequencer setting the SEQINT bit in INTSTAT along with the INTCODE. Setting the SEQINT bit will cause the sequencer to self-pause. The sequencer

may be restarted by clearing the SEQINT bit and writing a zero to the PAUSE bit in HCNTRL. The sequencer code will be structured to continue after the driver is finished handling the particular situation. A SCSI interrupt is caused by some catastrophic event such as a SCSI Reset, SCSI Parity Error, Unexpected Bus Free, or Selection Timeout. This interrupt is generated by hardware according to any SCSI event that is enabled in the SIMODE0 or SIMODE1. The sequencer is also paused by this interrupt. The BRKADRINT interrupt is used with special diagnostic code for the purpose of device debug, or for the detection of a hardware failure. The sequencer is paused by this interrupt.

## SCSI interrupts

SCSI interrupts occur when the appropriate bit in SIMODE0 or SIMODE1 is set and the corresponding condition comes true. This will set the system interrupt pin if INTEN (bit 1, HCNTRL) is set and also the SCSIINT bit in INTSTAT. If the sequencer is executing a SCSI command, these conditions are error conditions and will pause the sequencer.

If the driver is executing the SCSI command, this is the normal way to respond to a SCSI interrupt.

## **Command Complete Interrupts**

A Command Complete interrupt happens when the sequencer writes to the INTSTAT register with that bit set. It signifies that a command is finished and the ID has been loaded in the Queue Out register. The driver may read the Queue Out register and Queue Out count until the Queue Out is empty without pausing the sequencer. In this way the driver may service commands that have completed without error without interrupting the sequencer.

## **Breakpoint Interrupts**

The sequencer has a diagnostic feature which allows a driver to stop the sequencer at a predetermined address. The address is loaded in BRKADDR0 and BRKADDR1 with BRKDIS (bit 7, BRKADDR1) cleared. When the program counter of the sequencer equals the value loaded in BRKADDR then the sequencer will be paused. BRKADRINT (bit 3, INTSTAT) will be set at this time. If BRKADRINTEN (bit 3, SEQCTL) is set, the IRQA# pin will also be driven active. BRKADRINT and the interrupt may be cleared by setting CLRBRKADRINT (bit 3, CLRINT).

This interrupt is also set upon detection of an illegal opcode, or sequencer RAM parity error. This feature may be disabled by setting FAILDIS (bit 5, SEQCTL).

## **Software Interrupt**

The interrupt line IRQA# may be set by the software driver by setting SWINT (bit 4, HCNTRL). IRQA# will remain active until SWINT is cleared. INTEN will override SWINT, and must be set in order to see the IRQA#.

# **Interrupt Summary**

Table 5-5. Interrupt Summary

| Description                         | Enable Conditions                                                      | Pause | INSTAT bit | ERROR bit  |
|-------------------------------------|------------------------------------------------------------------------|-------|------------|------------|
| Sequencer Parity<br>Error           | PERRORDIS=0 and parity error detected during opcode read               | Yes   | BRKADRINT  | PARERR     |
| Memory Parity Error                 | FAILDIS=0 and MPARERR detected                                         | Yes   | BRKADRINT  | MPARERR    |
| Data Parity Error                   | FAILDIS=0 and DPARERR detected                                         | Yes   | BRKADRINT  | DPARERR    |
| Opcode Error                        | FAILDIS=0 and ILLOPCODE detected                                       | Yes   | BRKADRINT  | ILLOPCODE  |
| PCI Status Error<br>Detected        | FAILDIS=0 and PCI status error detected                                | Yes   | NONE       | PCIERRSTAT |
| Sequencer Break<br>Address Accessed | BRKDIS=0 and BRKADRINTEN=1 and BRKADDR compares with sequencer address | Yes   | BRKADRINT  | NONE       |
| SCSI Event                          | Set in SIMODE0 and SIMODE1                                             | Yes   | SCSIINT    | NONE       |
| Sequencer Event                     | Always enabled                                                         | Yes   | SEQINT     | NONE       |
| Command<br>Complete                 | Always enabled                                                         | No    | CMDCMPLT   | NONE       |
| Software                            | Always enabled                                                         | No    | NONE       | NONE       |

# Power-down

Power may be conserved by degating the clocks to most of the chip. Setting POWRDN (bit 6, HCNTRL) will cause the chip to minimize the use of CLKIN and PCLK signals. Limit the Device space register access and disable any interrupts that may be generated independent from the clock. Interrupts pending in this case will drive IRQA# as soon as POWRDN is cleared. The sequencer must be paused before setting POWRDN.

# **Diagnostics**

Upon power-on, the driver or BIOS will perform a series of diagnostics to the chip to ensure proper operation. This involves a series of register and RAM verifications as well as diagnostic code which will verify the sequencer and internal data path. Table 5-6 lists the series of tests.

Table 5-6. Diagnostics

| Test Performed                         | Action Taken                                               |
|----------------------------------------|------------------------------------------------------------|
| Sequencer RAM Check by Driver          | Driver verifies sequencer RAM through Host interface       |
| Scratch and SCB RAM Check by Driver    | Driver verifies scratch and SCB RAM through Host interface |
| Data FIFO Check by Driver              | Driver verifies Host / FIFO interface                      |
| Register Check by Driver               | Driver verifies Write/Read registers where possible        |
| Sequencer Instructions                 | Diagnostic code is loaded to verify sequencer operation    |
| Register Check by Sequencer            | Sequencer verifies Write/Read registers where possible     |
| Scratch and SCB RAM check by Sequencer | Sequencer verifies scratch and SCB RAM                     |
| Data FIFO Check by Sequencer           | Sequencer verifies Write/Read ability                      |
| Data Path                              | Sequencer transfers data through data FIFO/SCSI interface  |
| Interrupts                             | Driver verifies proper interrupt operation                 |
| Queue In/Queue Out                     | Driver verifies proper operation                           |
| Power Down Mode                        | Driver verifies power down nonoperation                    |
| PCI Address Parity Error               | Driver verifies proper error detection operation           |
| PCI Data Parity Error                  | Driver verifies proper error detection operation           |

# **6** Application Notes

# **About This Chapter**

Read this chapter to find out

- The phases that occur on the SCSI bus
- The purpose of the data FIFO
- The instruction set for programming the sequencer (SCSI PhaseEngine)
- Command line definitions and formats

\* \* \* \* \* 6

# **Chip Initialization**

Certain hardware level features must be initialized before the device can be used. Following is a summary of those features. The actual value loaded in the registers depends on the application.

- PCI standard Configuration registers (COMMAND0, COMMAND1, CACHESIZE, LATTIME, BASEADR0, BASEADR1, EXROMCTL, INTLINSEL)
- PCI Device register (DEVCONFIG)
- Device space registers (DSCOMMAND, HCNTRL)
- Data FIFO Thresholds
- SCSI ID

## **SCSI Phases**

#### Arbitration/Selection

Arbitration and Selection are automatic hardware sequences which are started by the sequencer (SCSI PhaseEngine). Arbitration will retry after a failed arbitration until complete. When a Bus Free condition is detected, the SCSI BSY signal is asserted along with the SCSI ID of the device. If no other higher priority IDs are on the SCSI bus and SEL is not active, the device will assert SEL with the device and target IDs, and drop BSY. After arbitration, the Selection phase will be entered using the target ID which is loaded in SCSIID. The attention bit will be driven during the Selection phase if ENAUTOATNO (bit 3, SCSISEQ) is set.

## **ID Message**

The next usual event on the SCSI bus is the Message Out phase. If ATN is active, the ID message is sent by the device. The driver has control over the content of the message and may disable disconnection by setting a bit in the SCB. If the Attention signal is not driven during the Selection phase, then this phase is not entered by the Target.

The driver may also execute synchronous negotiation or wide negotiation with this Target after the ID message is sent by setting the appropriate bit in the synchronous or wide control byte in scratch RAM. The sequencer will interrupt with the proper interrupt status. The sequencer will also interrupt if it needs assistance to execute an Extended message. The driver will handle the Extended message and then release the sequencer to complete the command.

#### Command

After the Message Out phase or Selection phase, the Command phase is usually entered. The sequencer gets the command pointer from the SCB area which was loaded by the driver, and the number of bytes are sent that the Target asks for up to the limit in the command byte count in the SCB. The command is sent to the SCSI bus by using the Bus Master DMA mechanism.

#### **Data Phase**

The phase should be Data In or Data Out at this time. The driver will set up the data path for a write or read operation and the SCSI sequencer will send data when it arrives or receive data when it comes if the phase matches with the expected phase. The number of bytes is loaded into a 24-bit counter which is counted down during the Data phase. This counter is examined by the sequencer after the Data phase for correctness. SDONE in SSTAT2 will be set if the counter has a zero value. An interrupt will be generated by the sequencer to indicate an underrun or overrun condition. The sequencer will calculate the residual count on an underrun.

**Note:** The transfer speed and control signal widths are dependent on the input clock frequency.

#### Disconnection

The sequencer will handle all disconnections. The SCB contains the address pointer and byte counter for the particular transfer. If the Save Data Pointers message is received, the current value is saved in the SCB area. If the Disconnect message is received without the Save Data Pointers message, the value in the SCB area is not changed. The sequencer will mark the SCB as a disconnected command so it may be found at reconnect time.

#### Reconnection

Reselection should always be enabled when there is an outstanding command. When a Target reselects the device, the sequencer will get the LUN from the ID message and attempt to match the target ID, channel and LUN to a disconnected SCB. If one is found the tag enable bit in the control byte is checked, and if enabled, the tag value is received and the correct SCB is continued. The sequencer will then follow the target's phase and if the Data phase is entered the address pointer and byte counter will be loaded and the transfer continued from where it was left off. If a match is not found, then the host will be interrupted.

## **Modify Data Pointers**

The AIC-7850 will support the Modify Data Pointers message if the Scatter/Gather list count is equal to one. The sequencer will accept the 2's complement value from the Target and add it to the current host address pointer.

If the Scatter/Gather list count is greater than one for the present command, then the sequencer will send a Message Reject message when the Modify Data Pointers message is received.

#### **Status**

The Status phase is handled by the sequencer, and the status byte is saved in a SCB location for examination later by the driver. If the status value or the Command Complete message is nonzero, the driver will be interrupted after the command complete message is received.

## **Command Complete Message**

The Command Complete message is sent to the Initiator after the Status phase. This is handled by the sequencer and causes a command complete status bit to be set for the firmware along with a CMDCMPLT interrupt. A Linked Command Complete message will cause a SEQINT with the appropriate code.

## Scratch RAM Definition

The scratch RAM area contains general-purpose RAM area used during the execution of commands and to store configuration data which describes the system setup.

# **Multithreaded Operation**

More than one target device may have commands open but disconnected. The sequencer will match the Target/Channel/LUN when a new SCB ID is received from the QINFIFO. In order to preserve the order of execution for any Target/LUN combination, the

restriction is made that no more than two SCBs with the same Target/Channel/LUN identification be loaded in the device. This restriction does not apply to tagged commands. Before any commands are executed or after a disconnection, the sequencer will look to see if there is another command to execute on the QINFIFO. If there is and the Target/Channel/LUN matches an open command, the ID will be pushed back on the QINFIFO. If there are more commands ready to be executed, they will be started. When reselection occurs a search for a disconnected command with the same Target/Channel/LUN is made and when found, the command is continued. In the case of tagged commands, the number of commands to the same Target/Channel/LUN may equal the space in the SCB Array. The commands will be sent with the tag value generated by the sequencer. Upon reselection, the sequencer will match Target/Channel/LUN/tag before completing the command.

## Scatter/Gather

Scatter/Gather will be implemented as a part of the normal sequencer program. A Scatter/Gather transfer is characterized by using a list of data segments which the device uses to transfer data to or from the SCSI bus. The list is composed of 1 to 255 elements. Each element consists of a segment data pointer (4 bytes) and a segment byte count (4 bytes). All data transfers will be Scatter/Gather transfers. The Scatter/Gather list pointer is always valid and will be used to obtain the elements of the list. Each segment will be transferred as a stand-alone entity until the number of segments transferred is equal to the Scatter/Gather segment count. The segment byte count will be loaded into STCNT and HCNT, and the segment data pointer will be loaded into HADDR and SHADDR and the transfer will be started. When the SCSI counter is zero, the next segment data pointer and segment byte count will be read from host memory using the list pointer. The sequencer will then load the new values in the hardware and start the transfer in the normal manner. After a write operation, when STCNT is zero, and SDONE is set, SCSI FIFO is reset when SDMAEN is cleared. This is to clear any residual read ahead data in preparation for the next segment transfer. A read operation does not affect the SCSI FIFO when SDMAEN is cleared.

The working values of the list pointer and segment count value are stored in temporary scratch RAM area. The current value of the segment data pointer is gotten from SHADDR and the value of the segment byte count is gotten from SCNT. If a Save Data

Pointers message is received before the Disconnect message, the working values will be saved in the SCB area. If a Disconnect message is received without a Save Data Pointers message, then the current value in the SCB area is not modified.

# **Tagged Queuing**

In order to execute a tagged command, the tag enable bit in the control byte of the SCB must be set. The type of tag is also indicated by coding bits 0 and 1 of the same byte. A 00 means a simple queue is intended, a 01 means a Head of Queue message will be sent, and a 10 means an Ordered Queue message will be sent. The tag value will be the ID of the SCB. The Tag message will be sent after the ID message with the tag value if the tag enable bit is set. On reconnection, the search will be made for the disconnected SCB for the Target/Channel/LUN, and if the tag enable bit is set, a Tagged Queue message will be expected. Once the tag value is received, the correct SCB is chosen and the command is resumed.

# Using the FIFO Threshold Control

The purpose of the data FIFO is to buffer the data in such a way to keep data streaming from one bus to the other. The rate of transfer of the SCSI and host buses will generally be different, and so the data FIFO is also providing the additional functions of speed matching and minimal host bus time usage by bursting data at the host bus maximum rate. Another independent variable is the latency of the host bus. It may take more or less time to gain control of the bus, depending on how busy other devices on the bus may be. In general one may include the host latency and transfer rate and generally set up the device for one of three situations of various degrees; a slow host and fast SCSI, slow SCSI and fast host, or equal-speed host and SCSI. The rates will be determined for each device by the driver and the information will be passed to the sequencer firmware.

DFTHRSH0/1 are defined (bits 6 & 7, PCISTATUS) to set the transfer threshold at different places. The possible settings are outlined below with suggestions on their usage.

■ DFTHRSH1, DFTHRSH0: 0,0—SCSI is much faster than the host.

Write operation - In this case, one would like to keep the host on the bus as much as possible, since it will be the limiting factor. In this case, the host transfer logic will start transmitting as soon as there is room in the FIFO, since we know the SCSI device will empty it faster than the host can fill it.

Read operation - In this case, one would like to read data from the FIFO as soon as there is something in it, since we know the SCSI device will fill it up faster than the host can empty it.

■ DFTHRSH1, DFTHRSH0: 0,1—Nearly equal speeds, SCSI is faster than or equal to host.

Write operation - When the FIFO empties to 50% full, the host transfer logic will request the bus and transfer till the FIFO is full.

Read operation - When the FIFO fills to 50% full, the host transfer logic will request the bus and transfer till the FIFO is empty.

■ DFTHRSH1, DFTHRSH0: 1,0—Nearly equal speeds, SCSI is slower than or equal to host

Write operation - When the FIFO empties to 75% empty, the host transfer logic will request the bus and transfer till the FIFO is full.

Read operation - When the FIFO fills to 75% full, the host transfer logic will request the bus and transfer till the FIFO is empty.

■ DFTHRSH1, DFTHRSH0: 1,1—Host is much faster than SCSI.

Write operation - In this case, the FIFO is empty before the host transfer logic will request the bus in order to minimize the host bus activity, since we know it will be some time before the SCSI device can empty it.

Read operation - In this case, the FIFO is full before the host transfer logic will request the bus, since we can empty it out long before the SCSI device can fill it up.

# **Contingent Allegiance**

In the event that an error occurs on the Target, a check condition will be sent to the Initiator in the status byte. In this case, sense information will be kept by the Target pertaining to the command which was in error for the Initiator which sent the command. This information will be kept until the next command is sent. The sequencer will interrupt the driver and pause upon receipt of any nonzero status from the Target after the command completes. The driver will get all information from the SCB and then reload the SCB area with a SCSI Sense command. The driver will then restart the sequencer at the point where it will execute the Sense command.

## **Abort**

When a driver receives an abort request, the command could be in several states of execution. It may be in the driver's own queue, in the QINFIFO, in the SCB Array but disconnected, or active on the SCSI bus. If the command is in the driver's own queue, it need only remove it and report completion. If it is not there, the driver will pause the sequencer and search the QINFIFO first. If the command is there, the driver need only remove that entry from the queue and unpause the sequencer. If the command is in the SCB Array and either waiting for selection or disconnected, the driver need only clear those status bits. When the sequencer responds to the selection or reselection, it will discover that there is no command available and will issue the Abort message on the SCSI bus. If the command is active at the time, the driver will need to recover by sending an Abort message, completing the command, or resetting the SCSI bus.

# **Retry on Busy**

There are occasions when a SCSI command will terminate with a busy bit set in the status byte. The sequencer will interrupt with nonzero status. The driver will handle the option of retrying the command or reporting the error to the original caller.

# **Command Linking**

SCSI Command Linking may be implemented by the driver. The sequencer will respond with an Unknown Message In interrupt. The driver will reload the SCB area with the new SCB and restart the sequencer at the entry which will execute the new command.

# **Target Mode**

SCSI Target mode is supported by the SCSI block in the AIC-7850. The initial firmware/driver does not support Target mode, but may be implemented with some code to handle the Select-In sequence on the SCSI bus. The sequencer would respond to selection, accept the ID and SCSI Command, and then disconnect. Detection of a Select-In would interrupt the driver to pass the Initiator/LUN information. The driver would prepare a Target command to pass data and complete the handshaking of the command. This requires additional sequencer code.

# 7 Design Notes

# **About This Chapter**

Read this chapter to find out

Register access exceptions

# ··· · 7

## I/O Decodes

Most registers will be accessible to both the sequencer (SCSI PhaseEngine) and the driver. There are some exceptions, however, where some registers will be accessible to the driver but not the sequencer and vice versa. Also there are some registers which the driver should be allowed to read or write without disturbing the sequencer (no pause). Below is a list of the exceptions.

- Host Control (HCNTRL), read or write by host only without pause or AAP
- Device Space Vendor ID (DSVENDID)[1:0], read by host only without pause or AAP
- Device Space Device ID (DSDEVID)[1:0], read by host only without pause or AAP
- Device Space Clear Interrupt (CLRINT), write by host only without pause or AAP
- Device Space Interrupt Status (INTSTAT), read by host only without pause or AAP, concurrent write by sequencer
- Device Space Error Status (ERROR), read by host only without pause or AAP
- Device Space Queue Out FIFO (QOUTFIFO), read by host only without pause or AAP, concurrent write by sequencer
- Device Space Queue Out Count (QOUTCNT), read by host only without pause or AAP, concurrent write by sequencer
- Device Space SINDIR is not usable by the host
- Device Space DINDIR is not usable by the host
- All Configuration space registers, read/write by host only without pause or AAP

# **About This Chapter**

Read this chapter to find out

- The Hardware Test modes and features used in the AIC-7850 to facilitate production testing
- A detailed explanation of each of the test groups and configurations

\*\*\*\* 8

## **Overview**

This section is a description of the Hardware Test modes and features used in the AIC-7850 to facilitate production testing. It contains a description of the special hardware configurations designed into the AIC-7850. A complete list of the functional and other tests written for this purpose is contained in the AIC-7850 Test Definition Document.

The AIC-7850 consists of six basic sections: SCSI, Sequencer (SCSI PhaseEngine), Host, Data FIFO, SCB RAM, and Scratch RAM. All registers are available to the host computer (except 2) and to the sequencer (except for 11), but not at the same time. Most of the chip may be tested through the host interface. The rest can be tested by loading a Sequencer Test program and running it.

The AIC-7850 contains special circuitry to help test input and output current levels.

Most of the signals connect to buses and should contain additional capacitive and resistive loading. These are detailed in a later section.

Some of the pins will change definition under certain test conditions. This is to allow the tester to see internal signals to shorten test time.

# **Test Register Description**

This section summarizes the registers which have been implemented specifically to enhance the testability of the device. The usage of these registers is detailed in the following sections.

The following conventions are used throughout this section:

- **set:** Indicates that the bit was loaded with a 1
- cleared: Indicates that the bit was loaded with a 0
- (0): Indicates that the bit is cleared when the reset pin is active
- (1): Indicates that the bit is set when the reset pin is active
- (x): Indicates that the bit is in an unknown state after the reset condition

# SCSI Test Control (SCSITEST)

**Type:** R/W **Address:** I-034Fh, E-zC0Fh, C-0Fh

This register is used to force test modes in the SCSI Module Logic.

| 0Eh SCSITEST<br>W |          |  |  |  |
|-------------------|----------|--|--|--|
| 7                 |          |  |  |  |
| 6                 |          |  |  |  |
| 5                 |          |  |  |  |
| 4                 | DATALOOP |  |  |  |
| 3                 |          |  |  |  |
| 2                 | RQAKCNT  |  |  |  |
| 1                 | CNTRTEST |  |  |  |
| 0                 | CMODE    |  |  |  |

| Bit |     | Name     | Definition                                                                                                                                                                                                                                                              |
|-----|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5 | (0) | Not Used |                                                                                                                                                                                                                                                                         |
| 4   | (0) | DATALOOP | When set to one, the SCSI data transfer may be controlled to transfer from the data FIFO through the SCSI block to the sequencer or in the reverse direction to test the data path and controls. The sequencer, in effect, acts like a Target to control the transfer.  |
| 3   | (0) | Not Used |                                                                                                                                                                                                                                                                         |
| 2   | (0) | RQAKCNT  | This bit is used to select STCNT or RQAKCNT values to test counter activity.                                                                                                                                                                                            |
| 1   | (0) | CNTRTEST | When set to one, the SCSI transfer counter STCNT and the selection time-out counter SELTIMER are put into a mode where they count down at the input clock rate, and the SCSI host address counter SHADDR is put into a mode where it counts up at the input clock rate. |
| 0   | (0) | CMODE    | When set to one, forces a stage-to-stage carry true in STCNT, SHADDR, and SELTIMER. During the Transfer Count test, the counter contents can be monitored by reading the desired stage.                                                                                 |

# **Selection Time-out Timer (SELTIMER)**

Type: R

**Address:** I0358h, E-zC18h, C-18h

This register is used to monitor the state of the hardware selection time-out timer.

| 0358 SELTIMER |         |  |  |  |
|---------------|---------|--|--|--|
| 7             | CLKOUT  |  |  |  |
| 6             |         |  |  |  |
| 5             | STAGE 6 |  |  |  |
| 4             | STAGE 5 |  |  |  |
| 3             | STAGE 4 |  |  |  |
| 2             | STAGE 3 |  |  |  |
| 1             | STAGE 2 |  |  |  |
| 0             | STAGE 1 |  |  |  |

| Bit |     | Name     | Definition                                       |
|-----|-----|----------|--------------------------------------------------|
| 7   | (0) | CLKOUT   | See register bit definition section for details. |
| 6   | (0) | Not Used | Always reads 0.                                  |
| 5   | (0) | STAGE 6  | (/2, output)                                     |
| 4   | (0) | STAGE 5  | (/2, output)                                     |
| 3   | (0) | STAGE 4  | (/2, output)                                     |
| 2   | (0) | STAGE 3  | (/10, output)                                    |
| 1   | (0) | STAGE 2  | (/256, output)                                   |
| 0   | (0) | STAGE 1  | (/256, output)                                   |

## **Special Function (SFUNC)**

**Type:** R/W (CIOBUS)

Address: I-135Fh, E-zC9Fh, C-9Fh

SFUNCT bits [4:0] select certain sections of the chip for test purposes. SFUNCT register bits 0 and 3 can only be set (=1) in a component test environment as test logic will be activated that redefines output pad functions. Writing to the SFUNCT register to set bits 0 and/or 3 (=1) requires TRDY#, DEVSEL#, and STOP# to be pulled low during the previous RST# assertion and stay at that state at least one PCLK cycle after RST#'s negation to activate an internal TESTBITEN status. This status will remain active until the next RST# assertion with at least one of the signals TRDY#, DEVSEL#, or STOP# is allowed to float, the normal condition has an internal pull-up. When TESTBITEN status is active, the value written to SFUNCT register will not take effect until two PCLKs after the PCLK that deasserts TRDY#. When TESTBITEN is not active, the written value will take effect on the PCLK that deasserts TRDY#. This delay, when present, must be taken into account when reading SFUNCT register or performing the selected test. This delay is provided so that the component tester that is performing the Write to Select tests, that will redefine the pin functions, will have an opportunity to switch from driving the pins that will be redefined to monitoring those pins without contention. SFUNCT register is cleared to 00h when RST# is asserted except when Input Pad is selected. To clear Input Pad tests, perform a write with value 00h or the next test value to the SFUNCT register, or write to CHIPRST=1. PCI pins are always high impedance when RST# is asserted for normal operation (except when component tests Input Pad test is selected).

| SFUNCT<br>R/W |          |  |  |  |
|---------------|----------|--|--|--|
| 7 SFUNCT2     |          |  |  |  |
| 6             | SFUNCT1  |  |  |  |
| 5 SFUNCTO     |          |  |  |  |
| 4 TESTRAM     |          |  |  |  |
| 3 TESTHOST    |          |  |  |  |
| 2 TESTSEQ     |          |  |  |  |
| 1 TESTFIFO    |          |  |  |  |
| 0             | TESTSCSI |  |  |  |

# **Test Group Description**

The following sections explain in greater detail each of the test groups and configurations. Table 8-1 explains the defined values which are loaded into SFUNCT and the tests they represent. CSDAT(7:0) is an internal bus which is made available to external pins SCD[7:0] in order to facilitate the test process.

Table 8-1. Test Group Description

| Data<br>(7:0) | HTEST | REF | Test<br>Monitor | Definition                                   |
|---------------|-------|-----|-----------------|----------------------------------------------|
| 00            | -     |     | N               | Normal Operation                             |
| 02            | -     | abe | N               | Enable data FIFO Quad Word Write             |
| 04            | -     | ae  | N               | Sequencer ALU Output Monitor Test            |
| 62            |       | d   | N               | Data FIFO Cache Logic Control Test           |
| D4            | •     | ae  | N               | Sequencer RAM Parity Test                    |
| F4            | -     | ae  | N               | Sequencer RAM Data Test                      |
| 0C            | 4     | ab  | M               | Sequencer ALU Output Monitor Test            |
| 29            | 1     | ac  | 1               | Input Pad Test                               |
| 49            | 2     | ac  | N               | Output Pad High Voltage Test                 |
| 69            | 3     | ac  | N               | Output Pad Low Voltage Test                  |
| 88            | 4     | а   | M               | HCNT[2:0] and Decode Test                    |
| A8            | 5     | а   | М               | LHADDR[3:0] and Decode Test                  |
| C2            |       | d   | M               | Data FIFO Cache Logic Monitor Test           |
| DC            | 6     | а   | М               | Sequencer RAM Parity Test                    |
| E2            |       | d   | М               | Data FIFO Cache Logic Control & Monitor Test |
| FC            | 7     | а   | М               | Sequencer RAM Data Test                      |

a = PHOST b = Sequencer c = SCSI d = Data FIFO

e = Tests modes that are also usable in normal system environment

N = None M = SCD[7:0] I = IRQA#

## Input Pad Testing

#### **Input Pad Test**

When a write is performed to place the AIC-7850 in this test mode, all input pads are connected in an ANDed string which is connected to output pad IRQA# for input threshold testing. This allows one input to be tested at a time. When all inputs in the string are at the input high level, IRQA# output will also be at an output high level. Placing any one input at an input low level will cause IRQA# output to also go to an output low level.

**Note:** PCLK input must be held at a low level to allow changes on the level of other inputs to be seen on IRQA# output pin.

While in the AIC-7850 Input Pad test selection, the reset of the SFUNCT register caused by RST# has a modified action to allow testing of the RST# input and at the same time prevent clearing of the Input Pad test selection. A write to SFUNCT register or CHIPRST may be used to exit from this test mode.

ANDed Input Pad Strings List

IRQA#:GNT#, PCLK, CBE3#, AD31 - AD24, IDSEL, CBE2#, AD23 - AD16, FRAME#, IRDY#, TRDY#, DEVSEL#, STOP#, PERR#, PAR, CBE1#, AD15 - AD08, CBE0#, AD07 - AD00, RST#, PREQ#, IO#, REQ#, CD#, SEL#, MSG#, RESET#, ACK#, BSY#, ATN#, SCD7# - SCD0#, SCDPL#, CLKIN

#### **Output Pad Voltage High Test**

When a write is performed to place the AIC-7850 in this test selection, all output pads are enabled and controlled to place the outputs at an output high level two PCLKs after the PCLK that deasserts TRDY#.

**Note:** Care should be taken not to exceed the total expected current for the normal quantity of driven outputs when applying output test load current.

Read or write cycles are prohibited after the write that placed the AIC-7850 in this selection and assertion of RST# or GNT# is required to exit from this test selection.

#### Output Pad Voltage Low Test

When a write is performed to place the AIC-7850 in this test selection, all output pads are enabled and controlled to place the outputs at an output low level two PCLKs after the PCLK that deasserts TRDY#.

**Note:** Care should be taken not to exceed the total expected current for the normal quantity of driven outputs when applying output test load current.

Read or write cycles are prohibited after the write that placed the AIC-7850 in this selection and assertion of RST# is required to exit from this test selection.

## **Host LHADDR Testing**

#### Host LHADDR(3:0) And Decode Test

When this test is selected the LHADDR address counter is segmented into bytes which are incremented with each rising edge of PCLK.

**Note:** The carry-in logic between bytes and the logic which normally controls counting by 1, 2, 3, 4 in master operation are not tested in this test selection.

Performing reads from LHADDR[3:0] will allow access to the counter values. Timer LATT is clocked by PCLK. A write to SFUNCT register or RST# may be used to exit from this test mode. The LHADDR counter byte carry-outs are observable on the SCD[7:0].

```
SCD0 (CSDAT0) = LHADDRCOA

SCD1 (CSDAT1) = LHADDRCOB

SCD2 (CSDAT2) = LHADDRCOC

SCD3 (CSDAT3) = SCL

SCD4 (CSDAT4) = ECL

SCD5 (CSDAT5) = ECLMF

SCD6 (CSDAT6) = ECLPF

SCD7 (CSDAT7) = ECLME
```

## **Host HCNT Testing**

#### Host HCNT(2:0) And Decode Test

When this test is selected the HCNT byte counter is segmented into bytes which are decremented with each rising edge of PCLK.

**Note:** The carry-in logic between bytes and the logic which normally controls counting by 1, 2, 3, 4 in master operation are not tested in this test selection.

Performing reads from HCNT[2:0] will allow access to the counter values. A write to SFUNCT register or RST# may be used to exit from this test mode. The HCNT counter byte carry-outs are observable on the SCD[7:0].

```
SCD0 (CSDAT0) = HCNTCOA

SCD1 (CSDAT1) = HCNTCOB

SCD2 (CSDAT2) = HCOTTH

SCD3 (CSDAT3) = HCOTF

SCD4 (CSDAT4) = HCOTE

SCD5 (CSDAT5) = HCLTCL

SCD6 (CSDAT6) = SCL

SCD7 (CSDAT7) = ECL
```

## **Sequencer Testing**

This capability is also provided for certain test modes when the SFunction register contains values of 0ch, 1ch, 88h, A8h, Dch, and Fch.

#### **Sequencer ALU Test**

The sequencer is loaded with code to test the internal logic of the block. These tests check the operation of the AND, OR, ADD, and JUMP instructions. CSDAT[7:0] is monitored to detect any unexpected results from the self-check.

#### **Sequencer RAM Parity Test**

Data is written to the sequencer RAM and read back. The parity bit is available on CSDAT0.

#### Sequencer RAM Data Test

Various patterns are written to the sequencer RAM and read back for verification.

#### Sequencer RAM Leakage Test

A special test sequence is performed to verify proper operation of RAM cell data storage capability.

The AIC-7850 TESTRAM procedure is run at wafer/package level and may also be run in demand type diagnostic level in the system. Its purpose is to write a test data value to a block RAM location. Place TESTRAM bit in the active state. Then write to the same block RAM location the second time with the same data. This will cause the CIOBUS logic in the block containing the RAM to enter a TESTLOCK state, (which latches the supplied CDDAT[7:0] data, the CDADR[7:0]- address, the RAM WE- input active and places the RAM cell TEST- input in the active state). The RAM when accessed in this manner will stress the addressed RAM location storage capability. The recommended minimum stress time period is 500ns. The stressed RAM location is then read to verify the stored data is still the same as originally stored. While in the TESTLOCK state the block containing the RAM is disconnected from the destination side of the CIOBUS with normal operation continuing on the source side of the CIOBUS. Placing TESTRAM in the inactive state will clear the latched states and return the block's destination side of the CIOBUS back to normal. Multiple blocks containing RAM may have a location stressed at the same time to shorten the overall test time. Block RAM that may be read 8-bits at a time may be verified directly with the CSDAT bus. RAM that is wider than 8 bits or not dual-ported will need additional logic to provide the compare function, with the compare output status accessed by the CSDAT bus.

## **SCSI Testing**

- When TESTSCSI is active, the external SCSI bus pins may be redefined for test purposes (reference SFUNCT register values 29, 2B, 49, 69). This redefinition may only be performed in a test environment where the redefinition will not affect system operation. TESTSCSI is placed in the active state (=1) when TESTBITEN is active by performing a write cycle to the SFUNCT register with D0 asserted).
- The SCSI block also has a test register within its own block that operates independently of SFUNCT register.

## FIFO Testing

#### **Enable Data FIFO Quad Word Write**

When TESTFIFO is active and SFUNCT<2:0>=0, CIOBUS writes to DFDAT will cause 64-bit writes to occur in the data FIFO with the 8-bit data value on the CSDAT bus written in parallel to each byte of the 64-bit data FIFO location pointed to by DFWADDR value. The DFWADDR value will increment following each write. This test feature shortens the data FIFO RAM test data load time for initializing data FIFO RAM parity and doing RAM data tests or for writing a constant data value to all RAM locations.

- DFDAT must be enabled for writing from the CIOBUS (reference DFCNTRL register).
- Reading DFDAT by the sequencer or the host is always 8 bits per read.

#### **Data FIFO Cache Logic Control**

When this test is selected the DFCACHE<1:0> inputs of the cache logic will be forced to 00. This is a special condition that cannot be exercised in the normal function.

**Note:** The special condition is (1) WRITE direction (2) DFCACHE<1:> = 00. Therefore, the DIRECTION bit of DFCNTRL register needs to be set to test this special condition.

#### Data FIFO Cache Logic Monitor Test

When this test is selected the cache logic outputs are observable on the SCD[7:0].

```
SCD0 (CSDAT0) = DCLMR
SCD1 (CSDAT1) = DCLMS
SCD2 (CSDAT2) = DCMR
SCD3 (CSDAT3) = DCMS
SCD4 (CSDAT4) = DCLA
SCD5 (CSDAT5) = DCS
SCD6 (CSDAT6) = ANSEQ
SCD7 (CSDAT7) = ANSCSI
```

#### **Data FIFO Cache Logic Control and Monitor Test**

When this test is selected the DFCACHE<1:0> inputs of the cache logic will be forced to 00. This is a special condition that cannot be exercised in the normal function. Also, the cache logic outputs are observable on the SCD[7:0].

**Note:** The special condition is (1) WRITE direction (2) DFCACHE<1:> = 00. Therefore, the DIRECTION bit of DFCNTRL register needs to be set to test this special condition.

```
SCD0 (CSDAT0) = DCLMR
SCD1 (CSDAT1) = DCLMS
SCD2 (CSDAT2) = DCMR
SCD3 (CSDAT3) = DCMS
SCD4 (CSDAT4) = DCLA
SCD5 (CSDAT5) = DCS
SCD6 (CSDAT6) = ANSEQ
SCD7 (CSDAT7) = ANSCSI
```

Electrical Information

# **About This Chapter**

Read this chapter to find out

- Electrical information about the AIC-7850
- PCI bus timing diagrams for the AIC-7850

# **Absolute Maximum Ratings**

Storage Temperature: -65°C to 150°C

Power Supply Voltage: 0 to 7 V

Voltage on any Pin: -0.5 to VDD+0.5 V

# **Operating/Test Conditions**

Ambient Temperature: 0°C to 70°C Supply Voltage: 4.5 to 5.5 V

Supply Current (max.):

65 mA Active 45 mA Paused Power Down 5 mA < 5 ns  $\mathsf{t}_\mathsf{f}$  $t_r$   $C_L$ < 5 ns

50 pf unless otherwise noted



Figure 9-1. A.C. Input Conditions



C = 50 pf unless otherwise noted

Figure 9-2. A.C. Output Conditions

## **DC Parameters**

#### **PCI**

Ta = 0°C to 70°C  $VDD = 5 V \pm 10\%$ GND = 0 V

| Symbol | Definition            | Min  | Max     | Units | Test Condition        | Notes |
|--------|-----------------------|------|---------|-------|-----------------------|-------|
| Vcc    | Supply Voltage        | 4.50 | 5.50    | V     | -                     |       |
| Vih    | Input High Voltage    | 2.0  | Vcc+0.5 | ٧     |                       |       |
| Vil    | Input Low Voltage     | -0.5 | 0.8     | ٧     |                       |       |
| lii    | Input Leakage Current |      | +/- 10  | μА    | $V_{in} = 0$ to $VDD$ | 1     |
| Voh    | Output High Voltage   | 2.4  |         | ٧     | lout = -2 MA          |       |
| Vol    | Output Low Voltage    |      | 0.55    | ٧     | lout = 3 MA           | 2     |
| Vol    | Output Low Voltage    |      | 0.55    | ٧     | lout = 6 MA           | 3     |
| Cin    | Input Pin Capacitance |      | 10      | pf    |                       | 4     |
| Cdk    | PCLK Pin Capacitance  | 5    | 12      | pf    |                       | 4     |
| CIDSEL | IDSEL Pin Capacitance |      | 8       | pf    |                       | 4     |
| Lpin   | Pin Inductance        |      | 20      | nН    |                       |       |

<sup>&</sup>lt;sup>1</sup> Input leakage include hi-Z output leakage for bidirectional buffers with tri-state outputs. <sup>2</sup> Signals without pull-up resistors (AD[31:00], CBE[3:0]#, PAR).

Signal trace length on printed circuit board upon which the AIC-7850 is installed is 1.5-inches maximum from the package pin to the PCI bus (speedway) connection (except for PCLK signal trace which must be 2.5 +/- 0.1 inches.).

#### **SCSI**

 $Ta = 0^{\circ}C \text{ to } 70^{\circ}C$  $VDD = 5 V \pm 10\%$ GND = 0 V

| Symbol | Definition            | Min  | Max   | Units | Test Condition        | Notes |
|--------|-----------------------|------|-------|-------|-----------------------|-------|
| Vcc    | Supply Voltage        | 4.50 | 5.50  | V     | <del>" -</del> .      |       |
| lit    | Input Leakage Current |      | +/-10 | μА    | $V_{in} = 0$ to $VDD$ | 1, 2  |
| Vih    | Input High Voltage    | 2.0  |       | V     |                       |       |
| Vil    | Input Low Voltage     |      | 0.8   | ٧     |                       |       |
| Vihys  | Input Hysteresis      | 0.2  |       | V     |                       |       |
| Voh1   | Output High Voltage   | 2.4  |       | ٧     | lo1 = -400 μA         | 3     |
| Voh2   | Output High Voltage   | 2.4  |       | V     | lo2= -2MA             |       |
| Vol    | Output Low Voltage    |      | .5    | V     | lo3= 48MA             |       |

<sup>&</sup>lt;sup>1</sup> Input leakage include hi-Z output leakage for bidirectional buffers with tri-state output (SCD[7:0]#, SCDPL#, CD#, IO#, MSG#, REQ#, ACK#, RESET#, SEL#, BSY#, ATN#).

<sup>&</sup>lt;sup>3</sup> Signals with pull-up resistors (FRAME#, IRDY#, TRDY#, DEVSEL#, STOP#, PERR#, SERR#).

<sup>&</sup>lt;sup>4</sup> At 1 MHz.

<sup>&</sup>lt;sup>2</sup> Inputs are controlled to limit input current, see STPWEN.

<sup>3</sup> Outputs (BSY#, SEL#, RESET#).

## **STPWDN Pin**

 $Ta = 0^{\circ}C \text{ to } 70^{\circ}C$   $VDD = 5 \text{ V } \pm 10\%$  GND = 0 V

| Symbol      | Definition             | Min  | Max     | Units | Test Condition                         | Notes |
|-------------|------------------------|------|---------|-------|----------------------------------------|-------|
| Vcc         | Supply Voltage         | 4.50 | 5.50    | ٧     |                                        |       |
| <b>V</b> ih | Input High Voltage     | 2.0  | Vcc+0.5 | ٧     |                                        |       |
| Vil         | Input Low Voltage      | -0.5 | 0.8     | ٧     |                                        |       |
| lit         | Input Leakage Current  |      | +/-10   | μΑ    | Vin = 0 to $VDD$                       |       |
| lol         | Output Leakage Current |      | +/-10   | μΑ    | $V_{out} = 0.5 \text{ to } V_{\infty}$ |       |
| Voh         | Output High Voltage    | 2.4  |         | ٧     | lout = -24 MA                          |       |
| Vol         | Output Low Voltage     |      | 0.5     | ٧     | lout = 24 MA                           |       |

## **CLKIN Pin**

 $Ta = 0^{\circ}C \text{ to } 70^{\circ}C$   $VDD = 5 \text{ V} \pm 10\%$  GND = 0 V

| Symbol | Definition            | Min  | Max   | Units      | <b>Test Condition</b> | Notes |
|--------|-----------------------|------|-------|------------|-----------------------|-------|
| Vcc    | Supply Voltage        | 4.50 | 5.50  | ٧          |                       | -     |
| lit    | Input Leakage Current |      | +/-10 | μ <b>A</b> | Vin = 0 to $VDD$      |       |
| Vih    | Input High Voltage    | 2.0  |       | ٧          |                       |       |
| Vil    | Input Low Voltage     |      | .8    | ٧          |                       |       |

# **Signal Test Loads**

| Signals                                                                 | Circuit Values                                        |              |                                                |
|-------------------------------------------------------------------------|-------------------------------------------------------|--------------|------------------------------------------------|
| SCD[7:0]#, SCDPL#, RESET#, BSY#, SEL#, REQ#, MSG#, IO#, CD#, ATN#, ACK# | Capacitance                                           | 300          | pf                                             |
|                                                                         | Pull-up Resistor                                      | 110          | Ohm                                            |
|                                                                         | Pull-down Resistor                                    | 165          | Ohm                                            |
| FRAME#, TRDY#, IRDY#, STOP#, DEVSEL#, PERR#, SEER#                      | Capacitance                                           | 50           | pf max                                         |
|                                                                         | Pull-up Resistor                                      | 936          | Ohm min                                        |
|                                                                         | Pull-up Resistor                                      | 2.7          | KOhm typ                                       |
|                                                                         | Pull-down Resistor                                    | —            | —                                              |
| AD[31:00], CBE[3:0]#, PAR, PREQ#                                        | Capacitance<br>Pull-up Resistor<br>Pull-down Resistor | 50<br>—<br>— | pf max<br>———————————————————————————————————— |
| IRQA#                                                                   | Capacitance                                           | 50           | pf max                                         |
|                                                                         | Pull-up Resistor                                      | 1.5          | KOhm min                                       |
|                                                                         | Pull-down Resistor                                    |              | —                                              |
| STPWCTL#                                                                | Capacitance                                           | 50           | pf max                                         |
|                                                                         | Pull-up Resistor                                      |              | —                                              |
|                                                                         | Pull-down Resistor                                    | -            | —                                              |

# **AC Parameters**

## PCI Pin V/I Curves

PCI Output Driver DC Curves



Figure 9-3. PCI Signal 5 Volt Pull-up Output V/I Curves

#### PCI Output Driver DC Curves



Figure 9-4. PCI Signal 3 Volt Pull-up Output V/I Curves



Figure 9-5. PCI Signal 3 Volt/5 Volt Pull-down Output V/I Curves

PCI Input VIN vs. VOUT, Fast N, Slow P, and Slow N, Fast P, Always 5 volts



Figure 9-6. PCI Signal 5 Volt Input VIN Curves

PCI Bus Inputs VIN vs. VOUT, Fast N, Slow P and Slow N, Fast P, 3.3 Volt



Figure 9-7. PCI Signal 3 Volt/5 Volt at 3 Volt Input VIN Curves





Figure 9-8. PCI Signal 3 Volt/5 Volt Input at 5 Volt VIN Curves

PCI Input VIN vs. VOUT, Fast N, Slow P, and Slow N, Fast P, Always 5 volts △ PCI SPEC FST\_N SLW\_P 100 DEGREE V OUT SLW\_N FST\_P 0 DEGREE V OUT 5.50 -5.0 4.50 4.0 1 0 1 0 3.50 3.0 L I N 2.50 1.50 500.0M 2.0

Figure 9-9. PCI Signal PCI Clock 5 Volt Input VIN Curves

1.40

VOLTS (LIN)

1.60

1.80

1.20

1.0

800.0M

# **Clock Timing**



Figure 9-10. Clock Timing

$$Ta = 0^{\circ} \text{ to } 70^{\circ}\text{C}$$

$$VCC = 5 \text{ V} \pm 10\%$$

$$GND = 0 \text{ V}$$

| Symbol | Definition     | Min | Max | Units | Figure | Notes |
|--------|----------------|-----|-----|-------|--------|-------|
| t1a    | PCLK Period    | 30  |     | ns    | 9-10   | 1     |
| t1b    | PCLK High Time | 12  |     | ns    | 9-10   | 1     |
| t1c    | PCLK Low Time  | 12  |     | ns    | 9-10   | 1     |
| t1d    | PCLK Rise Time | 1   | 4   | ns    | 9-10   | 1     |
| t1e    | PCLK Fall Time | 1   | 4   | ns    | 9-10   | 1     |

 $<sup>^{1}</sup>$ t1a referenced to 1.5V, other times referenced to 0.8V and 2.0V.

$$Ta = 0^{\circ} \text{ to } 70^{\circ}\text{C}$$

$$VCC = 5 \text{ V } \pm 10\%$$

$$GND = 0 \text{ V}$$

| Symbol | Definition      | Min | Max | Units | Figure | Notes |
|--------|-----------------|-----|-----|-------|--------|-------|
| t2a    | CLKIN Period    | 25  |     | ns    | 9-10   | 1     |
| t2b    | CLKIN High Time | 7   |     | ns    | 9-10   |       |
| t2c    | CLKIN Low Time  | 8   |     | ns    | 9-10   |       |
| t2d    | CLKIN Rise Time |     | 3   | ns    | 9-10   |       |
| t2e    | CLKIN Fall Time |     | 3   | ns    | 9-10   |       |

 $<sup>^{\</sup>rm 1}$  t2a referenced to 1.5V, other times referenced to 0.8V and 2.0V.

# **PCI Bus Timing**



Figure 9-11. Reset Timing

Ta = 0 to 70 degrees C VCC = 5 Volts + /-5%GND = 0 Volts

| Symbol | Definition                              | Min | Max | Units | Figure | Notes |
|--------|-----------------------------------------|-----|-----|-------|--------|-------|
| t3a    | RST# Period                             |     |     |       | 9-11   | 1     |
| t3b    | PCLK active following RST# assertion    | 0   |     | ns    | 9-11   |       |
| t3c    | PCLK active preceeding RST# deassertion |     |     |       | 9-11   | 2     |
| t3d    | POR active following RST# assertion     |     | 12  | ns    | 9-11   | 3     |
| 13e    | POR inactive following RST deassertion  |     |     |       | 9-11   | 4     |
| t3f    | PCI Outputs Float Delay                 | 2   | 28  | ns    | 9-11   |       |
| t3g    | PREQ# Output Enable Delay               | 2   | 11  | ns    | 9-11   |       |

<sup>&</sup>lt;sup>1</sup> 8 PCLK cycles minimum. <sup>2</sup> 6 PCLK cycles minimum. <sup>3</sup> Internal reset active (asynchronous to PCLK).

<sup>&</sup>lt;sup>4</sup> Internal reset inactive (synchronous to PCLK).



" = 'T/S" type output used as "OUT" type output (only floated when RST# is asserted).

\*\* = O/D type output

Figure 9-12. PCI Signal Input Output Timing

Ta = 0 to 70 degrees C VCC = 5 Volts +/- 5% GND = 0 Volts

| Symbol      | Definition                                                                                        | Min | Max | Units | Figure | Notes |
|-------------|---------------------------------------------------------------------------------------------------|-----|-----|-------|--------|-------|
| t4a         | PREQ# Assertion Delay                                                                             | 2   | 12  | ns    | 9-12   |       |
| t4b         | PREQ# Deassertion Delay                                                                           | 2   | 12  | ns    | 9-12   |       |
| t4c         | AD[31:00], CBE[3:0]#, PAR Output<br>Valid Delay                                                   | 2   | 11  | ns    | 9-12   | 1     |
| t4d         | AD[31:00], CBE[3:0]#, PAR Output Float Delay                                                      | 2   | 28  | ns    | 9-12   |       |
| t4e         | FRAME#, IRDY#, DEVSEL#,<br>TRDY#, STOP#, PERR# Output<br>Assertion Valid Delay                    | 2   | 11  | ns    | 9-12   | 1     |
| <b>t</b> 4f | FRAME#, IRDY#, DEVSEL#,<br>TRDY#, STOP#, PERR# Output<br>Deassertion Valid Delay                  | 2   | 11  | ns    | 9-12   | 2     |
| t4g         | FRAME#, IRDY#, DEVSEL#,<br>TRDY#, STOP, PERR# Output<br>Float Delay                               | 2   | 28  | ns    | 9-12   |       |
| t4h         | SERR# Output Assertion Valid<br>Delay                                                             | 2   | 11  | ns    | 9-12   |       |
| t4i         | SERR# Output Deassertion Valid<br>Delay                                                           | 2   | 11  | ns    | 9-12   |       |
| t4j         | AD[31:00], CBE[3:0]#, PAR,<br>FRAME#, IRDY#, DEVSEL#,<br>TRDY#, STOP#, PERR# Input Valid<br>Setup | 7   |     | ns    | 9-12   |       |
| t4k         | AD[31:00], CBE[3:0]#, PAR,<br>FRAME#, IRDY#, DEVSEL#,<br>TRDY#, STOP#, PERR# Input Valid<br>Hold  | 0   |     | ns    | 9-12   |       |
| t4i         | GNT# Input Valid Setup                                                                            | 10  |     | ns    | 9-12   |       |
| t4m         | GNT# Input Valid Hold                                                                             | 0   |     | ns    | 9-12   |       |

Includes float to output enable delay.
 Starts s//s type output deassertion assurance period.