National Semiconductor

## DS3875 Futurebus + Arbitration Controller

## **General Description**

The DS3875 Futurebus + Arbitration Controller is a member of National Semiconductor's Futurebus+ chip set designed specifically for the IEEE 896.1 Futurebus+ standard. The DS3875 implements Distributed Arbitration and Distributed Arbitration messages in a single chip.

The DS3875 interfaces with Futurebus+ through the DS3885 BTL Arbitration Transceiver and the DS3884A BTL Handshake Transceiver. The DS3885 BTL Arbitration Transceiver incorporates the competition logic needed for the Arbitration Number signal lines. The DS3884A BTL Handshake Transceiver has selectable Wired-OR receiver glitch filtering. The DS3884A is used for the Arbitration Sequencing and Arbitration Condition signal lines

Additional transceivers included in the Futurebus+ chip set are the DS3883A BTL 9-bit Data Transceiver and the DS3886A BTL 9-bit Latching Data Transceiver. The DS3886A transceiver features edge-triggered latches in the driver which may be bypassed during a fall-through mode and a transparent latch in the receiver. The DS3883A transceiver has no latches in either direction.

The Logical Interface Futurebus + Engine (LIFE) I/O Protocol Controller with 64-bit Data Path incorporates the Compelled Mode Futurebus+ Parallel Protocol. The Protocol Controller handles all the handshaking signals between the Futurebus+ and the local bus interfaces, and incorporates a DMA Controller with built-in FIFOs for fast queueing.

#### Features

- The controller implements the complete requirements of the IEEE 896.1 specification as a subset of its fea-
- Supports Arbitration message sending and receiving
- Supports the two modes of operation (RESTRICTED/ UNRESTRICTED)
- Software configurable double/single pass operation, slow/fast, IBA/Parking and restricted/unrestricted modes of arbitration
- Built-in 1 µs timer for use in the arbitration cycle

- User programmable 16 arbitration delays (8 slow and 8 fast)
- Built-in PLL for accurate delays. The PLL accepts clocks from 2 MHz to 40 MHz in steps of 1 MHz
- Signal to unlock slave modules on transfer of tenure. Auto unlock through a dummy cycle if the current master locked resources
- Programmable delay for releasing ar\* after issuing COMPETE/IBA\_CMPT. This is to ensure the assertion of the arbitration number during competition, before the release of ar\*. Also this delay ensures there is sufficient time to assert the AD/DATA lines during Idle Bus Arbitration before the release of ar\*
- Read/Write facility with data acknowledge for the host to load arbitration numbers, an arbitration message, and control registers
- On chip parity generator unloads the host of the additional parity generation function
- Separate interrupts to indicate error occurrence and arbitration message received. Interrupts cleared on a register write. Error status is available in a separate status register
- A special output pin to indicate that a POWERFAIL message was received
- Hardwired register to hold the first word of the arbitration message
- FIFO strobe provided to store more than one arbitration message externally to prevent overrun
- Idle Bus Arbitration (IBA) supported
- Parking implemented
- Bus initialization, system reset and Live-insertion supported. (The logic to detect these conditions must be implemented externally.)
- Testability in the form of reading from key registers which include the STATE, MCW, 1 µs timer and programmable input clock divider



© 1995 National Semiconductor Corporation TL/H/10747 RRD-B30M115/Printed in U. S. A.

November 1995

| Table of Contents                                                               |
|---------------------------------------------------------------------------------|
| 1.0 INTRODUCTION TO FUTUREBUS +                                                 |
| 2.0 INTRODUCTION TO FUTUREBUS + ARBITRATION                                     |
| 2.1 The Arbitration States                                                      |
| 3.0 INTRODUCTION TO DS3875 ARBITRATION CONTROLLER                               |
| 3 1 Using the DS3875 in 896 1 Compliant Mode 7                                  |
|                                                                                 |
| 4.0 D53875 INTERFACES                                                           |
| 5.0 ARBITRATING FOR FUTUREBUS +                                                 |
| 5.1 Unrestricted/Restricted Modes of Operation                                  |
| 5.2 The Arbitration Number and Arbitration Circuit                              |
| 5.2.1 Priority Field (PR)                                                       |
| 5.2.2 Roulid Robin Field (II) 14                                                |
| 5.3 Arbitration Categories 14                                                   |
| 5.3.1 Competitor for the Parallel Rus 14                                        |
| 5.3.2 Competitor to Send a Message                                              |
| 5.3.2.1 Using an External FIFO to Store Messages                                |
| 5.3.3 By-Stander                                                                |
| 5.3.4 By-Stander who decides to invoke Preemption15                             |
| 5.3.5 Master                                                                    |
| 5.3.6 Master Elect                                                              |
| 5.4 Futurebus+ Optional Means of Arbitration                                    |
| 5.4.1 Idle Bus Arbitration (IBA)17                                              |
| 5.4.1.1 Masters Support Circuitry to Enable IBA                                 |
| 5.4.1.2 Modules Support Circuitry to Participate in IBA                         |
| 5.4.2 Parking                                                                   |
| 5.5 The Arbitration Phases                                                      |
| 5.5.1 Phase 0, Idle Phase                                                       |
| 5.5.1.1 Phase 0, Idle Bus Arbitration Events That Cause a Transition to Phase 1 |
| 5.5.1.3 Phase 0, Parking                                                        |
| 5.5.2 Phase 1. Decision Phase                                                   |
| 5.5.2.1 Phase 1. Idle Bus Arbitration Events That Cause a Transition to Phase 2 |
| 5.5.3 Phase 2. Competition Phase                                                |
| 5.5.3.1 Phase 2. Idle Bus Arbitration Events That Cause a Transition to Phase 3 |
| 5.5.4 Phase 3, Error Check Phase                                                |
| 5.5.4.1 Phase 3, Idle Bus Arbitration Events That Cause a Transition to Phase 4 |
| 5.5.5 Phase 4, Master Release Phase                                             |
| 5.5.6 Phase 5, Tenure Transfer Phase                                            |
| 6.0 THE DS3875 ARBITRATION CONTROLLER SUPPORT OF LOCKING AND UNLOCKING          |
| 7.0 REGISTER DESCRIPTION                                                        |
| 7.1 ALL1S                                                                       |
| 7.2 TCXN0                                                                       |
| 7.3 TCXN1                                                                       |
| 7.4 TXMSG                                                                       |
| 7.9 UINET                                                                       |

## Table of Contents (Continued)



| FIII       | # of Pins            | Туре   | Description                                                                                                                                                                                                                     |
|------------|----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SIGNAL TO  | FROM THE             | HANDSH |                                                                                                                                                                                                                                 |
| APO        | 1                    | 0      | Arbitration handshake signal from the controller.                                                                                                                                                                               |
| AQO        | 1                    | 0      | Arbitration handshake signal from the controller.                                                                                                                                                                               |
| ARO        | 1                    | 0      | Arbitration handshake signal from the controller.                                                                                                                                                                               |
| AC0O       | 1                    | 0      | Arbitration condition signal from the controller.                                                                                                                                                                               |
| AC1O       | 1                    | 0      | Arbitration condition signal from the controller.                                                                                                                                                                               |
| API        | 1                    | I      | Arbitration handshake signal from Futurebus +. This signal is the filtered and inverted version of the Futurebus + backplane signal AP*.                                                                                        |
| AQI        | 1                    | I      | Arbitration handshake signal from Futurebus + . This signal is the filtered and inverted version of the Futurebus + backplane signal AQ*.                                                                                       |
| ARI        | 1                    | I      | Arbitration handshake signal from Futurebus $+$ . This signal is the filtered and inverted version of the Futurebus $+$ backplane signal AR <sup>*</sup> .                                                                      |
| AC0I       | 1                    | I      | Arbitration condition signal from Futurebus + .                                                                                                                                                                                 |
| AC1I       | 1                    | I      | Arbitration condition signal from Futurebus + .                                                                                                                                                                                 |
| SIGNAL TO  | FROM THE ansceiver.) | ARBITR | ATION TRANSCEIVER (Note: These pins are mapped to/from the DS3885 Futurebus+                                                                                                                                                    |
| CN(7:0)    | 8                    | 1/0    | The bus to carry competition number to/from the arbitration transceiver.                                                                                                                                                        |
| CNp        | 1                    | 0      | Parity bit of the competition number.                                                                                                                                                                                           |
| CMPT*      | 1                    | 0      | Enables the Arbitration number onto Futurebus +.                                                                                                                                                                                |
| ABRE*      | 1                    | 0      | Direction control for the competition number bus to/from the transceiver.                                                                                                                                                       |
| CN_LE*     | 1                    | 0      | Latch enable for latching the Arbitration number from the controller into the transceiver.                                                                                                                                      |
| PER*       | 1                    | 1      | PARITY ERROR: Indicates that a parity error was detected on the winner's arbitration number                                                                                                                                     |
| WIN*_GT*   | 1                    | I      | Win signal when competing/greater than signal when not competing (used to preempt).                                                                                                                                             |
| ALL1*      | 1                    | I      | Indicates that all the arbitration number lines on the bus are asserted (used for messages).                                                                                                                                    |
| SIGNALS TO | O/FROM THE           | PARAL  | LEL PROTOCOL CONTROLLER                                                                                                                                                                                                         |
| BRQ*       | 1                    | Ι      | BUS REQUEST: Indicates to the controller to acquire the bus for the module's use.                                                                                                                                               |
| BGRNT*     | 1                    | 0      | <b>BUS GRANT:</b> Signal asserted by the controller after the detection of a bus request. The module can start using the bus.                                                                                                   |
| RINT*      | 1                    | I      | Will put the arbitration controller in phase 0 and release all the bus lines except AR*. A selective reset is performed. The rising edge will release controller from phase 0. This reset is to be used for bus initialization. |
| RST*       | 1                    | 1      | Reset signal from the host. An internal reset is performed. All bus signals are released. The rising edge will put the controller in phase 0 (same as power-up reset).                                                          |
| HALT*      | 1                    | I      | Will halt the arbitration controller in phase 0. This signal is for use during live insertion.                                                                                                                                  |
| ENDT*      | 1                    | I      | END OF TENURE: Indicates the true end of bus tenure of the current master. This line may be asserted only after all the parallel protocol lines are released. (Generated via external logic                                     |

| Pin Defii    | nition (Co | ontinued) |                                                                                                                                                                                                                                                                                                                      |
|--------------|------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin          | # of Pins  | Туре      | Description                                                                                                                                                                                                                                                                                                          |
| SIGNALS TO/F | ROM THE H  | IOST (CI  | PU Plus External Interface Logic)                                                                                                                                                                                                                                                                                    |
| DATA(7:0)    | 8          | 1/0       | Data bus for the host to access the register bank of the controller.                                                                                                                                                                                                                                                 |
| ADD(3:0)     | 4          | I         | Address bits for the register bank of the controller.                                                                                                                                                                                                                                                                |
| CS*          | 1          | I         | CHIP SELECT: The host can read or write to/from the controller.                                                                                                                                                                                                                                                      |
| R_W*         | 1          | Ι         | Read/write signal from the host.                                                                                                                                                                                                                                                                                     |
| DSACK*       | 1          | 0         | Data acknowledge pin for host read/write.                                                                                                                                                                                                                                                                            |
| SEL          | 1          | I         | <b>SELECT:</b> Determines how the controller latches in data. A "1" on the pin uses the rising edge of CS*. A "0" on the pin uses the falling edge of DSACK*.                                                                                                                                                        |
| MGRQ*        | 1          | Ι         | MESSAGE REQUEST: Indicates to the controller to send an arbitration message.                                                                                                                                                                                                                                         |
| MGTX*        | 1          | 0         | MESSAGE TRANSMIT: Indicates the successful transmission of an arbitration message.                                                                                                                                                                                                                                   |
| ERINT*       | 1          | 0         | ERROR INTERRUPT: Indicates that an error occurred during the arbitration cycle.                                                                                                                                                                                                                                      |
| MGINT*       | 1          | 0         | MESSAGE INTERRUPT: Indicates the reception of an arbitration message.                                                                                                                                                                                                                                                |
| PFINT*       | 1          | 0         | POWER FAIL INTERRUPT: Indicates that a powerfail message was received.                                                                                                                                                                                                                                               |
| EXTERNAL LO  | GIC        |           |                                                                                                                                                                                                                                                                                                                      |
| IBACMPT*     | 1          | 0         | Signal to indicate that the Parallel Protocol controller may assert its bit on the ADDRESS/<br>DATA bus if it is participating in an Idle Bus Arbitration.                                                                                                                                                           |
| IBA_S*       | 1          | I         | This signal indicates that IBA was successful. If this module was a competitor in the IBA competition (IBRQ*), then this module is the winner and now the bus master. If this module was the master, but did not compete in the IBA competition and IBA was successful, then the M bit (Status register) is negated. |
| AS_CANCEL    | 1          | I         | Indicates the start of the disconnection phase of the current master or cancel the current arbitration cycle.                                                                                                                                                                                                        |
| LKD*         | 1          | I         | <b>LOCKED:</b> Signal to indicate that resources have been locked in the current tenure and hence generate either a dummy cycle if current master or UNLK* otherwise. (Decoded from Futurebus + Command port output from Data Path Unit.)                                                                            |
| UNLK*        | 1          | 0         | <b>UNLOCK:</b> Transfer of tenure indication to the parallel protocol controller for unlocking its resources. Generated only if the LKD* signal is asserted. (To external logic.)                                                                                                                                    |
| FSTR*        | 1          | 0         | FIFO STROBE: Signal generated to load an external FIFO for received arbitration messages.                                                                                                                                                                                                                            |
| CLK          | 1          | I         | Clock input to the internal PLL.                                                                                                                                                                                                                                                                                     |
| C1           | 1          | I         | External capacitor input for PLL—0.1 $\mu$ F.                                                                                                                                                                                                                                                                        |
|              |            |           |                                                                                                                                                                                                                                                                                                                      |

## 1.0 Introduction to Futurebus +

Futurebus + is a high-performance asynchronous multiplexed address/data backplane bus designed by the IEEE 896.1 committee for use in a wide variety of multiprocessor architectures. The Futurebus + standard is a next generation backplane bus standard developed to a set of requirements including openness, performance, and system facilities and flexibilities so as not to hinder systems using this bus for many generations of computer systems. Futurebus + is a single cache coherent backplane architecture featuring scalability, technology independent protocols, and explicit provisions to extend to future applications. Requirements set for the Futurebus + architecture by the IEEE 896.1 Futurebus + Working Group include:

- 1. Architecture, processor, and technology independent
- 2. A basic asynchronous (compelled) transfer protocol
- 3. An optional extended source-synchronized protocol
- 4. No technology-based upper limit to bus performance
- 5. Fully distributed parallel and arbitration protocols
- 6. Support for fault-tolerant and high-availability systems
- 7. Support for cache-based shared memory
- 8. Compatible message transport definition.

Compatibility of varying speed and technology boards connected to the same Futurebus+ backplane is dependent upon broadcast capability, or a snooping cache coherence scheme. The performance of a Futurebus+ backplane is scalable over time to allow a low-end 32-bit system operating at 100 Mbytes/sec to be expanded to a 256-bit system operating at 3.2 Gbytes/sec in the future. This performance is attainable by the use of source-synchronized protocols which eliminate spatial skews and receivers which are triggered by the incident wave from the driver. The synchronization protocol of the Futurebus+ backplane allows the synchronization domain of the sender to extend along the backplane, presenting only one synchronization interface between the bus and the receiver.

The Futurebus+ backplane uses "Backplane Transceiver Logic" (BTL). BTL is a signaling standard that has been developed to enhance the performance of backplane buses. This standard eliminates the settling time delays, that severely limit the TTL bus performance, to provide significantly higher bus transfer rates. BTL compatible transceivers feature low output capacitance drivers to minimize bus loading, a 1V nominal signal swing for reduced power consumption, and receivers with precision thresholds for maximum noise immunity. For example, all Futurebus+ signals are open collector with termination resistors (selected to match the bus impedance) connected to 2V at both ends. The low voltage is typically 1V. All Futurebus+ signals are active low, indicated by an \* after the signal name. (Refer to Table I.) Further, signals can be driven simultaneously by several modules. This requires that glitch filtering will be needed for those times to filter out the transmission line effect called the wire-or glitch. Refer to the Futurebus+ specifications for details

#### **TABLE I. Signal Definitions**

| Signal Type,<br>Example Signal | Terminology                  | Logic<br>Level | TTL | BTL |
|--------------------------------|------------------------------|----------------|-----|-----|
| Active High                    | Asserted                     | Logic 1        | 5V  | _   |
| Signal_Name                    | Negated                      | Logic 0        | 0V  | _   |
| Active Low                     | Asserted                     | Logic 1        | 0V  | 1V  |
| Signal_Name*                   | Negated                      | Logic 0        | 5V  | _   |
|                                | Released<br>(Open Collector) | Logic 0        | _   | 2V  |

# 2.0 Introduction to Futurebus + Arbitration

Futurebus + uses an evolved version of the Parallel Contention Arbiter (see *Figure 4*). Through the application of a unique arbitration vector to this logic, only one contender will be uniquely selected as the winner. This implementation requires no central logic on the backplane and gains the following advantages:

- 1. The current master can see any requests and their priority to determine whether it should give up the bus.
- Multiple priority levels can be implemented to allow systems to allocate bus bandwidth to modules running the most critical tasks.
- A Round Robin (fairness) protocol is implemented within each priority level to ensure fair and equitable allocation of bus tenure to all modules.
- A master elect can be preempted by a higher-priority contender. This allows the higher priority contender to access the bus with minimum latency (with some sacrifice to the system performance).
- 5. Arbitration Messages or events can be broadcast on the arbitration bus without disturbing the current transaction on the parallel bus. Important system control functions and interrupts can be sent using this mechanism without the need of dedicated bus lines.
- 6. A Module may support either Idle Bus Arbitration or Parking. Idle Bus Arbitration can be enabled by the current master to decrease the arbitration latency when ony one competitor is requesting the bus. If Idle Bus Arbitration is not selected then Parking may be enabled by the master. Parking allows the current master to regain bus tenure (during Phase 0) to perform new bus transactions.

# 2.0 Introduction to Futurebus + Arbitration (Continued)

#### 2.1 THE ARBITRATION STATES

Figure 1 is an Arbitration State Diagram showing four states that a module may enter as well as the events that cause the module to change states during the arbitration process. Transitions from one state to another occur only when certain conditions are met, based on the arbitration phase and the arbitration bus lines. Once a control acquisition cycle has started, all modules must participate in the arbitration to remain synchronized within the system.



#### FIGURE 1

## 3.0 Introduction to DS3875 Arbitration Controller

The DS3875 Arbitration Controller implements the complete requirements fo the IEEE 896.1 specifications. For example, both arbitration modes of operation (Unrestricted and Restricted) are supported. Also, either Idle Bus Arbitration or Parking may be selected for cases when only one request or no request for bus competition exist. The controller is software configurable to operate as a slow/fast module. This selects the minimum time the arbitration controller must wait during the arbitration competition before it can read the resulting competition status. This delay allows arbitration competition lines (AB[7 ... 0]\*, ABP\*) to settle due to several arbitration numbers being applied to them (Wireored bus lines). Further, a built-in PLL, which accepts a clock signal from 2 MHz to 40 MHz, in steps of 1 MHz, controls several programmable delay lines used for releasing ar\* after issuing CMPT\*/IBA\_CMPT\* (PS(1:0)). This delay compensates for the chip to chip skew to ensure sufficient time to drive the arbitration competition number onto the arbitration competition lines during normal arbitration; or to assert the AD/DATA lines during Idle Bus Arbitration before releasing ar\*. Internally, the PLL also generates the 1  $\mu$ s timer used during arbitration phase 2 and phase 4.

The Arbitration Controller supports Arbitration message sending. A FIFO strobe, FSTR\*, is provided to store more

than one arbitration message externally to prevent overrun. Also a hardwired register contains the first word of the arbitration message (h'1ff). Additional registers which hold arbitration numbers, status information, controller configuration information, and an arbitration message can be accessed by the host through Read/Write operations. For outgoing arbitration numbers, the on chip parity generator unloads the host of the parity generation function. For incoming arbitration numbers, the DS3885 Arbitration Transceiver performs the parity check function and drives the PER\* input signal to the Controller. Separate interrupt pins for error occurrence, reception of an arbitration message, and reception of Powerfail message are available. These interrupts are cleared by performing a dummy write cycle to these registers.

#### 3.1 DS3875 Futurebus + Arbitration Controller (Distributed) Configuration for IEEE 896.1 Compliance

The DS3875 Futurebus + Arbitration Controller implements the complete requirements of the IEEE 896.1 specification. On chip reset (RST\*), the arbiter defaults to the 896.1 compliance configuration features.

The D53875 Distributed Arbiter was designed before the 896.1 specification was finalized. Thus, it contains additional options that can he selected in proprietary bus applications or 896.1 compatible bus applications. There are three features in total that can be chosen through register programming.

First an explanation of each feature will be given, so that if an application can take advantage of the option, it can be programmed. Then, the 896.1 compliance configuration is given so the arbiter will operate in complete accordance with the specification.

#### Arbitration Number: Unrestricted/Restricted Mode

In Distributed Arbitration, both priority and fairness protocols are implemented. Applications requiring quick access to the Futurebus+ backplane can be assigned high priority to reduce bus latency times. Applications with the same (equal) need of the backplane bus, a fairness protocol is guaranteed. Thus, distributed arbitration implements a fairness protocol for modules assigned the same priority classification. The arbitration competition number encodes this information onto eight lines: AB[7:0] and arbitration number line: ABP. The Arbitration competition number consists of three fields: priority, round robin, and geographical address. Distributed Arbitration protocol allows from 1 to 256 priority levels. Systems not requiring more then two priority levels, a single pass competition number will suffice, one bit for priority. Systems with greater then two priority levels implemented will need a two pass competition number, where eight bits are allocated for priority representation. Now, the competition number exactly contains: 5 bits for geographical address (this guarantees uniqueness), 1 bit for round robin, either 1 bit for priority (single pass), or 8 bits for priority (two pass), and 1 bit to designate if the number is single pass or

When the DS3875 was designed, two modes of operation were defined: Unrestricted and Restricted. The Unrestricted mode allowed one and two pass competition numbers to coexist in a system. The Restricted mode allowed only one pass competition numbers. Now, the 896.1 specification

two pass. (Refer to Table II on page 14.)

## 3.0 Introduction to DS3875 Arbitration Controller (Continued)

only describes one method of operation. This method completely corresponds to the Unrestricted mode. In the DS3875, the R-U\* bit in the CTRL2 register, configures the operation mode of the arbiter. On reset, the arbiter is placed in the unrestricted mode, in accordance to the 896.1 specification

#### Arbitration Competition Settling Time

Distributed Arbitration uses contention logic to select the winner of the competition cycle. The Arbitration competition begins with all competing modules asserting the most significant bit AB[7], of the competition number onto the backplane lines. A bit wise comparison is performed where modules are allowed to assert the subsequent bits only as long as that module's competition number bits thus far asserted are greater than or equal to the bits seen on the backplane lines. Thus, all competing modules begin asserting their competition numbers onto the backplane lines, but at the end, only the winning module will be allowed to assert it's competition number onto the backplane lines.

When the DS3875 was designed, two speeds where allowed in the FBUS+backplane system for the arbitration competition settling time: Slow or fast. During the arbitration cycle, modules would indicate if they had a fast or slow competition settling time. If any module indicated that it had a slow competition settling time, then all modules would compete using the slow competition settling time, else, the fast settling time would be used during the competition cycle. The DS3875 allows the user to program a fast or a slow competition settling time. One of eight settling times can be selected for each mode with 16 total possible delay times.

The IEEE 896.1 specification now allows each module to use it's worst case arbitration settling time, t<sub>A</sub>, as the module's delay time to determine it's win/lose status for the arbitration competition. The ones and zeros combination in the competition number plays a significant role in determining the numbers settling time. Several factors are incorporated into the t<sub>A</sub> calculation:

Maximum end to end signal propagation delay along tpd: the transmission line (backplane). This is a function of the maximum length of the transmission line.

- Delay between a change on any arbitration line, tint: ABx\*, on the input to a module and the corresponding change on that module's adjacent arbitration output, ab[x-1]\*, or abp\*, as its competition number is applied to or withdrawn from those bits.
- Delay between a change on any arbitration line, text: ABx\*. on the input of any other competing module and the corresponding changes on that module's arbitration outputs, ab[x-1]\*, or abp\*, as its competition number is applied to or withdrawn from those bits
- twin<sup>.</sup> Maximum delay between the time when the arbitration bus. AB [7..0]\*. becomes stable and equivalent to cn[7..0] on the input to a module and the indication within that module that it is the winner.
- (Refer to 896.1 for more details).

Thus, now each module can evaluate it's win/lose condition when it's t<sub>A</sub> time has elapsed. During a particular competition, the winning module's competition number will have the longest worst case settling time since this is the module that has placed all of it's competition number bits onto the FBUS+.

To use the DS3875 in the 896.1 compliant mode, the user programs two delay values in the CTRL2 register that are closest to the calculated worst case settling time for the particular competition number. The F\_S\* bit should correspond to the table (fast or slow) that the most desired delay resides. The CTRL2 register bits PD3 to PD5 program the delay number that corresponds to the fast mode operation, and PD0 to PD2 program the delay number that corresponds to the slow mode operation. Thus, a delay that is closest to the desired delay time should be selected both from the fast (PD3 to PD5) table and the slow (PD0 to PD2) table. The F\_S\* bit will configure this arbiter in the fast or slow mode of operation.

| 3.0 Introduction to DS3875<br>Arbitration Controller (Continued) |      |     |     |     |     |     |     |  |
|------------------------------------------------------------------|------|-----|-----|-----|-----|-----|-----|--|
| CTRL2                                                            |      |     |     |     |     |     |     |  |
| 7                                                                | 6    | 5   | 4   | 3   | 2   | 1   | 0   |  |
| F_S*                                                             | R_U* | PD5 | PD4 | PD3 | PD2 | PDI | PD0 |  |

During the competition cycle, if any module has selected the slow mode of operation, AC0\* is asserted during phase 1 for indication to all modules to operate in the slow mode. Thus, each arbitration cycle will determine whether the programmed fast delay value or the programmed slow delay value is used for the arbitration number settling time delay. The range of values in the fast and slow delay tables are very close to each other and in some cases are exactly the same that the desired delay value can be easily chosen. The DS3875 is in complete accordance with 896.1 since AC0\* signal now only is evaluated in phase 3, 4, and 5, and the  $t_A$  number is individually determined for each number.

#### **Idle Bus Arbitration**

Previously, the Futurebus + specification allowed idle bus arbitration. Idle Bus Arbitration (IBA) gives a module quick access to Futurebus+ when the current master has completed it's transfers. IBA occurs on the parallel highway, AD[31:0] lines. When the arbitration cycle is in phase 0 and the master module is not carrying out transactions, another module initiates normal arbitration and IBA simultaneously. In IBA, each module is assigned a particular AD[31:0] bit to assert if a module wishes to get tenure of the bus. If more then one module asserts a bit onto the address/data lines then normal arbitration on the arbitration bus lines will determine the new master. If only one module asserted a bit on the address/data line, then during phase 2 of the normal arbitration cycle that module will be given a bus grant signal. Thus, IBA was specified to speed up the arbitration process when there are not multiple contenders for the bus.

IEEE 896.1 no longer allows IBA. Now, only Parking is allowed. It lets the current Futurebus + master quickly access the bus to perform other transfers when no other modules want to use it. Parking issues the BGRNT\* signal to the current bus master during Phase 0.

For IEEE 896.1 compliance in the DS3875, the IBA\_PK\* bit of the CTRL3 register should disable IBA and enable Parking. On chip reset, Parking is selected. The IBA\_CMPT\* output signal of the DS3875 should not be connected and IBA\_S\* input signal should be connected to  $V_{CC}$ .

#### **Concluding Remarks**

In retrospect, features which are no longer part of IEEE 896.1 specification were discussed. All of these features are user selectable. The DS3875 can be easily configured to operate in the 896.1 compliance mode. As a matter of fact, on power up reset, the DS3875 is configured in the compliance mode. Briefly:

- 1. Arbitration Number:
- CTRL2 register: R\_U\* bit

Unrestricted mode now corresponds with the 896.1 arbitration number representation scheme.

2. Arbitration Settling Time Delay:

CTRL2 register: Program as desired. Select a delay from the fast table and slow table that closely matches the worst case arbitration settling time number, t<sub>A</sub>.

#### 3. IBA:

CTRL3 register: IBA\_\_PK\* bit

Enable Parking for 896.1 compliance which simutanously disables IBA.

## 4.0 DS3875 Interfaces

The Arbitration Controller interfaces with the DS3884A Handshake Transceiver, DS3885 Arbitration Transceiver, host with other support chips, Protocol Controller, and Reset and Initialization logic.

*Figure 2* depicts an internal block diagram of the DS3875 Arbitration Controller. *Figure 3* shows the interface between the DS3875 Arbitration Controller and the other logic on the module. The DS3884A Handshake Transceiver drives the arbitration handshake and condition signals to the arbitration controller (API, AQI, ARI, ACOI, AC1I). The Arbitration Controller continuously monitors the Futurebus+ backplane through these signals. Whether the Arbitration Controller is competing in the current control acquisition cycle or not, it drives the arbitration handshake and condition signals (APO, AQO, ARO, ACOO, AC1O) which the handshake transceiver drives onto the Futurebus+ backplane.





FIGURE 3

When competing the DS3885 Arbitration Transceiver is enabled to place the competition numbers  $CN(7 \dots 0)$  and its associated parity bit, CNp, onto the Futurebus + backplane. During every cycle, whether or not competing, the winning module's arbitration number is read, the value of  $WIN*\_GT*$  signal and PER\* signal is determined and updated in the appropriate internal registers.

The host can read or write (R/W) into the Arbitration Controller registers to change the controller configuration, check status, or R/W a new arbitration number/message. The host can select to latch data either on the falling edge of DSACK\* or on the rising edge of CS\* by releasing or asserting the SEL pin.

The Module may become bus master during Phase 5 if the normal arbitration cycle was successful, Phase 0 if Parking was successful, or Phase 2 if IBA was successful. Upon becoming bus master, the Arbitration Controller will issue BGRNT\*. This signal indicates to the Protocol Controller

that it can now perform the desired transactions on the Parallel address/data bus.

The Protocol Controller will let the Arbitration Controller know if it has locked resources by asserting the LKD\* signal. If resources were locked, then at transfer of tenure, the Arbitration Controller will issue UNLK\* to the Protocol Controller to unlock resources.

A dummy cycle will be initiated by the Arbitration Controller to perform the unlocking function if lock (LKD\*) is still asserted after end of tenure (ENDT\*) is asserted and no other modules are competing. Unlock will be asserted at the transfer of bus tenure (even if this module wins the competition). If another module initiates arbitration competition this module will participate in the competition and will issue the unlock (UNLK\*) signal upon transfer of bus tenure. When the bus transaction is complete and no resources are locked, the Protocol Controller has the option of enabling either Idle Bus Arbitration or parking (IBA\_PK\* in CTRL3).

#### 4.0 DS3875 Interfaces (Continued)

The input signal ALL1\* (AB[7...0]\* and ABp\* all asserted) is used to determine if any module is sending an arbitration message during pass 1. For convenience, the Arbitration Controller outputs FSTR\* (to an external FIFO) during message reception so more than one arbitration message may be stored by the module.

The Arbitration Controller has dedicated interrupt pins (ERINT\*, MGINT\*, PFINT\*) that interface with the Protocol Controller so that important messages and error indications can be quickly detected.

The Protocol Controller will issue the message request or bus request signals to the DS3875. When a message has been transmitted (Second Pass of arbitration, Phase 5), the Arbitration Controller will assert MGTX\*.

On board reset, initialization, power-up, and live insertion logic will inform the Arbitration Controller which type of reset operation to perform: Power-Up Reset (RST\*), Initialization (RINT\*), or live insertion (HALT\*). See Sections 10.0 and 11.0 for more information.

### 5.0 Arbitrating for Futurebus +

The arbitration process allows a module to seek and gain tenure of Futurebus+ to transfer data to or from another module. The arbitration process is independent of the data transfer process and may take place concurrently with data transactions on Futurebus+. If a module (or several modules) want to use the bus, an arbitration competition takes place. The module with the highest arbitration number gets tenure of the bus.

The National Semiconductor solution to Futurebus+ arbitration includes the DS3875 Arbitration Controller, the DS3885 Arbitration Transceiver and the DS3884 Handshake Transceiver (see front page system block diagram). More information on Arbitration as it applies to the Futurebus+ IEEE standard is available in Section 5 of the "Futurebus+ P896.1 Logical Layer Specification".

## 5.1 UNRESTRICTED/RESTRICTED MODES OF OPERATION

The Arbitration Controller supports either the Unrestricted or the Restricted mode of arbitration. In the system environment, all modules must be configured to operate in the same mode at any given time.

During initialization, the Unrestricted mode is set since it must be supported by all modules. The Unrestricted mode allows a single pass of an 8-bit arbitration number or a two pass of a 16-bit arbitration number to be used.

Futurebus + allows arbitration numbers requiring a single pass control acquisition cycle to be mixed with those requir-

ing a two pass control acquisition cycle. During the first pass of a two pass cycle, more than one module may have the same number; however, during the second pass only one winner results where the competition numbers must be unique. A logic zero in the RU\_\_ bit of the CTRL2 register selects the unrestricted mode.

The Restricted mode of operation is optional and is selected by setting the RU\_\_ bit to a logic one in the CTRL2 register. This mode limits arbitration numbers to 8 bits. Thus, only a single control acquisition cycle occurs where all numbers are unique. The arbitration numbers are assigned by the module and can be dynamically changed.

## 5.2 THE ARBITRATION NUMBER AND ARBITRATION CIRCUIT

Each module has a unique arbitration number. When two or more modules compete for the bus, the module with the highest arbitration number will win the competition.

The DS3885 Arbitration Transceiver contains the arbitration circuit. See *Figure 4* for a functional model of the arbitration circuit. A Parallel Contention Arbitration Protocol controls how modules assert and release the AB[7 ... 0]\* and AB\*. After a period of time (ta) the protocol ensures that only the winners arbitration number will remain on the AB[7 ... 0]\* and ABp\*.

The arbitration number consists of one or two competition numbers, CN(7...0). The Arbitration Controller Transmits/ Receives the competition number to/from the Arbitration Transceiver. The  $CN\_LE^*$  signal latches the competition number into the transceiver while the  $AB\_RE^*$  signal allows the controller to read in the winner's competition number. Along with the competition number, the Arbitration Controller transmits the CNp bit, the generated parity bit of the competition number, to the Arbitration Transceiver. Odd parity, as specified in the Futurebus+ specifications, is implemented. Thus, CNp is set when even number CN(7...0) is received from the Arbitration Transceiver, the PER\* bit is checked for error detection.

Referring to Table II, in the Unrestricted mode, the CN7 bit indicates if the module requires another arbitration pass. When a one pass and a two pass arbitration number occur in the same control acquisition cycle, the one pass arbitration number will win.

The DS3875 allows the module to dynamically change the arbitration number by writing into the TXCN0 and/or the TXCN1 registers (see Section 7). If the arbitration number is changed during an arbitration cycle it will be used in the next arbitration competition.

The arbitration number is composed of three fields: Priority Field, Round Robin Field, and a Unique Field.



### 5.0 Arbitrating for Futurebus + (Continued) 5.2.1 Priority Field (PR)

The priority field represents a module's priority class which is determined by the system designer. In the unrestricted mode, the length of this field is a maximum of eight bits while in the restricted mode it is two bits.

#### 5.2.2 Round Robin Field (RR)

This field is represented by a single bit, CN5, in both modes of operation. The round robin protocol ensures that all modules in the same priority class have fair and equal access of the bus. A module is allowed to get tenure of the bus in a sequence defined by its value in the unique field.

The round robin bit is adjusted by the Arbitration Controller each time a transfer of tenure occurs in the module's same priority class whether or not the module is competing in the control acquisition cycle. In the module's same priority class, the round robin bit is set when tenure of the bus is transferred to a module with a larger unique field value or the round robin bit is cleared when tenure of the bus is transferred to a module with a lesser unique field value.

In the event, where the module's arbitration number is changed, after the next control acquisition cycle, the round robin bit is adjusted accordingly.

#### 5.2.3 Unique Field (U)

The five bit unique field, CN(4...0), guarantees the uniqueness of the module's arbitration number. The unique number may correspond to the module's geographical address or may be allocated by the system designer as he chooses while also in such a way that minimizes the arbitration settling time. The value "11111" is not allowed in systems using arbitration messages.

#### **5.3 ARBITRATION CATEGORIES**

A module can be in one of six categories when a control acquisition cycle is in progress;

- · Competitor for the Parallel bus
- Competitor to send a message
- By-Stander
- · By-Stander who decides to invoke Pre-emption
- Master
- Master Elect

#### 5.3.1 Competitor for the Parallel Bus

A Module may become a competitor for the parallel bus if it issues a Bus Request (! BRQ\*) to the arbitration controller before the arbitration cycle Phase 1 starts, see *Figure 5a*.

If the module issues a bus request and the arbitration cycle is in phase 0, the controller will assert APO to start an arbitration competition. If an arbitration competition has already started, and the module's bus request comes prior to API being asserted on the arbitration bus, the module may enter this arbitration cycle. If an arbitration competition has already started, and the module's bus request comes after AP\* being asserted on the arbitration bus, the module will have to wait until the next arbitration cycle to compete (or pre-empt the current arbitration cycle in Phase 3).

| TABLE | н. | Arbitration | Number |
|-------|----|-------------|--------|
|       |    |             |        |

| Bit                           | CN7      | CN6 | CN5 | CN4          | CN3   | CN2 | CN1 | CN0 |  |  |  |
|-------------------------------|----------|-----|-----|--------------|-------|-----|-----|-----|--|--|--|
| Unrestricted Mode—Single Pass |          |     |     |              |       |     |     |     |  |  |  |
| Pass 1                        | 1        | PR0 | RR  | U4           | U3    | U2  | U1  | U0  |  |  |  |
| Unrestricted Mode—Two Pass    |          |     |     |              |       |     |     |     |  |  |  |
| Pass 1                        | 0        | PR7 | PR6 | PR5          | PR4   | PR3 | PR2 | PR1 |  |  |  |
| Pass 2                        | 1 PR0 RR |     | RR  | U4           | U4 U3 |     | U1  | U0  |  |  |  |
|                               |          |     | Re  | stricted Mod | 9     |     |     |     |  |  |  |
| Pass 1                        | PR1      | PR0 | RR  | U4           | U3    | U2  | U1  | U0  |  |  |  |
| Arbitration Message           |          |     |     |              |       |     |     |     |  |  |  |
| Pass 1                        | 1        | 1   | 1   | 1            | 1     | 1   | 1   | 1   |  |  |  |
| Pass 2                        | a7       | a6  | a5  | a4           | a3    | a2  | a1  | a0  |  |  |  |

## 5.3.2 Competitor to Send a Message (Continued)

The Arbitration Controller supports message sending. Message sending is implemented in the unrestricted mode in a two pass arbitration cycle. The first pass of all ones (1FF H) in the competition number identifies the transaction as a message. The ALL1\* input signal is asserted by the Arbitration Transceiver when it detects 1FF H on the AB[7 ... 0]\* and ABp\* lines. The arbitration controller has a hardwired register that holds the first pass word. Further, a dedicated pin MGRQ\* (message request) places the Arbitration Controller in the message sending mode.

The message that is to be transmitted is loaded into the TXMSG register. The message of 1FF H is reserved as the powerfail message. Other messages are to be coded by the system designer with the greater priority messages having a higher arbitration number. Obviously, if more than one module simultaneously desires to send a message, the message with the highest arbitration number will be transmitted.

When a message is sent, no transfer of tenure takes place. Thus, the master (M) or the round robin (RR) bits are not updated. Upon successfully transmitting the message, MGTX\*\* signal is asserted.

When a message is received by the Arbitration Controller (Phase 5), message interrupt (MGINT\*) is asserted and FIFO Strobe (FSTR\*) is negated. In the case of a Powerfail message being received; the PFINT\* signal is asserted. When the PFINT\* signal is asserted, the MGINT\* and FSTR\* signals are not generated. See *Figure 5d*.

When sending a message, once the MGRQ\* signal is asserted, until the message has been transmitted, all other requests are blocked. Upon the MGTX\* signal being released, the message request signal will be reevaluated to see if another message needs to be sent.

If this module is the module sending the arbitration message, then the message interrupt (MGINT\*) or the Powerfail interrupt (PFINT\*) will not be generated on this module. These interrupts are generated only upon the reception of a message from another module. Refer to *Figure 5e*.

#### 5.3.2.1 Using an External FIFO to Store Messages

The Arbitration Controller provides a FIFO strobe (FSTR\*) signal to store more than one arbitration message in an external FIFO. A rising edge on FSTR\* is generated upon the reception of an arbitration message.

See Figure 3 and Timing Diagrams: T6, Phase 2 and Phase 5.

1. FSTR\* is always asserted (! FSTR\*) during phase 2.

- FSTR\* is negated (FSTR\*) during phase 5 given the following conditions.
  - 1. The message is not being sent by this module.
  - 2. This is the second pass of an arbitration message.
  - 3. No errors occurred during this arbitration cycle.

4. This is not a powerfail interrupt message (! PFINT\*).

The external latch shown in *Figure 3* is enabled by AB\_RE<sup>\*</sup> to temporarily hold the message. While AB\_RE<sup>\*</sup> is low (see timing diagrams phase 2 and 5), the latch is fall through. Then, during phase 5 on the rising edge of FSTR<sup>\*</sup>, the message held in the latch will be strobed into the FIFO.

#### 5.3.3 By-Stander

A Module is considered a by-stander in the arbitration competition if it does not issue a Bus Request (! BRQ\*) to the arbitration controller before arbitration cycle Phase 1 starts.

#### 5.3.4 By-Stander Who Decides to Invoke Pre-emption

A module with a higher arbitration number than the master elect may initiate a new arbitration cycle to establish a new master. This process, referred to as pre-emption, allows a high priority to acquire tenure of the bus with minimum latency.

Pre-emption is allowed in phase 3 when all of the following conditions are met:

- 1. the arbitration number is greater than the arbitration number on the bus
- 2. a bus request signal was recently received

3. did not participate in the arbitration competition phase 2. The master elect may be preempted by asserting AC10.

- Pre-emption is not allowed during:
- the first pass of a two pass cycle
- message sending

These two events are given higher precedence.

If a module decides to preempt and changes its competition number during phase 2 or phase 3 in the Arbitration Controller, the Arbitration Transceiver will still use the current latched competition number to make the greater than comparison. When the next arbitration cycle occurs, the new competition number will be used.

#### 5.3.5 Master

The Master is the module that currently has tenure of the parallel bus.

#### 5.3.6 Master Elect

The Master Elect is the module that won the current arbitration cycle. The Master Elect will become master upon transfer of tenure.





FIGURE 5. Bus Request Timing (Normal Arbitration, Idle Bus Arbitration and Parking) (Continued)

## 5.4 FUTUREBUS + OPTIONAL MEANS OF ARBITRATION

Besides the normal Futurebus + Parallel Contention Arbitration, the Futurebus + Specification allows two other optional arbitration methods to acquire the parallel bus quickly:

- Idle Bus Arbitration
- Parking

Both of these arbitration methods are supported by the National Semiconductor DS3875 Arbitration Controller.

#### 5.4.1 Idle Bus Arbitration (IBA)

Idle Bus Arbitration (IBA) is selected by setting the IBAPK\* bit in CTRL3 register. The aim of IBA is to give a module quick access to Futurebus+ when the current master has completed its transfers.

IBA is invoked the same as a normal arbitration bus request (! BRQ\*) but uses the parallel bus (AS\* negated, DS\* asserted, and the parallel address/data bus) to determine the winner of the arbitration cycle, see *Figure 5a, b*.

During normal arbitration the transfer of Futurebus + tenure occurs during phase 5. During IBA the transfer of Futurebus + tenure occurs during phase 2. During IBA the AC10 arbitration condition signal will be asserted by the new master. This will cancel the transfer of tenure during the normal arbitration cycle. Note that Futurebus + tenure was transferred but only the two modules involved in the IBA (the master and the master elect) know that the transfer of ten

ure has taken place. All the other modules involved in the normal arbitration cycle see that the transfer of tenure during the normal arbitration cycle was canceled.

If two or more modules have a request, then normal arbitration will determine which module will gain access. IBA takes place on the parallel highway, AD/DATA (31 ... 0). Each module is assigned a bit which is to be asserted during IBA. If only one bit is asserted during the IBA competition, then IBA issues the bus grant signal to that module. Concurrently with IBA, normal arbitration takes place. If a module does not want IBA to issue a bus grant, IBA may be inhibited by asserting DI\*. During phase 5, normal arbitration will determine appropriate actions.

#### 5.4.1.1 Masters Support Circuitry to Enable IBA

If IBA is allowed, it is invoked during phase 0. In order to support IBA external logic is needed in addition to the arbitration controller. The Masters external logic must monitor the arbitration control acquisition synchronization signals (AP\*, AQ\*, AR\*) and the parallel bus address handshake signals (AS\*, AK\*, AI\*). If the master supports IBA it should wait until it is ready to end its bus tenure (ENDT\* asserted). Then when it releases AS\* it should assert ds\* to enable modules to participate in IBA competition.

#### 5.4.1.2 Modules Support Circuitry to Participate in IBA

If a module wants to use IBA to gain tenure of Futurebus+ it must use external logic to monitor the arbitration control

### 5.0 Arbitrating for Futurebus + (Continued)

acquisition synchronization signals (AP\*, AQ\*, AR\*), the parallel bus address handshake signals (AS\*, AK\*, AI\*), the parallel bus data sync signal (DS\*) and data acknowledge inverse (DI\*), and the IBA\_CPT\* output from the arbitration controller.

#### 5.4.2 Parking

During Power Up, the Arbitration Controller is programmed to perform either Idle Bus Arbitration or Parking by setting or clearing the IBAPK\* bit in the CTLR3 register. Parking is selected by clearing the IBAPK\* bit. The aim of Parking is to give the Futurebus+ bus Master quick access to the bus to perform other transfers when no one else desires to use it. Thus, it is not necessary for the master to go through the entire arbitration cycle to get the BGNT\* signal. Parking issues BGNT\* in Phase 0, see *Figure 5c*. If another module gets a message request or bus request, the arbitration competition cycle begins like it normally does to handle the request.

All of the following conditions should be met to take advantage of Parking:

- 1. Parking in selected
- 2. module must be the current Master
- 3. ENDT\* signal is high
- 4. BGRNT\* signal is high
- 5. BRQ\* signal is asserted low while in phase 0
- 6. LKD\* signal is high (Resources are not locked)

When these conditions are true, the Arbitration Controller issues the BGRNT\* signal (asserted low) in phase 0. Upon end of tenure, BGRNT\* signal will be released. The Master may continue to use Parking to perform transactions until after the arbitration competition cycle selects a new master (see *Figures 5c* and 7).

Parking is allowed only when the Master has all resources unlocked (indicated by LKD\* signal being high). During phase 0, if the master still has resources locked (ENDT\* and BGRNT\* signals are high), the Arbitration Controller will immediately initiate a dummy cycle to unlock resources. The UNLK\* signal is generated during phase 5 upon the successful transfer of tenure. The transfer of tenure may be with itself or another module.

#### 5.5 THE ARBITRATION PHASES

The arbitration process consists of transitioning through six phases (Phase 0 thru Phase 5) of the three arbitration synchronization signals (AP\*, AQ\*, AR\*). To transition between control acquisition phases only one of the three arbitration synchronization signals will transition.

The Arbitration process is asynchronous and occurs as fast as all the modules that contain arbitration logic can transition through the arbitration phases. If a two-pass arbitration competition has been selected the entire control acquisition cycle is repeated twice.

Each arbitration synchronization signal (AP\*, AQ\*, AR\*) represents the wire-OR of each of the individual synchronization signals from each of the modules. For any of the synchronization signals on the bus to be released, all the modules must release their individual synchronization signals (ap\*, aq\*, ar\*). Therefore, the release of a synchronization signal forms a global synchronization point for all the modules. Likewise, during the assertion of a synchronization signal all modules must remain synchronized by asserting their own signals in response.

Each module must participate in the control acquisition cycle, whether or not the module is competing, to remain synchronized with the other modules. *Figure 6* is a timing diagram of the Control Acquisition Sequence. *Figures 7a-f* are state transition diagrams of the DS3875 Arbitration Controller. Tables III and IV represent the internal register bits that are affected by the arbitration states and their transitions. The DS3875 Arbitration Controller transitions to the next arbitration phase upon (see *Figure 6*):

- 1. APO output signal being asserted to phase 1
- ARI input signal being negated to phase 2. (This input is filtered and indicates all modules have released the AR\* synchronization signal on the Futurebus + backplane.)
- 3. AQO output signal being asserted to phase 3
- API input signal being negated to phase 4. (This input is filtered and indicates all modules have released the AP\* synchronization signal on the Futurebus+ backplane.)
- 5. ARO output signal being asserted to phase 5
- AQI input signal being negated to phase 0. (This input is filtered and indicates all modules have released the AQ\* synchronization signal on the Futurebus+ backplane.)





- Though this module may not be requesting Futurebus + another module may want to arbitrate for Futurebus + and assert AP\*. This action will cause the AP input (API) on this module to be asserted. API asserted will cause this modules arbitration controller to assert APO.
- 3. If this module is currently the master and ! LK\* is asserted, BGRNT\* is negated, ! ENDT\* has been received, no other requests have been received and API is negated, the module will initiate a dummy cycle to unlock its resources by asserting APO (if it is doing Single Pass or the First Pass of Two-Pass Arbitration).
- 4. A message request (! MGRQ\*) will cause APO to be asserted (if it is doing Single Pass or the First Pass of Two-Pass Arbitration). Note that if both a bus request (! BRQ\*) and ! MGRQ\* are received during phase 0,

3. Parking

during Phase 0:

1. Normal arbitration

2. Idle Bus Arbitration (IBA)

ted.

cycle is in progress or between the two control acquisition

1. If ! HALT\* is asserted the arbitration controller will not

2. If any of the "New Bits" are set (NCN, NGO, NDS) the

3. The arbitration condition lines (AC1\*, AC0\*) will be nega-

One of the following three types of arbitration may occur

be updated and then the "New Bits" will be reset.

corresponding internal arbitration controller registers will

While in Phase 0 the following actions are performed:

transition to Phase 1 until HALT\* is negated.

cycles of a two-pass arbitration sequence.

#### 5.0 Arbitrating for Futurebus + (Continued)

! MGRQ\* will be given a higher priority and will be acted upon during this arbitration cycle. ! BRQ\* will wait to arbitrate during the next arbitration cycle.

5. A Bus Request (! BRQ\*) will cause APO to be asserted (if it is doing Single Pass or the First Pass of Two-Pass Arbitration). This will cause the Futurebus + AP\* to be asserted and will indicate to the other modules that an arbitration competition is beginning.

Note that the user will violate the Futurebus + specification if he leaves the local modules resources locked (! LKD\*) and has IBA enabled in the arbitration controller. This incident is dangerous because it could lead to another module winning IBA with the local modules resources being locked. If the other module tried to access the local modules resources it would result in deadlock.

## 5.5.1.2 Phase 0, Idle Bus Arbitration Events That Cause a Transition to Phase 1

If IBA is desired and the arbitration cycle is in Phase 0 (! APO, ! AQI, ARO), the parallel bus is idle (AS\*, AK\*, ! AI\*), and DS\* has been released for a minimum period of time (Futurebus + spec.) the Masters external logic may assert ! DS\*. This will alert any module capable of doing IBA that IBA has been enabled.

#### 5.5.1.3 Phase 0, Parking

The aim of Parking is to give the Futurebus+ bus master quick access to the bus to perform other transfers when no one else desires to use it. If Parking is enabled (I IBA\_PK\*) and is successful the arbitration controller will issue BGNT\* in Phase 0. If another module gets a message request or bus request, the arbitration competition cycle begins like it normally does to handle the request (see Section 5.5.4 for more information).

#### 5.5.2 Phase 1, Decision Phase

This Phase is characterized by AP\* and AR\* asserted and AQ\* released on Futurebus+. See *Figure 7b* for the DS3875 Arbitration Controller Phase 1 state diagram.

The arbitration controller will be asserting APO and ARO and negating AQO. This is the state of the arbitration synchronization lines when the decision phase (1) is in progress.

During Phase 1 the individual modules must make the decision whether they want to compete. This decision will be based upon the state of the modules bus request, message request or locked status (! BRQ\* or ! MSGRQ\* or ! LKD\*) at the time APO is asserted. Since this condition is subject to mestastability a metastable hardened latch is used internal to the DS3875 to resolve this potential condition.

If the module is going to compete the arbitration competition number (CN(7:0)) and its parity bit (CNp) will be asserted to the arbitration transceiver, Latch enable of the arbitration transceiver will be asserted and negated (! CN\_LE\* asserted for 20 ns) to latch in the arbitration number, and compete will be asserted (! CMPT\*) to enable the arbitration competition number onto Futurebus +.

If the module is a slow module (! FS\*, see Section 7.6) the arbitration handshake signal AC0O will be asserted.

Once the decision to compete has been made, the arbitration handshake signal (! AC1O) that cancels the arbitration cycle will be negated. The Programmable Skew (PS(1:0)) gives time for the arbitration number to become valid on Futurebus + before ARO is negated. Once the Programmable Skew has timed out ARO will be negated. Once all modules have negated AR\* the arbitration cycle will transition to **Phase 2**.

Once all modules have negated AR\* a 1  $\mu s$  timer is started. This timer is used to guarantee that the competition cycle does not get stuck in phase 2. During Phase 2, the winner of the competition cycle, after waiting its  $t_A$  (arbitration settling time) time, transitions the cycle to Phase 3. The timer is used to prevent livelock where the winning module may not transition the cycle to Phase 3.

## 5.5.2.1 Phase 1, Idle Bus Arbitration Events That Cause a Transition to Phase 2

During phase 1 the arbitration controller will output ! IBA\_\_\_ CPT\*. When the external logic sees ! IBA\_\_CTP\* and the parallel bus is inactive (AS\*, AK\*, ! AI\*) it should drive one of the data bits of the parallel address/data bus.

#### 5.5.3 Phase 2, Competition Phase

This Phase is characterized by AP\* asserted and AQ\* and AR\* released on Futurebus+. See *Figure 7c* for the DS3875 Arbitration Controller Phase 2 state diagram.

The arbitration controller will be asserting APO, negating AQO and receiving ARI negated. This is the state of the arbitration synchronization lines when the competition phase (2) is in progress.

While in Phase 2 the following actions are performed:

- AB\_\_RE\* is asserted after 30 ns. This allows the arbitration controller to monitor the winning competition number.
- 2. The FIFO STRobe is now asserted (! FSTR\*).

There are two conditions that can cause AQO to be asserted causing a transition to **Phase 3**:

- 1. The AQI input being asserted.
- Competing, arbitration competition settling time (t<sub>a</sub>) expired, one μs Phase 2 arbitration error timer not expired, and the WIN\*\_GT\* input being asserted.

## 5.5.3.1 Phase 2, Idle Bus Arbitration Events That Cause a Transition to Phase 3

The external logic should drive the IBA Success signal (! IBA\_S\*) during phase 2 if DI\* is released, only this modules data bit is driven on the data bus, and the arbitration settling Time ( $t_s$ ) has not expired.

When the arbitration controller sees ! IBA\_S\* asserted it will issue bus grant (! BGRNT\*) to give access of the bus to the module that won the IBA. If two or more modules have a request, then normal arbitration will determine which module will gain access.

#### 5.5.4 Phase 3, Error Check Phase

This Phase is characterized by AP\* and AQ\* asserted AR\* released on Futurebus+. See *Figure 7d* for the DS3875 Arbitration Controller Phase 3 state diagram. Also see *Figures 6b, c, d* for how AS\_CANCEL relates to Phase 3.

The arbitration controller will be asserting APO and AQO, and negating ARO. This is the state of the arbitration synchronization lines when the error check phase (3) is in progress.

While in Phase 3 the following actions are performed:

- 1. If the module is a competitor and winner of the arbitration, the W(winner) bit in the STATUS register is set.
- 2. Upon entering phase 3, after 20 ns, AB\_RE\* is negated.

#### 5.0 Arbitrating for Futurebus + (Continued)

There are seven conditions that will cause the arbitration controller to negate APO:

- 1. This module has had a Bus ReQuest (! BRQ\*), won IBA, and asserted AC1O and AS.
- 2. The current master releases AS (! AS\_CANCEL). The master has completed its transactions on the parallel bus, see *Figures 6b, c, d*.
- 3. This module detected the 1  $\mu$ s timeout or a parity error occurred during the arbitration cycle. This error condition will cause the assertion of AC0O and AC1O and ERINT\* signals which will inhibit the transfer of tenure during this arbitration cycle.
- 4. Another module has detected that transfer of tenure is to be inhibited (AC1I).
- 5. This module was competing and won the competition where this is the first pass of a two pass arbitration cycle.
- 6. This module did not compete (CMPT\*) but now has a bus request (! BRQ\*) and its competition number is greater than (! WIN\*\_\_GT\*) the modules competition number that won the current arbitration competition. This module preempts the current arbitration competition by asserting AC10. This inhibits the transfer of tenure during this arbitration cycle and allows a new arbitration cycle to be initiated in which this module can compete.
- 7. This module was competing (! CMPT\*) and won the competition (W bit of Status register set) but the bus request or message request has been negated (BRQ\* or MGRQ\*). This error condition will cause the assertion of AC0O, AC1O and ERINT\* signals which will inhibit the transfer of tenure during this arbitration cycle.

After all the modules have negated AP\*, upon receiving !API, the arbitration cycle will transition to **Phase 4**.

## 5.5.4.1 Phase 3, Idle Bus Arbitration Events That Cause a Transition to Phase 4

During phase 3 of the arbitration cycle, when the current master has not yet released the bus (AS), the new master (a module that was competing (!IBA\_CMPT\*) and won (!IBA\_S\*)) will drive AC10 to inhibit the transfer of tenure during the normal bus arbitration cycle (tenure was transferred during the IBA cycle).

Note: The new master will now continue the normal arbitration process to completion but may begin conducting transactions on the bus.

#### 5.5.5 Phase 4, Master Release Phase

This Phase is characterized by  $AP^*$  released,  $AQ^*$  asserted, and  $AR^*$  released on Futurebus+. See *Figure 7e* for the DS3875 Arbitration Controller Phase 4 state diagram and *Figures 6b, c, d* for how AS\_CANCEL relates to phase 4.

The arbitration controller will be receiving API negated, asserting AQO and negating ARO. This is the state of the arbitration synchronization lines when the master release phase (4) is in progress.

While in Phase 4 the following actions are performed:

1. All modules, other then the bus master, start a 1  $\mu$ s timer. This is referred to as the Master release timer. The master has 1  $\mu$ s to complete its transactions or to inhibit the transfer of tenure and proceed to phase 5. This timer is specified in the Futurebus+ specification so in the event where the current master does not respond, the master elect may assume mastership during phase 5.

- 2. The CMPT\* signal is negated (CMPT\*).
- There are six conditions that can cause ARO to be asserted causing a transition to **Phase 5**:
- 1. Transfer of tenure is inhibited indicated by the assertion of AC1I.
- 2. Was not Master and the ARI input was asserted.
- 3. Was Master and did not cancel (! AS\_CANCEL) the arbitration competition, see *Figures 6b, c, d*.
- 4. There is no current master (immediately following power up) so the master elect may assert ARO.
- Was Master and did cancel (! AS\_CANCEL) the arbitration competition, see *Figure 6d*. In this case the current master will assert AC10 to inhibit the transfer of tenure during this arbitration cycle.
- 6. All modules other then the current master detect the Master Release Timeout.

#### 5.5.6 Phase 5, Tenure Transfer Phase

This Phase is characterized by AP\* released, AQ\* asserted, and AR\* asserted on Futurebus+. See *Figure 7f* for the DS3875 Arbitration Controller Phase 5 state diagram.

The arbitration controller will be negating API and asserting AQO and ARO. This is the state of the arbitration synchronization lines when the tenure transfer phase (5) is in progress.

While in Phase 5 the following actions are performed:

- 1. If IBA\_CMPT\* signal was asserted, it is now negated (IBA\_CMPT\*).
- The unlock signal (! UNLK\*) will be asserted if locked (! LKD\*) is asserted and the arbitration condition signals (AC0I, AC1I) are negated.
- 3. This phase will update the following status bits:
  - 1. The Master status bit (bit 5) in the status register.
  - 2. The Competitor status bit (bit 4) in the status register.
  - 3. The WIN status bit (bit 3) in the status register.
  - 4. The Uniqueness, round robin and priority fields of the RXCN1 register.
  - 5. The Priority field of the RXCN0 register.

There are four conditions that can cause AQO to be negated:

- Had a message request (! MGRQ\*) and won the competition (! WIN\*\_\_GT\*). In this case the message transmitted output will also be asserted (! MSGTX\*).
- Competed for the bus (! CMPT\*), there were no errors (! ACOI, ! AC1I), and won the competition (! WIN\*\_\_GT\*). In this case the bus grant output will be asserted (! BGRNT\*) and the internal master bit will be set (M, bit 5 in the status register).
- 3. There were no errors (! AC0I, ! AC1I) and the module is not the winner. Resets the M bit in the status register.
- A Message was received. In this case either message interrupt will be asserted (! MGINT\*) or the powerfail interrupt (! PFINT\*) will be asserted.













| TABLE III. Restricted Mode Arbitration or Unrestricted Mode Arbitration           (One Pass, or Second Pass of Two Pass) |               |          |       |       |                   |          |        |       |                   |    |        |            |            |        |                  |
|--------------------------------------------------------------------------------------------------------------------------|---------------|----------|-------|-------|-------------------|----------|--------|-------|-------------------|----|--------|------------|------------|--------|------------------|
| Modules Category                                                                                                         | TXCN1<br>RR   | TXCN1    | TXCN1 | TXCN1 | STATE<br>All Bits | STATUS   |        | RXCN0 | RXCN1<br>(Note 2) |    |        |            | RXMSG      | CLRERI | CLRMGI<br>CLRPFI |
| during Arbitration                                                                                                       |               | (Note 1) | w     | С     | м                 | All Bits | U(0:4) | RR    | РО                | P1 | A(0:7) | Reset, Set | Reset, Set |        |                  |
| Competitor                                                                                                               | 5             | х        | 1, 2  | 0, 1  | 5                 |          | 3      | 3     | 3                 | 3  | 3      | X, 4       | X, 5       |        |                  |
| By-Stander                                                                                                               | 5             | х        | 1     | 0     | 5                 |          | 3      | 3     | 3                 | 3  | 3      | X, 4       | X, 5       |        |                  |
| Sending Message                                                                                                          |               | х        | 1, 2  | 0, 1  |                   |          |        |       |                   |    | 3      | X, 4       | X, 5       |        |                  |
| Receiving Message                                                                                                        |               | х        | 1     | 0, 1  |                   |          |        |       |                   |    | 3      | X, 4       | X, 5       |        |                  |
| Pre-Emption                                                                                                              |               | х        |       |       |                   |          | 3      | 3     | 3                 | 3  |        |            |            |        |                  |
| IBA                                                                                                                      | 5<br>(Note 4) | x        |       |       | 5<br>(Note 5)     |          | 3      | 3     | 3                 | 3  | 3      | X, 4       | X, 5       |        |                  |
| Parking<br>(Note 3)                                                                                                      |               |          |       |       |                   |          |        |       |                   |    |        |            |            |        |                  |

Arbitration Controller Internal Register Bit Changes

Note: The number shown within the box defines the arbitration phase where the particular bit may change state.

Note 1: Note that the STATE Register is updated in each Phase of Arbitration.

Note 2: This is the new Masters Competition Number.

Note 3: Parking is only a Phase 0 event.

Note 4: The RR bit is only updated on the New Master.

Note 5: The M bit is updated if IBA succeeded during Restricted Mode, or Unrestricted Mode (One Pass or the First Pass of Two Pass Arbitration).

"X" means that any Phase can update this bit (or bits).

"," is used in the table to depict the condition where a particular Status bit is Reset and where it is Set (Ex. 0, 1 means that this Status bit is Reset in Phase 0 and Set in Phase 1).

"-" is used in the table to depict the condition where a particular Status bit may change within several sequential phases (Ex. 2-4 means that this Status bit can change in Phases 2, 3, or 4).

| Modules Category<br>during Arbitration | TXCN1<br>RR | TXCN1    | TXCN1 | TXCN1 | TXCN1 | TXCN1    | TXCN1  | TXCN1 | TXCN1 | TXCN1 | TXCN1  | TXCN1      | TXCN1      | TXCN1 | TXCN1 | TXCN1 | State         RXCN0         RXCN1           All Bits         All Bits         All Bits         All Bits |  | RXMSG | CLRERI<br>Boost Set | CLRMGI<br>CLRPFI |
|----------------------------------------|-------------|----------|-------|-------|-------|----------|--------|-------|-------|-------|--------|------------|------------|-------|-------|-------|---------------------------------------------------------------------------------------------------------|--|-------|---------------------|------------------|
|                                        |             | (Note 1) | w     | С     | м     | (Note 2) | U(0:4) | RR    | PO    | 0 P1  | A(0:7) | neset, set | Reset, Set |       |       |       |                                                                                                         |  |       |                     |                  |
| Competitor                             |             | х        | 1, 2  | 0, 1  |       | 3        |        |       |       |       |        | X, 4       | X, 5       |       |       |       |                                                                                                         |  |       |                     |                  |
| By-Stander                             |             | x        | 1     | 0     |       | 3        |        |       |       |       |        | X, 4       | X, 5       |       |       |       |                                                                                                         |  |       |                     |                  |
| Sending Message                        |             | х        | 1, 2  | 0, 1  |       |          |        |       |       |       |        | X, 4       | X, 5       |       |       |       |                                                                                                         |  |       |                     |                  |
| Receiving Message                      |             | x        | 1     | 0, 1  |       |          |        |       |       |       |        | X, 4       | X, 5       |       |       |       |                                                                                                         |  |       |                     |                  |
| Pre-emption                            |             | х        |       |       |       | 3        |        |       |       |       |        |            |            |       |       |       |                                                                                                         |  |       |                     |                  |
| IBA                                    |             | х        |       |       | 5     | 3        |        |       |       |       |        | X, 4       | X, 5       |       |       |       |                                                                                                         |  |       |                     |                  |
| Parking (Note 3)                       |             |          |       |       |       |          |        |       |       |       |        |            |            |       |       |       |                                                                                                         |  |       |                     |                  |

TABLE IV. Unrestricted Mode, First Pass of Two Pass Arbitration

Note: The Number shown within the box defines the arbitration phase where the particular bit may change state.

Note 1: Note that the STATE Register is updated in each Phase of Arbitration.

Note 2: This is the new Masters Competition Number.

Note 3: Parking is only a Phase 0 event.

Note: "X" means that any Phase can update this bit (or bits).

Note: "," is used in the table to depict the condition where a particular Status bit is Reset and where it is Set (Ex. 0, 1 means that this Status bit is Reset in Phase 0 and Set in Phase 1).

Note: "-" is used in the table to depict the condition where a particular Status bit may change within several sequential phases (Ex. 2-4 means that this Status bit can change in Phases 2, 3, or 4).





# 6.0 The DS3875 Arbitration Controller Support of Locking and Unlocking

The DS3875 Arbitration Controller supports locking and unlocking of the modules resources whether it is a master or a slave (see *Figure 8*).

If the Module becomes master and wishes to lock the slave's resources, it should assert LKD\* (! LKD\*) after receiving bus grant (! BGRNT\* from the arbitration controller), and drive the appropriate lock command during the parallel bus connection phase. This lock command (during the connection phase of the parallel bus) will cause the selected slave module(s) to assert lock (! LKD\*) to their arbitration controller. Once the module has finished its parallel bus transactions it will assert end of tenure (! ENDT\*).

If the Master is in, or enters, Phase 0:

- 1. with end of tenure issued,
- 2. no other module has started an arbitration competition,
- 3. LKD\* is still asserted,
- 4. a new bus request (! BRQ\*) has not been issued

it will start a dummy arbitration competition cycle to unlock all resources on the bus that were locked. The dummy cycle will proceed through the normal arbitration competition except that no bus grant will be asserted if the module wins the arbitration competition.

If another module has initiated an arbitration competition the master will participate in the competition and no dummy cycle will be initiated.

During Phase 5, upon successful completion of the arbitration cycle unlock will be asserted (! UNLK\*) until the lock input is negated.



## 7.0 Register Description

### TOTAL MEMORY MAP

## ADDRESSABLE REGISTERS

## HARDWIRED REGISTER

| 0000 | TXCN0<br>7   |          | (R/W)<br>0 |
|------|--------------|----------|------------|
| 0001 | TXCN1<br>7   |          | (R/W)<br>0 |
| 0010 | TXMSG<br>7   |          | (R/W)<br>0 |
| 0011 | CTRL1<br>7   |          | (R/W)<br>0 |
| 0100 | CTRL2<br>7   |          | (R/W)<br>0 |
| 0101 | CTRL3<br>7   |          | (R/W)<br>0 |
| 0110 | STATE<br>7   |          | (R)<br>0   |
| 0111 | STATUS<br>7  |          | (R)<br>0   |
| 1000 | RXCN0<br>7   |          | (R/W)<br>0 |
| 1001 | RXCN1<br>7   |          | (R/W)<br>0 |
| 1010 | RXMSG<br>7   |          | (R/W)<br>0 |
| 1011 | CLRERI<br>7  |          | (R/W)<br>0 |
| 1100 | CLRMGI<br>7  |          | (R/W)<br>0 |
| 1101 | CLRPFI<br>7  |          | (R/W)<br>0 |
| 1110 |              | Reserved |            |
| 1111 | REV NO.<br>7 |          | (R)<br>0   |

ALL 1s 8

Register Type

Legend:

| Register | Register_Name | (Read/Write) |
|----------|---------------|--------------|
| Address  |               |              |
| ADD(3:0) | MSB           | LSB          |

0

## 7.0 Register Description (Continued)

This section describes the addressable registers and the ALL1s hardwired register.

### 7.1 ALL1S

This register carries the first word of an arbitration message (h'1ff).

### 7.2 TXCN0 (ADD(3:0) = 0000)

For the Unrestricted Mode, this register stores the pass 1 arbitration number of a two pass arbitration. (CN7 = 0). Defaults to h'00.

| 7   | 6      | 5                                           | 4                      | 4 3 2            |                 | 1                 | 0          |  |  |
|-----|--------|---------------------------------------------|------------------------|------------------|-----------------|-------------------|------------|--|--|
| 0   | P7     | P6                                          | P5                     | P4               | P3              | P2                | P1         |  |  |
|     |        |                                             |                        |                  |                 |                   |            |  |  |
| Bit | Symbol |                                             |                        | Descript         | ion             |                   |            |  |  |
| 0-6 | P(1:7) | Priority field of the                       | arbitration numb       | er.              |                 |                   |            |  |  |
| 7   | 0      | This bit is fixed at z two pass arbitration | ero as specified<br>n. | in the Futurebus | + specification | for the pass 1 nu | umber of a |  |  |

Note: The Parity bit CNp for the arbitration number is internally generated during the time the host writes the numbers into the controller. The odd parity as specified in the Futurebus+ specifications is generated. CNp is set to one when even number of ones are present in the arbitration number.

#### 7.3 TXCN1 (ADD(3:0) = 0001)

For the Unrestricted Mode, this register stores the pass 2 arbitration number of a two pass arbitration, or stores the single pass arbitration number (CN7 = 1). This register also stores the arbitration number used in the Restricted Mode. Defaults to h'80.

| 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|
| 1/P1 | P0 | RR | U4 | U3 | U2 | U1 | UO |
|      |    |    |    |    |    |    |    |

| Bit | Symbol | Description                                                                                                                                                                                                                                           |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0-4 | U(0:4) | Uniqueness field of the arbitration number.                                                                                                                                                                                                           |
| 5   | RR     | Round Robin bit of the arbitration number. <b>Note:</b> This bit is updated during phase 5, upon the<br>successful transfer of tenure. See Table III.                                                                                                 |
| 6   | PO     | Priority field of the arbitration number. If configured as a two pass arbitor, P0 is part of P(0:7). If<br>configured as a single pass arbitor, P0 is the priority field. If configured to arbitrate in restricted<br>mode then P0 is part of P(0:1). |
| 7   | 1/P1   | This bit is fixed at one as specified in the spec for the pass 2 number of a two pass arbitration,<br>and for the single pass arbitration number. This bit is P1 for the restricted mode arbitration<br>number.                                       |

Note: The Parity bit CNp for the arbitration number is internally generated during the time the host writes the numbers into the controller. The odd parity as specified in the Futurebus+ specifications is generated. CNp is set to one when even number of ones are present in the arbitration number.

| 7                                                                 | el liolus tile alb                                                                              | itration message to                                                                                                                                                                                                                                         | be transmitted.                                                                                                                                                                     | Defaults to h'ff (I                                                                                                                             | Powerfail).                                                                                                                       |                                                                                               |                                                                 |
|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
|                                                                   | 6                                                                                               | 5                                                                                                                                                                                                                                                           | 4                                                                                                                                                                                   | 3                                                                                                                                               | 2                                                                                                                                 | 1                                                                                             | 0                                                               |
| Α/                                                                | A6                                                                                              | A5                                                                                                                                                                                                                                                          | A4                                                                                                                                                                                  | A3                                                                                                                                              | A2                                                                                                                                | A1                                                                                            | A0                                                              |
| Bit                                                               | Symbol                                                                                          |                                                                                                                                                                                                                                                             |                                                                                                                                                                                     | Descripti                                                                                                                                       | on                                                                                                                                |                                                                                               |                                                                 |
| 0-7                                                               | A(0:7)                                                                                          | Arbitration messag                                                                                                                                                                                                                                          | e to be sent.                                                                                                                                                                       |                                                                                                                                                 |                                                                                                                                   |                                                                                               |                                                                 |
| ote: The Pa<br>ecified in th                                      | arity bit CNp for the<br>ne Futurebus+ spec                                                     | arbitration number is inte<br>ifications is generated. C                                                                                                                                                                                                    | ernally generated d                                                                                                                                                                 | uring the time the hos                                                                                                                          | st writes the number<br>les are present in th                                                                                     | s into the controlle<br>arbitration numbe                                                     | er. The odd parity<br>r.                                        |
| ontrol reg<br>issued b<br>e release<br>hip reset,<br>itialization | gister 1. PS(1:0)<br>efore the releas<br>of ar*. PC(5:0)<br>(RST*) the div<br>n for the desired | programs the delay<br>e of ar*, or, during IE<br>programs the intern<br>ider is set to recei<br>frequency. Default                                                                                                                                          | needed to ensu<br>3A, this delay en<br>al divider to rec<br>ve a clock of 2<br>s to h'14.                                                                                           | re the assertion o<br>nsures there is suf<br>eive a clock input<br>20 MHz. This inpu                                                            | f the most signif<br>fficient time to a<br>from 2 MHz to<br>ut clock divider                                                      | cant 1 in CN(7:<br>ssert the AD/D<br>40 MHz in steps<br>should be pro                         | 0) after comp<br>ATA lines bef<br>s of 1 Mz. Dur<br>grammed dur |
| 7                                                                 | 6                                                                                               | 5                                                                                                                                                                                                                                                           | 4                                                                                                                                                                                   | 3                                                                                                                                               | 2                                                                                                                                 | 1                                                                                             | 0                                                               |
| PS1                                                               | PS0                                                                                             | PC5                                                                                                                                                                                                                                                         | PC4                                                                                                                                                                                 | PC3                                                                                                                                             | PC2                                                                                                                               | PC1                                                                                           | PC0                                                             |
|                                                                   |                                                                                                 |                                                                                                                                                                                                                                                             |                                                                                                                                                                                     |                                                                                                                                                 |                                                                                                                                   |                                                                                               |                                                                 |
| Bit                                                               | Symbol                                                                                          |                                                                                                                                                                                                                                                             |                                                                                                                                                                                     | Descrip                                                                                                                                         | tion                                                                                                                              |                                                                                               |                                                                 |
| 6–7                                                               | PS0-PS1                                                                                         | 1 MHz.         The binary value program the divider to receiv         Programs the ch         PS0       PS1         0       0         1       1         1       1         1       1         1       1         1       1         5       sufficient time for | e of the clock fre<br>der to receive a<br>e a 10 MHz sigr<br>ip to chip skew<br>DELAY<br>0 ns<br>5 ns<br>15 ns<br>25 ns<br>res that after co<br>e put on the bus<br>r asserting AD/ | equency is coded (<br>25 MHz signal PC<br>al PC5:PC0 bits a<br>when releasing A<br>mpete is issued to<br>before releasing<br>(DATA lines during | with PC5 being t<br>55:PC0 bits are:<br>re: 001010.<br>R* in phase 1.<br>the transceiver<br>AR*. It also prov<br>g IBA before the | he MSB. For ex<br>011001. To pro-<br>sufficient time i<br>rides a means to<br>release of ar*. | ample, to<br>gram the<br>s allowed for<br>o provide             |

## 7.0 Register Description (Continued)

7.6 CTRL2 (ADD(3:0) = 0100)

3

Control register 2. This register stores two parameters FS\_(Fast/Slow) and DS\_(Restricted/Unrestricted) that configure the controller to operate in the chosen mode. PD(5:3) selects one of eight delays for the fast module and PD(2:0) selects one of eight delays for the slow module. Defaults to h'00.

|                  | 7                                |                | 6                                           | 5                                                             | 4                                                     | 3                                    | 2                                    | 1                       | 0       |
|------------------|----------------------------------|----------------|---------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------|--------------------------------------|--------------------------------------|-------------------------|---------|
| F.               | _S*                              |                | R_U*                                        | PD5                                                           | PD4                                                   | PD3                                  | PD2                                  | PD1                     | PD0     |
| Bi               | t                                | Sy             | mbol                                        |                                                               |                                                       | Descri                               | ption                                |                         |         |
| 0-               | 0–5 PD0–PD5                      |                | Programs the<br>16 selectable<br>PD3-PD5 se | e arbitration dela<br>e delays, 8 fast a<br>elect the fast mo | ay that is timed<br>and 8 slow. PD0<br>odule's delay. | in a competition<br>)-PD2 select the | . These bits give<br>e slow module's | a total of<br>delay and |         |
|                  |                                  |                |                                             |                                                               | (PD5 PD4 P                                            | D3) Fa                               | ist (PD:                             | 2 PD1 PD0)              | Slow    |
|                  |                                  |                |                                             |                                                               | 000                                                   | 1(                                   | 00                                   | 000                     | 125     |
|                  |                                  |                |                                             |                                                               | 001                                                   | 12                                   | 20                                   | 001                     | 165     |
|                  |                                  |                |                                             |                                                               | 010                                                   | 14                                   | 45                                   | 010                     | 210     |
|                  |                                  |                |                                             |                                                               | 011                                                   | 16                                   | 65                                   | 011                     | 255     |
|                  |                                  |                |                                             |                                                               | 100                                                   | 19                                   | 90                                   | 100                     | 300     |
|                  |                                  |                |                                             |                                                               | 101                                                   | 21                                   | 10                                   | 101                     | 345     |
|                  |                                  |                |                                             |                                                               | 110                                                   | 23                                   | 35                                   | 110                     | 385     |
|                  |                                  |                |                                             |                                                               | 111                                                   | 25                                   | 55                                   | 111                     | 430     |
| 6                |                                  | R              | _U*                                         | R_U*                                                          | Restricted/l                                          | Unrestricted:                        |                                      |                         |         |
|                  |                                  |                |                                             | 0                                                             | Configure                                             | s the controller                     | to arbitrate in ur                   | restricted mode         | ).      |
|                  |                                  |                |                                             | 1                                                             | Configure                                             | s the controller                     | to arbitrate in re                   | stricted mode.          |         |
| 7                |                                  | F.             | S*                                          | F_S*                                                          | Fast/Slow:                                            |                                      |                                      |                         |         |
|                  |                                  |                |                                             | 0                                                             | Configure                                             | s the controller                     | as a slow modu                       | le.                     |         |
|                  |                                  |                |                                             | 1                                                             | Configure                                             | s the controller                     | as a fast module                     | э.                      |         |
| .7 CTI<br>efault | <b>RL3</b> (AE<br>is to h'(<br>7 | DD(3:0)<br>00. | = 0101)<br>6                                | 5                                                             | 4                                                     | 3                                    | 2                                    | 1                       | 0       |
|                  |                                  | Т              | CSEL                                        | IBAPK*                                                        | NCN                                                   | ND_S*                                | NGO                                  | D_S*                    | G0      |
| Bit              | Svn                              | nbol           |                                             |                                                               |                                                       | Description                          |                                      |                         |         |
| 0                | GO                               |                | GO Bit-                                     |                                                               |                                                       |                                      |                                      |                         |         |
| 0                |                                  |                | 1                                           | indicates that a                                              | II the required in                                    | iitialization is co                  | mplete and the                       | controller may a        | ccept   |
|                  |                                  |                | 0                                           | the controller w<br>(bystander).                              | ill follow the nor                                    | rmal flow of arbi                    | itration along wit                   | h other modules         | 3       |
| 1                | D_S                              | S*             | D_S*                                        | Double/Single                                                 |                                                       |                                      |                                      |                         |         |
|                  |                                  |                | 0                                           | Configures the                                                | controller to arb                                     | itrate in a single                   | e pass arbitration                   | ו mode.                 |         |
|                  |                                  |                | 1                                           | Configures the                                                | controller to arb                                     | itrate in a two p                    | ass arbitration n                    | node.                   |         |
| 2                | NGC                              | )              | A "one"                                     | indicates that a ne                                           | ew GO bit has b                                       | een loaded. Thi                      | is bit is reset aut                  | omatically when         | the new |

NGO A "one" indicates that a new GO bit has been loaded. This bit is reset automatically when the new GO bit takes effect. To be set by the user when the GO bit is changed.
 ND\_S\* A "one" indicates that a new D\_S\* bit has been loaded. This bit is reset automatically when the new D\_S\* bit takes effect. To be set by the user when the D\_S\* bit is changed.

|   |        | $D_S^*$ bit takes effect. To be set by the user when the $D_S^*$ bit is changed.                                                                                                          |
|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4 | NCN    | A "one" indicates that a new CN has been loaded. This bit is reset automatically when the new CN takes effect. This bit is set internally when TXCN1 is accessed while the GO bit is set. |
| 5 | IBAPK* | Idle Bus Arbitration/Parking:1Configures the controller to do Idle Bus Arbitration.0Configures the controller to do Parking.                                                              |
| 6 | TCSEL  | A "one" indicates that a test clock is being fed through the CLK pin to test the timers and counters in the controller.                                                                   |
|   |        |                                                                                                                                                                                           |

| 7                                  | 6                                                   | 5                                                                                                     | 4                                                                        | 3                                                                          | 2                            | 1                                             | 0             |
|------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------|-----------------------------------------------|---------------|
|                                    |                                                     | ST5                                                                                                   | ST4                                                                      | ST3                                                                        | ST2                          | ST1                                           | ST0           |
| Bit                                | Symbol                                              |                                                                                                       |                                                                          | Descript                                                                   | ion                          |                                               |               |
| 0-5                                | ST(0:5)                                             | These bits indicat                                                                                    | e the current phas                                                       | e of the arbitrat                                                          | ion controller.              |                                               |               |
| 9 STATL<br>nis registe<br>ts may b | JS (ADD(3:0) =<br>er contains sta<br>e evaluated wh | <ul> <li>0111)</li> <li>tus information and interpretation</li> <li>test feeding in a test</li> </ul> | nternal counter/di<br>clock.                                             | vider test bits. 1                                                         | Γhe M, C, W bits             | default to zero.                              | The counter t |
| 7                                  | 6                                                   | 5                                                                                                     | 4                                                                        | 3                                                                          | 2                            | 1                                             | 0             |
| М                                  | C                                                   | W                                                                                                     | CT2                                                                      | CT1                                                                        | CT0                          |                                               |               |
| Bit                                | Symbol                                              |                                                                                                       |                                                                          | Descript                                                                   | ion                          |                                               |               |
| 2-4                                | CT(0:2)                                             | Counter test bits:<br>CT2—set to one v<br>CT1—set to one v<br>CT0—set to one v                        | when 1 $\mu$ s timeout<br>when divide by 40<br>when divide by n d        | occurs.<br>divider has divid<br>ivider has divide                          | led 40 times.<br>ed n times. |                                               |               |
| 5                                  | W                                                   | Win attribute of th<br>arbitration cycle/r                                                            | e module. A ''one'<br>bass.                                              | ' indicates that                                                           | the module is the            | e winner of the c                             | urrent        |
| 6                                  | С                                                   | Competitor attribu                                                                                    | ite of the module.                                                       | A "one" indicate                                                           | es that the modu             | Ile is competing                              | for the bus.  |
| 7<br>10 BXCN                       |                                                     | Master attribute o                                                                                    | f the module. A "c                                                       | ne" indicates th                                                           | hat the module is            | the current mas                               | ter of the    |
| his regist                         | er stores the re                                    | eceived pass 1 arbit                                                                                  | ration number of a                                                       | a two pass num                                                             | ber (CN = 0). [              | Defaults to h'00.                             |               |
|                                    |                                                     | 5                                                                                                     | 4                                                                        | 3                                                                          | 2                            | 1                                             | 0             |
| 7                                  | 6                                                   |                                                                                                       |                                                                          |                                                                            |                              | P2                                            |               |
| 7<br>0                             | 6<br>P7                                             | P6                                                                                                    | P5                                                                       | P4                                                                         | P3                           | 12                                            | P1            |
| 7<br>0<br>Bit                      | 6<br>P7<br>Symbol                                   | P6                                                                                                    | P5                                                                       | P4<br>Descript                                                             | ion                          | 12                                            | P1            |
| 7<br>0<br><b>Bit</b><br>0-6        | 6<br>P7<br>Symbol<br>P(1:7)                         | Priority field of the the controller is of                                                            | P5                                                                       | P4<br>Descript<br>naster elect arbit<br>te in Unrestricte                  | tration number.              | This register is us                           | P1            |
| 7<br>0<br><b>Bit</b><br>0-6<br>7   | 6<br>P7<br>Symbol<br>P(1:7)<br>0                    | Priority field of the<br>the controller is co<br>This field is fixed a<br>pass arbitration.           | P5<br>e current master/m<br>onfigured to arbitra<br>at zero as specified | P4<br>Descript<br>naster elect arbitte in Unrestricte<br>d in the Futurebo | P3                           | This register is us<br>le.<br>e pass 1 number | ed only if    |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                            | 6                                                                                                                                                                                                                                  | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                                                                                                 | 3                                                                                                   | 2                                                                           | 1                                        | 0                                         |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------|-------------------------------------------|--|
| 1/P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                          | P0                                                                                                                                                                                                                                 | RR                                                                                                                                                                                                                                                                                                                                                                                                                                                           | U4                                                                                                                | U3                                                                                                  | U2                                                                          | U1                                       | U0                                        |  |
| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Symbol                                                                                                                                     |                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                   | Descript                                                                                            | ion                                                                         |                                          |                                           |  |
| 0-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | U(0:4)                                                                                                                                     | Unic                                                                                                                                                                                                                               | ueness field o                                                                                                                                                                                                                                                                                                                                                                                                                                               | f the current mast                                                                                                | er/master elect                                                                                     |                                                                             |                                          |                                           |  |
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RR                                                                                                                                         | Rou                                                                                                                                                                                                                                | nd Robin bit of                                                                                                                                                                                                                                                                                                                                                                                                                                              | the current maste                                                                                                 | er/master elect.                                                                                    |                                                                             |                                          |                                           |  |
| 6<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P0<br>1/P1                                                                                                                                 | Prior<br>P(0:<br>restr<br>This<br>and<br>num                                                                                                                                                                                       | Priority field of the current master/master elect. If configured as a two pass arbitor, P0 is part of P(0:7). If configured as a single pass arbitor, P0 is the priority field. If configured to arbitrate in restricted mode then P0 is part of P(0:1). This field is fixed at one as specified in the spec for the pass 2 number of a two pass arbitration, and for the single pass arbitration number. This bit is P1 for the restricted mode arbitration |                                                                                                                   |                                                                                                     |                                                                             |                                          |                                           |  |
| 12 RXM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>SG</b> (ADD(3:0<br>ter stores the                                                                                                       | )) = 1010<br>e received                                                                                                                                                                                                            | )<br>d non-powerfai                                                                                                                                                                                                                                                                                                                                                                                                                                          | I arbitration mess                                                                                                | age. Defaults to                                                                                    | o h'00.                                                                     |                                          |                                           |  |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                            | 6                                                                                                                                                                                                                                  | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                                                                                                 | 3                                                                                                   | 2                                                                           | 1                                        | 0                                         |  |
| A7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                            | A6                                                                                                                                                                                                                                 | A5                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A4                                                                                                                | A3                                                                                                  | A2                                                                          | A1                                       | A0                                        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                            |                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                   |                                                                                                     |                                                                             |                                          |                                           |  |
| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Symbol                                                                                                                                     |                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                   | Descript                                                                                            | ion                                                                         |                                          |                                           |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits t<br>e error b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>pits. Defaults                                                                        | Non<br>) = 1011<br>arity, no B<br>to h'00.                                                                                                                                                                                         | -powerfail arbit<br>)<br>BRQ/MGRQ or                                                                                                                                                                                                                                                                                                                                                                                                                         | ration message r                                                                                                  | Descript<br>eceived from an<br>A dummy write i                                                      | ion<br>other module.<br>into this register                                  | clears the erro                          | or interrupt and                          |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits to<br>be error b<br>7<br>ER3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>oits. Defaults<br>E                                                                   | Non<br>)) = 1011<br>arity, no E<br>to h'00.<br>6<br>ER2                                                                                                                                                                            | -powerfail arbit<br>)<br>3RQ/MGRQ or<br>5<br>ER1                                                                                                                                                                                                                                                                                                                                                                                                             | a timeout error.                                                                                                  | Descript<br>eceived from ar<br>A dummy write<br>3                                                   | ion<br>nother module.<br>into this register<br>2                            | clears the erro                          | or interrupt and                          |  |
| Bit<br>0-7<br>13 CLRi<br>rror bits t<br>re error b<br>7<br>ER3<br>Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Symbol<br>A(0:7)<br>ERI (ADD(3:(<br>to indicate P<br>bits. Defaults<br>E<br>Symbol                                                         | Non<br>) = 1011<br>arity, no E<br>to h'00.<br>6<br>ER2                                                                                                                                                                             | -powerfail arbit<br>)<br>3RQ/MGRQ or<br>5<br>ER1                                                                                                                                                                                                                                                                                                                                                                                                             | ration message r<br>a timeout error<br>4                                                                          | Descript<br>eceived from ar<br>A dummy write<br>3<br>Descripti                                      | ion<br>nother module.<br>into this register<br>2                            | clears the erro                          | or interrupt and                          |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits<br>te error b<br>7<br>ER3<br>Bit<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>oits. Defaults<br>ER3                                                                 | Non           )) = 1011           arity, no E           to h'00.           6           ER2           Erron           pres                                                                                                          | -powerfail arbit<br>)<br>BRQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.                                                                                                                                                                                                                                                                                                                                                                                | a timeout error.<br>4<br>s to the winner of                                                                       | Descript eceived from ar A dummy write 3 Descripti the arbitration of                               | ion<br>nother module.<br>into this register<br>2<br>ion<br>cycle that BRQ/M | clears the erro<br>1<br>//GRQ signal is  | or interrupt and<br>0                     |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits to<br>rror bits to<br>r<br>Bit<br>r<br>6 | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>oits. Defaults<br>ER3<br>ER2                                                          | Non<br>)) = 1011<br>arity, no E<br>to h'00.<br>6<br>R2<br>Errou<br>pres<br>Errou                                                                                                                                                   | -powerfail arbii<br>)<br>3RQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate                                                                                                                                                                                                                                                                                                                                                           | a timeout error.                                                                                                  | Descript eceived from ar A dummy write i 3 Descripti the arbitration of                             | ion<br>nother module.<br>into this register<br>2<br>ion<br>cycle that BRQ/M | clears the erro<br>1<br>//GRQ signal is  | or interrupt and<br>0                     |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits to<br>e error to<br>7<br>ER3<br>Bit<br>7<br>6<br>5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Symbol<br>A(0:7)<br>ERI (ADD(3:C<br>to indicate P<br>bits. Defaults<br>ERI<br>ER3<br>ER2<br>ER1                                            | Non )) = 1011 arity, no E to h'00. 6 Erroi pres Erroi Erroi Erroi Erroi                                                                                                                                                            | -powerfail arbit<br>)<br>3RQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate<br>r bit 1: indicate                                                                                                                                                                                                                                                                                                                                      | a timeout error.<br>4<br>s to the winner of<br>s a timeout error.<br>s a Parity error.                            | Descript<br>eceived from an<br>A dummy write<br>3<br>Descripti<br>the arbitration o                 | ion<br>iother module.<br>into this register<br>2<br>ion<br>cycle that BRQ/M | clears the erro<br>1<br>//GRQ signal is  | or interrupt and<br>0                     |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits<br>e error b<br>7<br>ER3<br>Bit<br>7<br>6<br>5<br>14 CLRI<br>15 CLRI<br>dummy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>oits. Defaults<br>ER3<br>ER2<br>ER1<br>MGI (ADD(3:0<br>write into th                  | Non           )) = 1011           arity, no E           to h'00.           6           R2           Erroi           pres           Erroi           Erroi           0) = 1100           0) = 1101           ese regist              | -powerfail arbit<br>)<br>3RQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate<br>r bit 1: indicate<br>0)<br>)<br>ers clears the                                                                                                                                                                                                                                                                                                         | a timeout error.                                                                                                  | Descript eceived from ar A dummy write i 3 Descripti the arbitration o                              | ion<br>into this register<br>2<br>ion<br>cycle that BRQ/M                   | clears the erro                          | or interrupt and<br>0<br>s no longer      |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits to<br>e error to<br>7<br>ER3<br>Bit<br>7<br>6<br>5<br>14 CLRI<br>15 CLRI<br>dummy<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>bits. Defaults<br>ER1<br>ER3<br>ER2<br>ER1<br>MGI (ADD(3:0<br>write into th           | Non           )) = 1011           arity, no E           to h'00.           6           Erroi           pres           Erroi           Erroi           0) = 1100           0) = 1101           ess regist           6               | -powerfail arbit<br>)<br>BRQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate<br>r bit 1: indicate<br>controls<br>p)<br>ters clears the<br>5                                                                                                                                                                                                                                                                                            | a timeout error.<br>4<br>s to the winner of<br>s a timeout error.<br>s a Parity error.<br>respective interru<br>4 | Descript<br>eceived from an<br>A dummy write i<br>3<br>Descripti<br>the arbitration of<br>upt.<br>3 | ion<br>iother module.<br>into this register<br>2<br>ion<br>cycle that BRQ/M | clears the erro                          | or interrupt and<br>0<br>s no longer<br>0 |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits +<br>e error b<br>RR3<br>Bit<br>7<br>6<br>5<br>14 CLRI<br>15 CLRI<br>dummy<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>oits. Defaults<br>ER3<br>ER2<br>ER1<br>MGI (ADD(3:0<br>write into th                  | Non           )) = 1011           arity, no E           to h'00.           6           R2           Erroi           pres           Erroi           Erroi           0) = 1100           0) = 1101           ese regist           6  | -powerfail arbii<br>)<br>3RQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate<br>r bit 1: indicate<br>0)<br>)<br>ters clears the<br>5                                                                                                                                                                                                                                                                                                   | a timeout error.                                                                                                  | Descript eceived from ar A dummy write i 3 Descripti the arbitration o upt. 3                       | ion iother module. into this register 2 ion con cycle that BRQ/M            | clears the erro                          | or interrupt and<br>0<br>s no longer<br>0 |  |
| Bit<br>0-7<br>13 CLRI<br>rror bits te error to<br>7<br>ER3<br>Bit<br>7<br>6<br>5<br>14 CLRI<br>dummy<br>7<br>Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Symbol<br>A(0:7)<br>ERI (ADD(3:0<br>to indicate P<br>bits. Defaults<br>ER3<br>ER3<br>ER2<br>ER1<br>MGI (ADD(3:0<br>write into th<br>Symbol | Non           )) = 1011           arity, no E           to h'00.           6           :R2           Erroi           pres           Erroi           Erroi           D) = 1100           )) = 1101           ese regist           6 | -powerfail arbit<br>)<br>3RQ/MGRQ or<br>5<br>ER1<br>r bit 3: indicate<br>ent.<br>r bit 2: indicate<br>r bit 1: indicate<br>p)<br>)<br>ers clears the<br>5                                                                                                                                                                                                                                                                                                    | a timeout error.                                                                                                  | Descript eceived from ar A dummy write i 3 Descripti the arbitration o upt. 3 Descript              | ion iother module. into this register 2 ion cycle that BRQ/M 2 ion          | clears the error<br>1<br>//GRQ signal is | or interrupt and<br>0<br>s no longer<br>0 |  |



## 8.0 Programming Registers

During power up, the registers should be initially programmed. The host may read/write to/from the register block at any time. The host may select to write data into the register either on the falling edge of DSACK\* or on the rising edge of CS\*. A zero on the SEL input pin configures the controller to latch in data on the falling edge of DSACK\* while a one sets the controller to latch in data on the rising edge of CS\*. Refer to the timing diagrams (see *Figures T2a*, *b*, *c*).

#### 8.1 HOST WRITE CYCLE USING FALLING EDGE OF DSACK\* (Figure T2A)

1. R\_W\* signal is negated.

ADD(3:0) contains the address of the register to be accessed. (Note: The setup time with respect to  $\rm CS^*$  must be satisfied.)

- 2. CS\* is asserted (! CS\*).
- 3. When the proper setup time of CS\* to the rising edge of clock is met and CS\* is low for at least 3 clock cycles, then DATA(7:0) will be latched into the register, by the falling edge of DSACK\*, on the 3rd rising clock edge after the assertion of CS\*. If the CS\* setup time is not met and CS\* is low for at least 3 clock cycles, then DSACK\* is asserted and the data (DATA(7:0)) is latched into the arbitration register on the following 3rd or 4th rising clock edge after the assertion of CS\*. If CS\* is negated (CS\*) before 3 clock cycles, then DSACK\* is not generated and as a default, DATA (7:0) is latched into the arbitration controller register on the rising edge of CS\*.
- 4. Host negates CS\*.
- 5. Arbitration Controller negates DSACK\* (DSACK\*) if it was asserted.

## 8.2 HOST WRITE CYCLE USING RISING EDGE OF CS\* (Figure T2b)

1. R\_W\* signal is negated.

ADD(3:0) contains the address of the register to be accessed. (Note: The setup time with respect to CS\* must be satisfied.)

- 2. CS\* is asserted (! CS\*).
- 3. DSACK\* is asserted (! DSACK\*) by the Arbitration Controller when CS\* is asserted for at least three clock cycles. If CS\* is negated (CS\*) before three clock cycles, DSACK\* is not asserted. The DSACK\* signal may be used or ignored by the system designer, in this case.
- Host negates CS\*. DATA (7:0) which satisfied the setup time to the rising edge of CS\* is latched into the arbitration controller register.
- Arbitration Controller negates DSACK\* (DSACK\*) if it was asserted.

#### 8.3 HOST READ CYCLE (Figure T2c)

1. R\_W\* signal is set high.

ADD (3:0) contains the address of the register to be accessed. (Note: The setup time with respect to  $CS^{\,\ast}$  must be satisfied.)

- 2. CS\* is asserted (! CS\*).
- 3. The data will be available on the DATA (7:0) bus within the access time specified in the AC timing section.
- 4. The Data Strobe ACKnowledge (DSACK\*) signal is generated as an acknowledge to the host signifying the validity of the accessed data. DSACK\* may be used to insert WAIT states to the host during a host read cycle. When the proper setup time of CS\* to the rising edge of clock is met and CS\* is low for at least three clock cycles, DSACK\* is asserted (! DSACK\*) on the 3rd rising clock edge after the assertion of CS\*. If the CS\* setup time was not met and CS\* is low for at least three clock cycles, the DSACK\* is asserted on the following 3rd or 4th rising clock edge after the assertion of CS\*. If CS\* is not low for at least 3 clock cycles, DSACK\* is not generated.
- 5. Host reads data and negates CS\* (CS\*).
- Arbitration Controller negates DSACK\* (DSACK\*) if it was asserted.

#### 9.0 Clock/Timer/Delay Lines

(See *Figure 9*.) The input clock signal (CLK) to the arbitration controller is assumed to be a clock from 2 MHz to 40 MHz, in steps of 1 MHz.

The clock signal is also used for synchronization purposes during read or write transfers. This is accomplished by synchronizing the DSACK\* (Data Strobe Acknowledge) output from the Arbitration Controller to the clock during arbitration controller register reads or writes.

The binary value of the input clock (CLK) frequency is loaded into the CTRL1 [5:0] register. This value is used to program the divide by n counter to scale the input clock down to a 1 MHz clock internally. The PLL ring oscillator also has a clock divider (divide by 40) to scale it down to a 1 MHz clock. These two clocks are compared and the difference between the two clocks is fed back to the ring oscillator to cause it to lock onto the appropriate frequency.

The PLL is used to generate several programmable delay lines and the 1  $\mu$ s Timer used during phase 2 and phase 4.

The 1  $\mu s$  timer, divide by 40 divider and divide by n divider can be tested to determine proper functionality. Refer to Testing the Arbitration Controller and Register Description sections for details.



### 10.0 Reset/Initialization/Power Up

Two distinct input reset pins are available on the Arbitration Controller, RINT\* (Bus Reset and Initialization) and RST\* (Power Up Reset). These signals are activated by the module upon detecting either RE\* (in an appropriate condition) on Futurebus + or reset from the host or the Protocol Controller. Both these signals are asynchronous inputs so that the reset function is performed immediately after the signal is asserted.

RINT\* may be asserted by external logic from RE\* being asserted for at least 2 ms or some other appropriate condition. When RINT\* is asserted (! RINT\*):

- 1. the arbitration controller is placed in phase 0
- 2. all outputs of the arbitration controller are negated, except ARO
- The following registers are cleared: RXCN0, RXCN1, RXMSG, CLRERI, CLRMGI, CLRPFI, and M C W bits of the STATUS register
- 4. ST0 bit is set in the STATE register

 Contents of other registers remain, except for the round robin (RR) bit of TXCN1 which is reset.

The rising edge of RINT\* will release the arbiter from phase 0. This reset signal should be used during Futurebus + initialization.

When RST\* is asserted (! RST\*):

- 1. all outputs of the arbitration controller are negated
- 2. the registers are set to default values as given in the register description, Section 7.

The rising edge of RST\* will cause ARO to be asserted causing the arbiter to be in phase 0. This reset signal should be used during power-up and live withdrawal.

Figure 10 illustrates how the reset and initialization signals may be used during power up. While powering up, when RINT\* is asserted for 100 ms-200 ms, the registers may be programmed. BRQ\* should not be issued until after 10 ms after the register CTRL1 is programmed giving the PLL a sufficient time to lock onto the CLK signal.



## **11.0 Live Insertion**

The arbitration Controller supports live insertion (see Figure 11). When a module is being live inserted into an active Futurebus+ system it will be powered up and reset. The live inserted module will reset it's arbitration controller with the RST\* input and will drive re\* on the Futurebus+ backplane.

RE\* asserted will cause all active Futurebus+ modules to release their bus lines to prepare for live insertion to the Futurebus+ backplane.

When all the active Futurebus+ modules detect RE\* asserted, they should assert HALT\* to their arbitration controller and limit the current parallel bus transaction to 128  $\mu s$ . The active modules will then remain in Phase 0, upon completion of the current control acquisition cycle, until HALT\* is negated.

When the live inserted module detects both:

1. the Parallel bus in the Idle state (AS\* and AKf negated),

2. the arbitration bus lines in Phase 0

for 1  $\mu s$  then it should assert ai\* (protocol controller) and negate the RST\* input. The arbitration controller will assert ARO upon detecting the negation of RST\*. These actions will complete the Futurebus+ alignment. The live inserted module will then be in arbitration Phase 0; thus, aligned with the other live modules. Then the live inserted module will negate re\*.

When the active modules detect the negation of  $RE^*$  they negate the HALT\* input to their arbitration controllers, thus allowing arbitration competition to proceed.

At this point, the live inserted module can only participate as a by-stander during the arbitration competition cycle until it is programmed and 10 ms has elapsed (PLL lock on time). Once the 10 ms has elapsed the module can enable arbitration competition by setting the GO bit in CTRL3. At this time bus requests (BRQ\*, MGRQ\*) can be accepted to join competition for the parallel bus.



FIGURE 11. Live Insertion

### 12.0 Live Withdrawal

When a module is notified to be live withdrawn it will:

- 1. complete any tasks currently in progress
- 2. inhibit itself from participating in any more bus transactions (becomes a by-stander)

The module can withdraw from the arbitration protocol in one of three phases:

- 1. During phase 0 by negating ARO
- 2. During phase 2 by negating APO
- 3. During phase 4 by negating AQO

This may be achieved in the DS3875 by issuing the HALT\* signal, then when it is observed that the arbitration controller is in Phase 0, asserting the RST\* signal to cause all outputs of the arbitration bus to be released. The module may then be withdrawn from the Futurebus+ system.

#### 13.0 Testing the DS3875

The Arbitration Controller has features designed in which ease the testing and monitoring tasks for the user. Registers may be read to determine proper functionality of the chip. For instance, while the Arbitration Controller is operating, the arbitration phase can be monitored by reading the state register. Also to check proper operation of the 1  $\mu$ s timer, divide by n divider, and divide by 40 divider, the TCSEL bit in CTRL3 register can be set so that a test clock may be used. This will allow the clock signal to be applied to the circuitry, thus disabling the internally generated signals that are used during normal operation. See *Figure 10.* To determine the status of the timer and dividers, the status register CT(0:2) bits can be read.

If the user wants to check the proper operation of the CN port:

- An arbitration number can be loaded into the CN port by performing a write cycle to any of the receive registers (RXCN0, RXCN1, or RXMSG). The Arbitration Controller will load the number from the CN port instead of the DATA port into the register upon detecting a write to any of the receive registers. The timing is the same as those given for the register write using the DATA port. Refer to Timing Section T2.
- Next, by performing a read cycle to the register just written to (RXCN0, RXCN1, or RXMSG), the arbitration number stored will be placed onto the DATA port. Thus, the proper operation of the CN port is tested.

## **14.0 Electrical Characteristics**

### **Absolute Maximum Ratings**

Lead Temperature

 

 If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

 Supply Voltage
 6.5V

 Control Input Voltage
 5.5V

 Power Dissipation at 70°C
 0.6W

 Storage Temperature Range
 -65°C to + 150°C

# Recommended Operating Conditions

|                                                   | Min | Max | Units |
|---------------------------------------------------|-----|-----|-------|
| Supply Voltage, V <sub>DD</sub>                   | 4.5 | 5.5 | V     |
| Operating Free Air Temperature                    | 0   | 70  | С     |
| ESD Tolerance:                                    |     |     |       |
| $C_{ZAP} = 120 \text{ pF}, R_{ZAP} = 1500 \Omega$ |     |     | 2kV   |

### **Electrical Characteristics** (Notes 2 and 3) $T_A = 0^{\circ}C$ to $+70^{\circ}C$ , $V_{CC} = 5V \pm 10\%$

260°C

| Symbol          | Parameter                  | Conditions                                                                          | Min  | Тур  | Max | Units |
|-----------------|----------------------------|-------------------------------------------------------------------------------------|------|------|-----|-------|
| V <sub>IH</sub> | Minimum Input High Voltage |                                                                                     | 2.8  |      |     | V     |
| VIL             | Minimum Input Low Voltage  |                                                                                     |      |      | 0.8 | V     |
| V <sub>OH</sub> | Voltage Output High        | $I_{OH},I_{OL}$ for Several Drivers i.e., $I_{OL}$ 4 mA                             | 2.4  | 3.2  |     | v     |
| V <sub>OL</sub> | Voltage Output Low         | I <sub>OH</sub> , I <sub>OL</sub> for Several Drivers<br>i.e., I <sub>OL</sub> 8 mA |      | 0.35 | 0.5 | v     |
| l <sub>l</sub>  | Input Leakage Current      | Input at $V_{DD}$ or $V_{SS}$                                                       | -1.0 |      | 1.0 | μΑ    |
| I <sub>IH</sub> | Input High Current         | Input at V <sub>IH</sub>                                                            |      |      | 1.0 | μΑ    |
| IIL             | Input Low Current          | Input at V <sub>IL</sub>                                                            | -1.0 |      |     | μA    |
| I <sub>DD</sub> | Supply Current             | Dynamic Supply Current                                                              |      |      | 100 | mA    |
| Icc             | Static Supply Current      | Input at Standby                                                                    |      |      | 30  | mA    |

Note 1: "Absolute maximum ratings" are those beyond which the safety of the device cannot be guaranteed. They are not meant to imply that the device should be operated at these limits. The table of "Electrical Characteristics" provide conditions for actual device operation.

Note 2: All currents into device pins are positive; all currents out of device pin are negative. All voltages are referenced to device ground unless otherwise specified.

Note 3: All typicals are given for  $V_{\text{DD}}$  = 5V, and  $T_{\text{A}}$  = 25°C.

## 15.0 AC Parameters

#### Legend to AC Parameter Number Assignments

| Parameter<br>Number | Description                         |
|---------------------|-------------------------------------|
| t000-t099           | Phase 0                             |
| t100-t199           | Phase 1                             |
| t200-t299           | Phase 2                             |
| t300-t399           | Phase 3                             |
| t400-t499           | Phase 4                             |
| t500-t599           | Phase 5                             |
| tAXX                | Reset, Initialization               |
| tBXX                | Register Access Data Port           |
| tCXX                | Register Access CN Port - Input     |
| tDXX                | Clearing Interrupts                 |
| tEXX                | FIFO Strobe                         |
| tFXX                | WIN*GT* Valid                       |
| tGXX                | Message Signals                     |
| tHXX                | Busrequest, Busgrant, End of Tenure |
| tJXX                | Locked, Unlock Handshake Signals    |

## 15.0 AC Parameters (Continued)

**AC Timing Parameters** Unless otherwise stated:  $T_A = 0^{\circ}C \text{ to } + 70^{\circ}C$ ,  $V_{CC} = 5V \pm 10\%$ All transitions are specified after the input signals are stable and valid for evaluation. This table will describe the parameters as given in the following pages. All values are given in nanoseconds (ns), unless otherwise stated.

| Number           | Symbol               | Parameter Description                                                             | Min       | Тур               | Max               |
|------------------|----------------------|-----------------------------------------------------------------------------------|-----------|-------------------|-------------------|
| t <sub>1</sub>   | t <sub>BQBG</sub>    | BRQ* Asserted to BGRNT* Asserted                                                  |           | 19                | 33                |
| t <sub>2</sub>   | t <sub>AQAC</sub>    | AQI Negated to AC0O, AC1O Negated                                                 |           | 22                | 30                |
| t <sub>3</sub>   | t <sub>APIO</sub>    | API Asserted to APO Asserted                                                      |           | 16                | 26                |
| t <sub>4</sub>   | t <sub>RQAP</sub>    | MGRQ* or BRQ* Asserted to APO Asserted                                            |           | 19                | 32                |
| t <sub>5</sub>   | t <sub>EDAP</sub>    | (Dummy Cycle) ENDT* Asserted to APO Asserted                                      |           | 28                | 40                |
| t <sub>6</sub>   | t <sub>BQAP</sub>    | (Consecutive Bus Requests) BRQ* Asserted to APO Asserted                          |           | 17                | 28                |
| t <sub>7</sub>   | t <sub>HTAP</sub>    | HALT* Negated to APO Asserted                                                     |           | 16                | 26                |
| t <sub>100</sub> | <sup>t</sup> CNLEAR  | CN_LE* Negated to ARO Negated. Determined by Programmable Value                   |           | 2+(0-25)          | 4+(0-25)          |
| t <sub>101</sub> | t <sub>CNLE</sub>    | CN_LE* Width                                                                      | 18        | 20                | 26                |
| t <sub>102</sub> | t <sub>CNS</sub>     | CN Port Setup Time                                                                | 23        | 28                |                   |
| t <sub>103</sub> | t <sub>CNZ</sub>     | ARI Negated to TRI-STATE CN Port                                                  | 16        | 20                |                   |
| t <sub>104</sub> | t <sub>IBCAR</sub>   | (IBA Mode) IBA-CMPT* Asserted to ARO Negated. Determined by<br>Programmable Value | 20+(0-25) | 30+(0-25)         |                   |
| t <sub>105</sub> | <sup>t</sup> CPTAR   | CMPT* Asserted to ARO Negated. Determined by Programmable Value                   | 20+(0-25) | 30+(0-25)         |                   |
| t <sub>106</sub> | t <sub>AC0AR</sub>   | (Slow Mode) AC0O Asserted to ARO Negated. Determined by<br>Programmable Value     | 20+(0-25) | 30+(0-25)         |                   |
| t <sub>107</sub> | t <sub>APCNLE</sub>  | APO Asserted to CN-LE* Asserted. CTRL3[0], "G0" Bit is Set                        |           | 22                | 32                |
| t <sub>108</sub> | t <sub>APCPTA</sub>  | APO Asserted to CMPT* Asserted                                                    |           | 14                | 22                |
| t <sub>109</sub> | t <sub>APIBC</sub>   | APO Asserted to IBA_CMPT* Asserted                                                |           | 13                | 18                |
| t <sub>110</sub> | t <sub>APAC</sub>    | APO Asserted to AC0O Asserted (Slow Mode)                                         |           | 18                | 28                |
| t <sub>200</sub> | t <sub>ARABRD</sub>  | ARI Negated to AB_RE* Asserted                                                    |           | 52                | 62                |
| t <sub>201</sub> | t <sub>ARIBS</sub>   | (IBA Mode) ARI Negated to IBA_S*. $T_A = Arbitration Timer 60-300$                |           | TA                | TA                |
| t <sub>202</sub> | t <sub>IBSBG</sub>   | (IBA Mode) IBA_S* Asserted to BGRNT* Asserted                                     |           | 19                | 33                |
| t <sub>203</sub> | t <sub>WINAQ</sub>   | WIN*GT* Asserted to AQO Asserted. After T <sub>A</sub> Expired.                   |           | 18                | 29                |
| t <sub>204</sub> | t <sub>AQIO</sub>    | AQI Asserted to AQO Asserted                                                      |           | 13                | 20                |
| t <sub>205</sub> | t <sub>ARAQ</sub>    | ARI Negated to AQO Asserted                                                       |           | 18+T <sub>A</sub> | 28+T <sub>A</sub> |
| t <sub>207</sub> | t <sub>IBSAQ</sub>   | (IBA Mode) IBA-S* Asserted to AQO Asserted                                        |           | 20                | 33                |
| t <sub>300</sub> | t <sub>AC10AP</sub>  | AC10 Asserted to APO Negated                                                      |           | 15                | 29                |
| t <sub>301</sub> | t <sub>ASNAP</sub>   | AS_Cancel* Negated to APO Negated                                                 |           | 15                | 24                |
| t <sub>310</sub> | t <sub>APABRD</sub>  | APO Negated to ABRE* Negated                                                      |           | 5                 | 8                 |
| t <sub>320</sub> | t <sub>AQAC1</sub>   | AQO Asserted to AC1O Asserted                                                     |           | 6                 | 10                |
| t <sub>321</sub> | t <sub>AC1IAPN</sub> | AC1I Asserted to APO Negated                                                      | 7         | 12                | 18                |
| t <sub>322</sub> | t <sub>ASAAP</sub>   | AS_Cancel* Asserted to APO Negated                                                | 7         | 12                | 18                |
| t <sub>330</sub> | t <sub>AC1IAP</sub>  | AC1I Asserted to APO Negated                                                      |           | 13                | 22                |
| t <sub>340</sub> | t <sub>RQAC</sub>    | MGRQ* or BRQ* Negated to AC0O, AC1O Asserted                                      |           | 21                | 32                |
| t <sub>341</sub> | t <sub>AQAC0</sub>   | AQO Asserted to AC0O Negated                                                      |           | 0                 | 3                 |
| t <sub>342</sub> | t <sub>AQER</sub>    | AQO Asserted to ERIT* Asserted                                                    |           | 14                | 22                |
| t <sub>400</sub> | t <sub>APCPTN</sub>  | API Negated to CMPT* Negated                                                      |           | 18                | 30                |

## 15.0 AC Parameters (Continued)

**AC Timing Parameters** Unless otherwise stated:  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ ,  $V_{CC} = 5V \pm 10\%$  (Continued) All transitions are specified after the input signals are stable and valid for evaluation. This table will describe the parameters as given in the following pages. All values are given in nanoseconds (ns), unless otherwise stated.

| Number           | Symbol               | Parameter Description                                         | Min | Тур      | Max |
|------------------|----------------------|---------------------------------------------------------------|-----|----------|-----|
| t <sub>401</sub> | t <sub>AC1IAR</sub>  | AC1I Asserted to ARO Asserted                                 |     | 12       | 21  |
| t <sub>403</sub> | t <sub>CANAC1</sub>  | AS_Cancel* Asserted to AC1O Asserted                          | 7   |          | 19  |
| t <sub>405</sub> | t <sub>ARIO</sub>    | ARI Asserted to ARO Asserted                                  |     | 14       | 19  |
| t <sub>407</sub> | t <sub>EDAR</sub>    | ENDT* Asserted to ARO Asserted                                |     | 15       | 25  |
| t <sub>500</sub> | t <sub>ARBG</sub>    | ARO Asserted to BGRNT* Asserted                               |     | 7        | 12  |
| t <sub>501</sub> | tOAQ                 | BGRNT*, MGTX*, UNLK* or any Interrupt Asserted to AQO Negated | 5   | 7        |     |
| t <sub>502</sub> | t <sub>ARFTR</sub>   | ARO Asserted to FSTR* Negated                                 |     | 5        | 8   |
| t <sub>503</sub> | t <sub>ARIBC</sub>   | ARO Asserted to IBA_CMPT* Negated                             |     | 5        | 8   |
| t <sub>504</sub> | t <sub>ARABSA</sub>  | ARO Asserted to MGTX*, UNLK* or any Interrupt Asserted        |     | 5        | 9   |
| t <sub>A1</sub>  | t <sub>RSTPW</sub>   | RST* Pulse Width                                              | 50  | 50       |     |
| t <sub>A2</sub>  | t <sub>RSTRE</sub>   | Output Reset Time                                             |     | 30       | 45  |
| t <sub>A3</sub>  | t <sub>RSTAR</sub>   | RST* Negated to ARO Asserted                                  |     | 15       | 25  |
| t <sub>A4</sub>  | t <sub>RINTPW</sub>  | RINT* Pulse Width                                             | 50  | 50       |     |
| t <sub>A5</sub>  | t <sub>RINTRE</sub>  | Output Initialization Reset Time                              |     | 30       | 45  |
| t <sub>B1</sub>  | t <sub>CSPW</sub>    | CS* Pulse Width                                               | 35  |          |     |
| t <sub>B2</sub>  | t <sub>CSPWN</sub>   | CS* Recovery Time                                             | 15  |          |     |
| t <sub>B3</sub>  | t <sub>CSDKA</sub>   | CS* Asserted to DSACK* Asserted                               |     | 12       | 18  |
| t <sub>B4</sub>  | t <sub>ADDS</sub>    | ADD (3:0) Setup Time                                          | 5   | 2        |     |
| t <sub>B5</sub>  | t <sub>ADDH</sub>    | ADD (3:0) Hold Time                                           | 6   | 5        |     |
| t <sub>B6</sub>  | t <sub>CSDKN</sub>   | CS* Negated to DSACK* Negated                                 | 7   | 12       |     |
| t <sub>B7</sub>  | t <sub>RWS</sub>     | R_W* Setup Time                                               | 0   |          |     |
| t <sub>B8</sub>  | t <sub>SELS</sub>    | SEL Setup Time                                                | 0   |          |     |
| t <sub>B10</sub> | t <sub>DATASDK</sub> | Data (7:0) Setup Time with Respect to DSACK*                  | 24  | 15       |     |
| t <sub>B11</sub> | t <sub>DATAHDK</sub> | Data (7:0) Hold Time with Respect to DSACK*                   | 0   | 0        |     |
| t <sub>B12</sub> | t <sub>SELH</sub>    | SEL Hold Time                                                 | 3   |          |     |
| t <sub>B24</sub> | t <sub>DATASCS</sub> | Data (7:0) Setup Time with Respect to CS* Negated             | 15  | 6        |     |
| t <sub>B25</sub> | t <sub>DATAHCS</sub> | Data (7:0) Hold Time with Respect to CS* Negated              | 5   | 5        |     |
| t <sub>B27</sub> | t <sub>DATALZ</sub>  | Data (7:0) Low Z Time                                         |     | 14       | 22  |
| t <sub>B28</sub> | t <sub>DATAV</sub>   | Data (7:0) Valid Time before DSACK*                           |     |          |     |
| t <sub>B29</sub> | t <sub>DATAA</sub>   | Data (7:0) Access Time with Respect to CS* Asserted           |     | 22       | 30  |
| t <sub>B30</sub> | t <sub>DATAHRC</sub> | Data (7:0) Hold Time                                          | 6   | 10       |     |
| t <sub>B31</sub> | t <sub>DATAHZ</sub>  | Data (7:0) Hi-Z Time                                          |     | 12       | 25  |
| t <sub>C2</sub>  | t <sub>ABRDCNZ</sub> | AB_RE* Negated to CN (7:0) TRI-STATE                          | 0   | 0        |     |
| t <sub>D1</sub>  | t <sub>CSXINTN</sub> | CS* Asserted to any Interrupt Negated                         |     | 22       | 36  |
| t <sub>E1</sub>  | t <sub>FSTR</sub>    | FSTR* Recovery Time                                           | 80  |          |     |
| <sup>t</sup> E1  | <sup>I</sup> FSTR    | LOTH, Hecovery lime                                           | 80  | <u> </u> |     |



























National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications