# QSpan II (CA91L862A) PCI-to-Motorola Processor Bridge Manual



www.tundra.com

The information in this document is subject to change without notice and should not be construed as a commitment by Tundra Semiconductor Corporation. While reasonable precautions have been taken, Tundra Semiconductor Corporation assumes no responsibility for any errors that may appear in this document.

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of Tundra Semiconductor Corporation.

Tundra® products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Tundra product could create a situation where personal injury or death may occur. Should Buyer purchase or use Tundra products for any such unintended or unauthorized application, Buyer shall indemnify and hold Tundra and its officers, employees, subsidiaries, affiliates and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Tundra was negligent regarding the design or manufacture of the part.

The acceptance of this document will be construed as an acceptance of the foregoing conditions.

Product: QSpan II (CA91L862A)Title: QSpan II PCI-to-Motorola Processor Bridge ManualDocument: 8091862.MA001.06Status: FinalCopyright: September 2000 Tundra Semiconductor Corporation

Published in Canada All rights reserved.

Tundra and Tundra logo are registered trademarks of Tundra Semiconductor Corporation. All other product and logo trademarks are the property of their respective companies.

## **Revision History**

8091862.MA001.06, Final Manual, September 2000 8091862.MA001.05, Final Manual, September 2000 8091862.MA001.04, Preliminary Manual, December 1999 8091862.MA001.03, Preliminary Manual, September 1999 8091862.MA001.02, Preliminary Manual, September 1999 8091862.MA001.01, Preliminary Manual, August 1999

# Contents

| Cha                                                                                                                | pter 1                                                                                  | : General Information                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 1.1                                                                                                                | What i                                                                                  | s the QSpan II                                                                                                                          |
|                                                                                                                    | 1.1.1                                                                                   | QSpan II Features                                                                                                                       |
|                                                                                                                    | 1.1.2                                                                                   | QSpan II verses QSpan                                                                                                                   |
| 1.2                                                                                                                | Docum                                                                                   | ent Conventions                                                                                                                         |
|                                                                                                                    | 1.2.1                                                                                   | Signals                                                                                                                                 |
|                                                                                                                    | 1.2.2                                                                                   | Bit Ordering                                                                                                                            |
|                                                                                                                    | 1.2.3                                                                                   | Numeric Conventions                                                                                                                     |
|                                                                                                                    | 1.2.4                                                                                   | Topographic Conventions                                                                                                                 |
|                                                                                                                    | 1.2.5                                                                                   | Symbols                                                                                                                                 |
|                                                                                                                    | 1.2.6                                                                                   | Document Status                                                                                                                         |
| 1.3                                                                                                                | Related                                                                                 | Documentation                                                                                                                           |
| 1.4                                                                                                                | Custon                                                                                  | her Support Information                                                                                                                 |
|                                                                                                                    |                                                                                         |                                                                                                                                         |
| Cha                                                                                                                | pter 2                                                                                  | : Functional Overview                                                                                                                   |
| <b>Cha</b><br>2.1                                                                                                  | -                                                                                       | • Functional Overview                                                                                                                   |
|                                                                                                                    | Overvi                                                                                  |                                                                                                                                         |
| 2.1                                                                                                                | Overvi<br>The QI                                                                        | ew                                                                                                                                      |
| 2.1<br>2.2                                                                                                         | Overvi<br>The QI<br>The PC                                                              | ew                                                                                                                                      |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> </ol>                                                                  | Overvi<br>The QI<br>The PC<br>The ID                                                    | ew                                                                                                                                      |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> <li>2.4</li> </ol>                                                     | Overvi<br>The QI<br>The PC<br>The ID<br>The DI                                          | ew35Bus Slave Channel36CI Target Channel37MA Channel37                                                                                  |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> <li>2.4</li> <li>2.5</li> </ol>                                        | Overvi<br>The QI<br>The PC<br>The ID<br>The DI<br>The Re                                | ew35Bus Slave Channel36CI Target Channel37MA Channel37MA Channel37                                                                      |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> <li>2.4</li> <li>2.5</li> <li>2.6</li> </ol>                           | Overvi<br>The QI<br>The PC<br>The ID<br>The DI<br>The Re<br>The Int                     | ew.35Bus Slave Channel36CI Target Channel37MA Channel.37MA Channel37egister Channel37                                                   |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> <li>2.4</li> <li>2.5</li> <li>2.6</li> <li>2.7</li> <li>2.8</li> </ol> | Overvi<br>The QI<br>The PC<br>The ID<br>The DI<br>The Re<br>The Int<br>The EF           | ew.35Bus Slave Channel36CI Target Channel37MA Channel.37MA Channel37egister Channel37gister Channel37373737373838                       |
| <ol> <li>2.1</li> <li>2.2</li> <li>2.3</li> <li>2.4</li> <li>2.5</li> <li>2.6</li> <li>2.7</li> <li>2.8</li> </ol> | Overvi<br>The QI<br>The PC<br>The ID<br>The DI<br>The DI<br>The Re<br>The Int<br>The EF | ew.35Bus Slave Channel36CI Target Channel37MA Channel37MA Channel37orgister Channel37orgister Channel37Berrupt Channel38EPROM Channel38 |

|     | 3.2.1  | QBus Slave Module                                  |
|-----|--------|----------------------------------------------------|
|     |        | 3.2.1.1 QBus Data Parity Generation and Detection  |
|     | 3.2.2  | Qx-FIFO and Qr-FIFO                                |
|     | 3.2.3  | PCI Master Module                                  |
| 3.3 |        | el Description                                     |
| 3.4 | Addres | ss Phase                                           |
|     | 3.4.1  | Transaction Decoding and QBus Slave Images         |
|     |        | 3.4.1.1 MPC860 Cycles                              |
|     |        | 3.4.1.2 MC68360 Cycles                             |
|     |        | 3.4.1.3 M68040 Cycles                              |
|     | 3.4.2  | PCI Bus Request                                    |
|     | 3.4.3  | Address Translation                                |
|     | 3.4.4  | Address Phase on the PCI Bus                       |
| 3.5 | Data P | hase                                               |
|     | 3.5.1  | Endian Mapping                                     |
|     | 3.5.2  | Data Path                                          |
|     |        | 3.5.2.1 Writes                                     |
|     |        | 3.5.2.2 Read Transactions — Burst and Single Cycle |
|     |        | 3.5.2.3 Prefetched Reads                           |
|     |        | 3.5.2.4 Delayed Reads and PCI Transaction Ordering |
|     | 3.5.3  | PCI Target Channel Reads                           |
|     | 3.5.4  | Parity Monitoring by PCI Master Module             |
| 3.6 | Termir | nation Phase                                       |
|     | 3.6.1  | Posted Write Termination                           |
| 3.7 | PCI M  | aster Retry Counter                                |
| Cha | pter 4 | : The PCI Target Channel 61                        |
| 4.1 | Overvi | ew61                                               |
| 4.2 | PCI Ta | arget Channel Architecture                         |
|     | 4.2.1  | PCI Target Module                                  |
|     | 4.2.2  | Px-FIFO and Pr-FIFO                                |
|     | 4.2.3  | QBus Master Module                                 |
|     |        | 4.2.3.1 QBus Data Parity Generation and Detection  |
| 4.3 | Chann  | el Description                                     |
| 4.4 | Addres | ss Phase                                           |

|     | 4.4.1  | Transaction Decoding.                              | . 65 |
|-----|--------|----------------------------------------------------|------|
|     | 4.4.2  | Address Translation                                | . 68 |
|     | 4.4.3  | Transaction Codes on the QBus                      | . 70 |
|     | 4.4.4  | PCI BIOS Memory Allocation                         | . 71 |
|     |        | 4.4.4.1 Block Size and PCI Address Space           | . 71 |
|     |        | 4.4.4.2 Base Address                               | . 71 |
| 4.5 | Data P | hase                                               | . 72 |
|     | 4.5.1  | Endian Mapping                                     | . 72 |
|     |        | 4.5.1.1 Write Cycle Mapping for PCI Target Channel | . 72 |
|     |        | 4.5.1.2 Read Cycle Mapping for PCI Target Channel  | . 74 |
|     | 4.5.2  | Data Path                                          | . 78 |
|     |        | 4.5.2.1 Posted Writes                              | . 78 |
|     |        | 4.5.2.2 Delayed Writes                             | . 79 |
|     |        | 4.5.2.3 Single Read Transactions.                  | . 80 |
|     |        | 4.5.2.4 Prefetched Read Transactions               | . 80 |
|     | 4.5.3  | Parity Monitoring by PCI Target Module             | . 81 |
| 4.6 | Reads  | and PCI Transaction Ordering                       | . 81 |
|     | 4.6.1  | Transaction Ordering Disable Option                | . 82 |
| 4.7 | QBus A | Arbitration and Sampling                           | . 82 |
|     | 4.7.1  | MC68360 Bus Arbitration                            | . 82 |
|     | 4.7.2  | MPC860 Bus Arbitration                             | . 83 |
|     | 4.7.3  | M68040 Bus Arbitration.                            | . 84 |
| 4.8 | Termir | nations                                            | . 84 |
|     | 4.8.1  | QBus Master Module Terminations                    | . 84 |
|     | 4.8.2  | MC68360 Cycle Terminations                         | . 84 |
|     | 4.8.3  | MPC860 Cycle Terminations                          | . 85 |
|     | 4.8.4  | M68040 Cycle Terminations                          | . 85 |
|     | 4.8.5  | Terminations driven by the PCI Target Module       | . 86 |
|     |        | 4.8.5.1 Target-Disconnect                          | . 86 |
|     |        | 4.8.5.2 Target-Retry                               | . 87 |
|     |        | 4.8.5.3 Target-Abort                               | . 87 |
|     | 4.8.6  | Terminations of Posted Writes                      | . 88 |

| Cha | pter 5  | : The IDMA Channel 89                               |
|-----|---------|-----------------------------------------------------|
| 5.1 | Overvi  | ew                                                  |
| 5.2 | PCI Re  | ad Transactions                                     |
|     | 5.2.1   | Data Path                                           |
| 5.3 | PCI W   | rite Transactions                                   |
|     | 5.3.1   | Data Path                                           |
| 5.4 | TC[3:0  | 9] Encoding with MPC860 IDMA94                      |
| 5.5 | IDMA    | Status Tracking                                     |
| 5.6 | IDMA    | Errors, Resets, and Interrupts                      |
| 5.7 | IDMA    | Endian Issues                                       |
| Cha | pter 6  | : The DMA Channel                                   |
| 6.1 | Overvi  | ew                                                  |
| 6.2 | DMA     | Registers                                           |
|     | 6.2.1   | Burst Cycles                                        |
|     | 6.2.2   | DMA Cycles on QBus                                  |
| 6.3 | Direct  | Mode DMA Operation                                  |
|     | 6.3.1   | Initiating a Direct Mode Transfer                   |
|     | 6.3.2   | Terminating a Direct Mode Transfer                  |
| 6.4 | Linked  | List Mode DMA Operation                             |
|     | 6.4.1   | Initiating a Linked List Mode DMA Operation         |
|     | 6.4.2   | Terminating a Linked List Mode DMA Operation        |
| Cha | pter 7  | : The Register Channel                              |
| 7.1 | Overvi  | ew                                                  |
| 7.2 | Registe | er Access Fairness                                  |
| 7.3 | Registe | er Access from the PCI Bus                          |
| 7.4 | Registe | er Access from the QBus                             |
|     | 7.4.1   | Examples of QBus Register Accesses                  |
|     | 7.4.2   | PCI Configuration Cycles Generated from the QBus114 |
|     | 7.4.3   | Address Phase of PCI Configuration Cycles           |
|     |         | 7.4.3.1 Data Phase of PCI Configuration Cycles      |
|     | 7.4.4   | Interrupt Acknowledge Cycle                         |
| 7.5 | Registe | er Access Synchronization                           |
| 7.6 | Mailbo  | x Registers                                         |

| Cha  | pter 8: The Interrupt Channel119                                             |
|------|------------------------------------------------------------------------------|
| 8.1  | Overview                                                                     |
| 8.2  | Hardware-Triggered Interrupts                                                |
| 8.3  | Software-Triggered Interrupts                                                |
|      | 8.3.1 Interrupt Generation due to PCI Configuration Register Status Bits 124 |
| 8.4  | Interrupt Acknowledge Cycle                                                  |
| 8.5  | Disabling PCI Interrupts 125                                                 |
| Cha  | pter 9: The EEPROM Channel                                                   |
| 9.1  | Overview                                                                     |
| 9.2  | EEPROM Configuration and Plug and Play Compatibility                         |
| 9.3  | EEPROM I <sup>2</sup> C Protocol                                             |
| 9.4  | Mapping of EEPROM Bits to QSpan II Registers                                 |
| 9.5  | Programming the EEPROM from the QBus or PCI Bus                              |
|      | 9.5.1 Writing to the EEPROM                                                  |
|      | 9.5.2 Reading from the EEPROM                                                |
| 9.6  | EEPROM Access                                                                |
| 9.7  | Vital Product Data Support                                                   |
|      | 9.7.1 Reading VPD Data                                                       |
|      | 9.7.2 Writing VPD Data 135                                                   |
| Cha  | pter 10: I <sub>2</sub> O Messaging Unit137                                  |
| 10.1 | Overview                                                                     |
| 10.2 | Inbound Messaging                                                            |
| 10.3 | Outbound Messaging                                                           |
| 10.4 | I <sub>2</sub> O Operation                                                   |
| 10.5 | Summary of I <sub>2</sub> O Operations                                       |
|      | 10.5.1 Initialization                                                        |
|      | 10.5.1.1 Inbound I <sub>2</sub> O Message $\dots$ 142                        |
|      | 10.5.1.2 $I_2O$ Outbound Message                                             |
| 10.6 | I <sub>2</sub> O Interrupts                                                  |
| Cha  | pter 11: PCI Bus Arbiter145                                                  |
| 11.1 | Overview                                                                     |
| 11.2 | Arbitration Scheme                                                           |
| 11.3 | Bus Parking                                                                  |

| Cha  | pter 12: CompactPCI Hot Swap Friendly Support |
|------|-----------------------------------------------|
| 12.1 | Overview                                      |
| 12.2 | Hot Swapping with the QSpan II                |
| 12.3 | CompactPCI Hot Swap Card Insertion151         |
| 12.4 | CompactPCI Hot Swap Card Extraction           |
| Cha  | pter 13: PCI Power Management Event Support   |
| 13.1 | Overview                                      |
| 13.2 | Power Management Event (PME#) Support         |
| Cha  | pter 14: Reset Options 159                    |
| 14.1 | Types of Resets                               |
|      | 14.1.1 PCI Transactions during QBus Reset     |
|      | 14.1.2 IDMA Reset                             |
|      | 14.1.3 Clocking and Resets                    |
| 14.2 | Configuration Options at Reset                |
|      | 14.2.1 PCI Bus Master Reset Option            |
|      | 14.2.2 QBus Master and Slave Modes            |
|      | 14.2.3 EEPROM Loading                         |
|      | 14.2.4 PCI Register Access Option             |
|      | 14.2.5 PCI Bus Arbitration Option             |
| Cha  | pter 15: Hardware Implementation Issues       |
| 15.1 | Test Mode Pins                                |
| 15.2 | JTAG Support                                  |
| 15.3 | Decoupling Capacitors                         |
| Cha  | pter 16: Signals 165                          |
| 16.1 | Terminology                                   |
| 16.2 | Overview                                      |
| 16.3 | MC68360 Signals: QUICC 167                    |
| 16.4 | MPC860 Signals: PowerQUICC171                 |
| 16.5 | M68040 Signals                                |
| 16.6 | PCI Bus Signals                               |
| 16.7 | Hot Swap Signals                              |

| 16.8 | Miscell | laneous Signals                     |     |
|------|---------|-------------------------------------|-----|
| 16.9 | JTAG S  | Signals                             | 182 |
| Cha  | pter 1  | 7: Signals and DC Characteristics   | 183 |
| 17.1 | Termin  | ology                               | 183 |
| 17.2 | Packag  | ing and Voltage Level Support       |     |
| 17.3 | Signals | and DC Characteristics              |     |
| 17.4 | Pinout  |                                     | 196 |
| Арр  | endix   | A: Registers                        | 199 |
| A.1  | Overvi  | ew                                  | 199 |
| A.2  | Termin  | ology                               | 200 |
| A.3  | Registe | er Map                              | 201 |
| A.4  | Registe | ers                                 | 206 |
| Арр  | endix   | B: Timing                           | 305 |
| B.1  | Overvi  | ew                                  | 305 |
| B.2  | Timing  | Parameters                          | 306 |
| B.3  | Wait St | tate Insertion — QBus Slave Module  | 320 |
| B.4  | Timing  | Diagrams                            | 321 |
|      | B.4.1   | QBus Interface — MC68360            | 321 |
|      | B.4.2   | QBus Master Cycles — MC68360        | 321 |
|      |         | B.4.2.1 QBus Slave Cycles — MC68360 | 324 |
|      |         | B.4.2.2 QBus IDMA Cycles — MC68360  | 328 |
|      | B.4.3   | QBus Interface — MPC860             | 336 |
|      |         | B.4.3.1 QBus Master Cycles — MPC860 | 336 |
|      |         | B.4.3.2 QBus Slave Cycle — MPC860   | 341 |
|      |         | B.4.3.3 QBus IDMA Cycles — MPC860   | 347 |
|      | B.4.4   | QBus Interface — M68040             | 351 |
|      |         | B.4.4.1 QBus Master Cycles — M68040 | 352 |
|      |         | B.4.4.2 QBus Slave Cycles — M68040  | 355 |
|      | B.4.5   | Interrupts and Resets               | 361 |
|      | B.4.6   | Reset Options                       | 363 |

| Арр | endix | C: Typical Applications 3                 | 65  |
|-----|-------|-------------------------------------------|-----|
| C.1 | MC683 | 360 Interface                             | 365 |
|     | C.1.1 | Hardware Interface                        | 365 |
|     |       | C.1.1.1 Clocking                          | 365 |
|     |       | C.1.1.2 Resets                            | 366 |
|     |       | C.1.1.3 Memory Controller                 | 367 |
|     |       | C.1.1.4 QBus Direct Connects              | 368 |
|     |       | C.1.1.5 Interrupts                        | 368 |
|     |       | C.1.1.6 PCI Signals                       | 368 |
|     |       | C.1.1.7 EEPROM Interface                  | 368 |
|     |       | C.1.1.8 Reset Options                     | 369 |
|     |       | C.1.1.9 Unused Inputs Requiring Pull-Ups  | 369 |
|     |       | C.1.1.10 No Connects                      | 369 |
|     |       | C.1.1.11 JTAG Signals                     | 369 |
|     |       | C.1.1.12 Address Multiplexing for DRAM    | 370 |
|     | C.1.2 | Software Issues                           | 370 |
|     | C.1.3 | MC68360 Slave Mode Interface              | 370 |
| C.2 | MPC8  | 60 Interface                              | 371 |
|     | C.2.1 | Hardware Interface                        | 372 |
|     |       | C.2.1.1 Clocking                          | 372 |
|     |       | C.2.1.2 Resets                            | 373 |
|     |       | C.2.1.3 Memory Controller                 | 374 |
|     |       | C.2.1.4 QBus Direct Connects              | 374 |
|     |       | C.2.1.5 Interrupts                        | 375 |
|     |       | C.2.1.6 PCI Signals                       | 375 |
|     |       | C.2.1.7 EEPROM Interface.                 | 375 |
|     |       | C.2.1.8 Reset Options                     | 375 |
|     |       | C.2.1.9 Unused Inputs Requiring Pull-Ups. | 376 |
|     |       | C.2.1.10 No Connects                      | 376 |
|     |       | C.2.1.11 JTAG Signals                     | 376 |
|     |       | C.2.1.12 Bused Signals                    | 376 |
|     |       | C.2.1.13 Address Multiplexing for DRAM    | 376 |
|     |       | C.2.1.14 Software Issues                  | 377 |
| C.3 | M6804 | 0 Interface                               | 378 |
|     | C.3.1 | Hardware Interface                        | 379 |

|      | C.3.1.1 Clocking                                |
|------|-------------------------------------------------|
|      | C.3.1.2 Resets                                  |
|      | C.3.1.3 Address Decoder                         |
|      | C.3.1.4 QBus Direct Connects                    |
|      | C.3.1.5 Interrupts                              |
|      | C.3.1.6 PCI Signals                             |
|      | C.3.1.7 EEPROM Interface                        |
|      | C.3.1.8 Reset Options                           |
|      | C.3.1.9 Unused Inputs Requiring Pull-Ups        |
|      | C.3.1.10 No Connects                            |
|      | C.3.1.11 JTAG Signals                           |
| Арр  | endix D: Software Initialization                |
| D.1  | Miscellaneous Control Register Configuration    |
| D.2  | QBus Slave Channel Initialization               |
| D.3  | Register Access from the PCI Bus                |
| D.4  | PCI Target Channel Initialization               |
| D.5  | Error Logging of Posted Transactions            |
| D.6  | IDMA/DMA Channel Initialization                 |
| D.7  | Interrupt Initialization                        |
| D.8  | Generation of PCI Configuration and IACK Cycles |
| D.9  | EEPROM and VPD Initialization                   |
| D.10 | I <sub>2</sub> O Messaging Unit Initialization  |
| D.11 | PCI Expansion ROM Implementation                |
| App  | endix E: Endian Mapping                         |
| E.1  | Overview                                        |
| E.2  | Big-Endian System                               |
| E.3  | Little-Endian System                            |
| E.4  | Endian Mapping Methods                          |
|      | E.4.1 Address Invariance                        |
|      | E.4.2 Data Invariance                           |
|      | E.4.3 Combined Method 399                       |

| Арр  | endix  | F: Operating and Storage Conditions 40 | <b>D1</b> |
|------|--------|----------------------------------------|-----------|
| F.1  | Power  | Dissipation                            | -01       |
| F.2  | Operat | ing Conditions                         | -02       |
| F.3  | Therm  | al Characteristics                     | .02       |
| Арр  | endix  | G: Mechanical Information 4            | 05        |
| G.1  | Mecha  | nical Information                      | .05       |
|      | G.1.1  | 256 PBGA — 17 mm                       | .05       |
|      |        | G.1.1.1 PBGA Notes — 17 mm             | .06       |
|      | G.1.2  | 256 PBGA — 27 mm                       | .07       |
|      |        | G.1.2.1 PBGA Notes — 27 mm             | .08       |
| Арр  | endix  | H: Ordering Information 4 <sup>4</sup> | 11        |
| H.1  | Orderi | ng Information                         | -11       |
| Glos | ssary  |                                        | 13        |
| Inde | x      |                                        | 15        |

# **List of Figures**

| Figure 1:  | QSpan II Bridging PCI and Processor Buses                |
|------------|----------------------------------------------------------|
| Figure 2:  | QSpan II Functional Diagram                              |
| Figure 3:  | QBus Slave Channel — Functional Diagram 40               |
| Figure 4:  | Address Generator for QBus Slave Channel Transfers       |
| Figure 5:  | PCI Target Channel — Functional Diagram                  |
| Figure 6:  | Address Generator for PCI Target Channel Transfers       |
| Figure 7:  | IDMA Channel — Functional Diagram                        |
| Figure 8:  | DMA Channel — Functional Diagram 100                     |
| Figure 9:  | Linked List DMA Operation                                |
| Figure 10: | Register Channel — Functional Diagram 110                |
| Figure 11: | QSpan II Control and Status Registers 111                |
| Figure 12: | QCSR Access from the QBus 113                            |
| Figure 13: | Example of a Register-Access Synchronization Problem 117 |
| Figure 14: | Interrupt Channel — Functional Diagram                   |
| Figure 15: | EEPROM Channel — Functional Diagram                      |
| Figure 16: | Sequential Read from EEPROM 129                          |
| Figure 17: | I <sub>2</sub> O Messaging Unit — Functional Diagram     |
| Figure 18: | I <sub>2</sub> O Implementation                          |
| Figure 19: | PCI Bus Arbiter — Functional Diagram 146                 |
| Figure 20: | PCI Bus Arbiter — Arbitration Scheme                     |
| Figure 21: | CompactPCI Hot Swap — Functional Diagram 150             |
| Figure 22: | Hot Swap Card Insertion                                  |
| Figure 23: | Hot Swap Card Extraction    155                          |
| Figure 24: | Reference Voltages for AC Timing Specification           |
| Figure 25: | QCLK Input Timing — MC68360 CLKO1 321                    |
| Figure 26: | QBus Arbitration — MC68360                               |
| Figure 27: | Single Read — QSpan II as MC68360 Master 322             |

| Figure 28: | Single Write — QSpan II as MC68360 Master                  | . 323 |
|------------|------------------------------------------------------------|-------|
| Figure 29: | Delayed Single Read — QSpan II as MC68360 Slave            | . 324 |
| Figure 30: | Single Write — QSpan II as MC68360 Slave                   | . 325 |
| Figure 31: | Register Read — QSpan II as MC68360 Slave                  | . 326 |
| Figure 32: | Register Write — QSpan II as MC68360 Slave                 | . 327 |
| Figure 33: | MC68360 DREQ_ Timing                                       | . 328 |
| Figure 34: | MC68360 IDMA Read — Single Address, Standard Terminations  | . 329 |
| Figure 35: | MC68360 IDMA Write — Single Address, Standard Terminations | . 330 |
| Figure 36: | MC68360 IDMA Read — Single Address, Fast Termination       | . 331 |
| Figure 37: | MC68360 IDMA Write — Single Address, Fast Termination      | . 331 |
| Figure 38: | MC68360 IDMA Read — Dual Address, Standard Termination     | . 332 |
| Figure 39: | MC68360 IDMA Write — Dual Address, Standard Termination    | . 333 |
| Figure 40: | MC68360 IDMA Read — Dual Address, Fast Termination         | . 334 |
| Figure 41: | MC68360 IDMA Read — Dual Address, Fast Termination         | . 335 |
| Figure 42: | QBus Arbitration — MPC860                                  | . 336 |
| Figure 43: | Single Read — QSpan II as MPC860 Master                    | . 337 |
| Figure 44: | Single Write — QSpan II as MPC860 Master                   | . 338 |
| Figure 45: | Burst Read — QSpan II as MPC860 Master                     | . 339 |
| Figure 46: | Aligned Burst Write — QSpan II as MPC860 Master            | . 340 |
| Figure 47: | Single Read — QSpan II as MPC860 Slave                     | . 341 |
| Figure 48: | Single Write — QSpan II as MPC860 Slave                    | . 342 |
| Figure 49: | Burst Read — QSpan II as MPC860 Slave                      | . 343 |
| Figure 50: | Burst Write — QSpan II as MPC860 Slave                     | . 344 |
| Figure 51: | Register Read — QSpan II as MPC860 Slave                   | . 345 |
| Figure 52: | Register Write — QSpan II as MPC860 Slave                  | . 346 |
| Figure 53: | MPC860 DREQ_ Timing                                        | . 347 |
| Figure 54: | MPC860 IDMA Read — Single Address                          | . 348 |
| Figure 55: | MPC860 IDMA Write — Single Address                         | . 349 |
| Figure 56: | MPC860 IDMA Read — Dual Address                            | . 350 |
| Figure 57: | MPC860 IDMA Write — Dual Address                           | . 351 |
| Figure 58: | QCLK Input Timing — M68040 BCLK                            | . 351 |
| Figure 59: | QBus Arbitration — M68040                                  | . 352 |
| Figure 60: | Single Read — QSpan II as M68040 Master                    | . 353 |
| Figure 61: | Single Write — QSpan II as M68040 Master                   | . 354 |
| Figure 62: | Single Read — QSpan II as M68040 Slave                     | . 355 |

| Figure 63: | Single Write — QSpan II as M68040 Slave 356           |
|------------|-------------------------------------------------------|
| Figure 64: | Delayed Burst Read — QSpan II as M68040 Slave 357     |
| Figure 65: | Posted Burst Write — QSpan II as M68040 Slave 358     |
| Figure 66: | Register Reads — QSpan II as M68040 Slave 359         |
| Figure 67: | Register Write — QSpan II as M68040 Slave             |
| Figure 68: | Reset from PCI Interface — RST# related to RESETO 361 |
| Figure 69: | Software Reset                                        |
| Figure 70: | INT# Interrupt to QINT_ Interrupt                     |
| Figure 71: | PERR# Interrupt                                       |
| Figure 72: | SERR# Interrupt                                       |
| Figure 73: | QINT_Interrupt to INT# Interrupt                      |
| Figure 74: | Reset Options                                         |
| Figure 75: | MC68360 Interface                                     |
| Figure 76: | MPC860 Interface                                      |
| Figure 77: | MPC860/QSpan II Clocking Scheme Example               |
| Figure 78: | Example Code for Executing an MPC860 Delay Loop 373   |
| Figure 79: | M68040 Interface                                      |
| Figure 80: | Big-Endian System                                     |
| Figure 81: | Little-Endian System                                  |
| Figure 82: | Address Invariant Mapping                             |
| Figure 83: | Data Invariant Mapping 399                            |
| Figure 84: | 256 PBGA, 17 mm — Top and Side Views 406              |
| Figure 85: | 256 PBGA, 17 mm — Bottom View 407                     |
| Figure 86: | 256 PBGA, 27 mm — Top and Side Views                  |
| Figure 87: | 256 PBGA, 27 mm — Bottom View 409                     |

# **List of Tables**

| Table 1:  | QSpan II New Features and Functional Enhancements               |
|-----------|-----------------------------------------------------------------|
| Table 2:  | Reset Options for QBus Slave Modes 41                           |
| Table 3:  | Address Fields for QBus Slave Image 44                          |
| Table 4:  | Control Fields for QBus Slave Image 44                          |
| Table 5:  | Translation of QBus Address to PCI Address                      |
| Table 6:  | Command Type Encoding for Transfer Type 49                      |
| Table 7:  | Translation from QBus Transaction to PCI Transaction Type       |
| Table 8:  | Little-Endian QBus Slave Channel Cycle Mapping 51               |
| Table 9:  | Big-Endian QBus Slave Channel Cycle Mapping                     |
| Table 10: | Translation of Cycle Termination from PCI Bus to QBus           |
| Table 11: | MC68360 Cycle Terminations of QBus Slave Module                 |
| Table 12: | MPC860 Cycle Terminations of QBus Slave Module                  |
| Table 13: | M68040 Cycle Terminations of QBus Slave Module                  |
| Table 14: | QBus Slave Channel Error Responses                              |
| Table 15: | Reset Options for QBus Master and Slave Modes                   |
| Table 16: | Address Fields for PCI Target Image                             |
| Table 17: | Control Fields for PCI Target Image                             |
| Table 18: | Translation of PCI Bus Address to QBus Address                  |
| Table 19: | Little-Endian PCI Target Write Cycle Mapping — 32-Bit QBus Port |
| Table 20: | Big-Endian PCI Target Write Cycle Mapping — 32-Bit QBus Port    |
| Table 21: | Little-Endian PCI Target Read Cycle Mapping — 32-Bit QBus Port  |
| Table 22: | Big-Endian PCI Target Read Cycle Mapping — 32-Bit QBus Port     |
| Table 23: | Little-Endian PCI Target Read Cycle Mapping — 16-Bit QBus Port  |
| Table 24: | Big-Endian PCI Target Read Cycle Mapping — 16-Bit QBus Port     |
| Table 25: | Little-Endian PCI Target Read Cycle Mapping — 8-Bit QBus Port   |
| Table 26: | Big-Endian PCI Target Read Cycle Mapping — 8-Bit QBus Port      |
| Table 28: | MPC860 Cycle Terminations of QBus Master Module                 |

| Table 29: | M68040 Cycle Terminations of QBus Master Module                    | 85  |
|-----------|--------------------------------------------------------------------|-----|
| Table 27: | MC68360 Cycle Terminations of QBus Master Module                   | 85  |
| Table 30: | Translation of Cycle Termination from QBus to PCI Bus              | 88  |
| Table 32: | IDMA Interrupt Source, Enabling, Mapping, Status and Clear bits    | 96  |
| Table 31: | QSpan II's Response to IDMA Errors                                 | 96  |
| Table 34: | 16-Bit Big-Endian IDMA Cycle Mapping                               | 98  |
| Table 35: | 32-Bit Little-Endian IDMA Cycle Mapping                            | 98  |
| Table 36: | 32-Bit Big-Endian IDMA Cycle Mapping                               |     |
| Table 33: | 16-Bit Little Endian IDMA Cycle Mapping                            | 98  |
| Table 37: | PCI Memory Cycle Access to bits 15-08 of the PCI_CLASS register    | 112 |
| Table 38: | Big-Endian QBus Access to bits 15-08 of the PCI_CLASS register     | 114 |
| Table 39: | Little-Endian QBus Access to bits 15–08 of the PCI_CLASS register  | 114 |
| Table 40: | PCI AD[31:16] lines asserted as a function of DEV_NUM field        | 116 |
| Table 41: | Mapping of Hardware-Initiated Interrupts                           | 121 |
| Table 42: | Interrupt Source, Enabling, Mapping, Status and Clear bits         | 122 |
| Table 43: | Software Interrupt Mapping, Status and Source bits                 | 124 |
| Table 44: | Destination of EEPROM Bits Read                                    | 131 |
| Table 45: | Insertion Sequence                                                 | 152 |
| Table 46: | Extraction Sequence                                                | 154 |
| Table 47: | Hardware Reset Mechanisms                                          | 159 |
| Table 48: | Reset Options for QBus Master and Slave Modes                      | 162 |
| Table 49: | Test Mode Operation                                                | 163 |
| Table 50: | QBus Signal Names Compared to Motorola Signals                     | 166 |
| Table 51: | MC68360/MPC860 Encoding for the SIZ[1:0] Signal                    | 175 |
| Table 52: | M68040 Encoding for the SIZ[1:0] Signal                            | 178 |
| Table 53: | Non-PCI DC Electrical Characteristics ( $V_{DD} \pm 5\%$ )         | 184 |
| Table 54: | 3.3V PCI I/O Signaling AC/DC Characteristics (V <sub>DD</sub> ±5%) | 185 |
| Table 55: | 5V PCI I/O Signaling AC/DC Electrical Characteristics              | 186 |
| Table 56: | Pin List for QSpan II Signals                                      | 187 |
| Table 57: | PCI Bus Address/Data Pins                                          | 191 |
| Table 58: | QBus Address Pins                                                  | 192 |
| Table 59: | QBus Data Pins                                                     | 193 |
| Table 60: | External Request and Grant Pins                                    | 193 |
| Table 61: | Pin Assignments for Power (V <sub>DD</sub> )                       | 194 |
| Table 62: | Voltage Required to be Applied to VH                               | 194 |

| Table 63: | Pin Assignments for Ground (V <sub>SS</sub> ) 195          |
|-----------|------------------------------------------------------------|
| Table 64: | No-connect Pin Assignments                                 |
| Table 65: | Pinout of 17x17 mm Package                                 |
| Table 66: | Pinout of 27x27 mm Package 197                             |
| Table 67: | Register Map                                               |
| Table 68: | I2O Memory Map — Lower 4K                                  |
| Table 69: | PCI Configuration Space ID Register                        |
| Table 70: | PCI Configuration Space Control and Status Register        |
| Table 71: | PCI Configuration Class Register                           |
| Table 72: | PCI Configuration Miscellaneous 0 Register                 |
| Table 73: | PCI Configuration Base Address for Memory Register         |
| Table 74: | I20 Base Address Register                                  |
| Table 75: | PCI Configuration Base Address for Target 0 Register       |
| Table 76: | PCI Address Lines Compared as a Function of Block Size 215 |
| Table 77: | PCI Configuration Base Address for Target 1 Register       |
| Table 78: | PCI Address Lines Compared as a Function of Block Size 217 |
| Table 79: | PCI Configuration Subsystem ID Register                    |
| Table 80: | PCI Configuration Expansion ROM Base Address Register      |
| Table 81: | Writable BA bits as a function of Block Size               |
| Table 82: | PCI Capabilities Pointer Register                          |
| Table 83: | PCI Configuration Miscellaneous 1 Register                 |
| Table 84: | PCI Power Management Capabilities Register                 |
| Table 85: | PCI Power Management Control and Status Register           |
| Table 86: | CompactPCI Hot Swap Register                               |
| Table 87: | PCI Vital Product Data Register                            |
| Table 88: | PCI VPD Data Register                                      |
| Table 89: | PCI Bus Target Image 0 Control Register                    |
| Table 90: | PCI Bus Target Image 0 Address Register                    |
| Table 91: | PCI Address Lines Compared as a Function of Block Size 231 |
| Table 92: | PCI Bus Target Image 1 Control Register                    |
| Table 93: | PCI Bus Target Image 1 Address Register 234                |
| Table 94: | PCI Address Lines Compared as a Function of Block Size 235 |
| Table 95: | PCI Bus Expansion ROM Control Register                     |
| Table 96: | PCI Address Lines Compared as a Function of Block Size     |
| Table 97: | PCI Bus Error Log Control and Status Register              |

| Table 98:  | PCI Bus Address Error Log Register                          | 240 |
|------------|-------------------------------------------------------------|-----|
| Table 99:  | PCI Bus Data Error Log Register                             | 241 |
| Table 100: | I2O Control and Status Register                             | 242 |
| Table 101: | I2O Inbound Free_List Top Pointer Register                  | 244 |
| Table 102: | I2O Inbound Free_List Bottom Pointer Register               | 245 |
| Table 103: | I2O Inbound Post_List Top Pointer Register                  | 246 |
| Table 104: | I2O Inbound Post_List Bottom Pointer Register               | 247 |
| Table 105: | I2O Outbound Free_List Top Pointer Register                 | 248 |
| Table 106: | I2O Outbound Free_List Bottom Pointer Register              | 249 |
| Table 107: | I2O Outbound Post_List Top Pointer Register                 | 250 |
| Table 108: | I2O Outbound Post_List Bottom Pointer Register              | 251 |
| Table 109: | IDMA Control and Status Register                            | 252 |
| Table 110: | IDMA/DMA PCI Address Register                               | 255 |
| Table 111: | IDMA/DMA Transfer Count Register                            | 256 |
| Table 112: | DMA QBus Address Register                                   | 257 |
| Table 113: | DMA Control and Status Register                             | 258 |
| Table 114: | DMA Command Packet Pointer Register                         | 261 |
| Table 115: | Configuration Address Register                              | 262 |
| Table 116: | PCI AD[31:16] lines asserted as a function of DEV_NUM field | 263 |
| Table 117: | Configuration Data Register                                 | 264 |
| Table 118: | IACK Cycle Generator Register                               | 265 |
| Table 119: | Interrupt Status Register                                   | 266 |
| Table 120: | Interrupt Control Register                                  | 269 |
| Table 121: | Interrupt Direction Register                                | 272 |
| Table 122: | Interrupt Control Register 2                                | 275 |
| Table 123: | Mailbox 0 Register                                          | 276 |
| Table 124: | Mailbox 1 Register                                          | 277 |
| Table 125: | Mailbox 2 Register                                          | 278 |
| Table 126: | Mailbox 3 Register                                          | 279 |
| Table 127: | Miscellaneous Control and Status Register                   | 280 |
| Table 128: | Master/Slave Mode — MSTSLV field                            | 282 |
| Table 129: | EEPROM Control and Status Register                          | 283 |
| Table 130: | Miscellaneous Control 2 Register                            | 284 |
| Table 131: | PCI Bus Arbiter Control Register                            | 287 |
| Table 132: | Parked PCI Master                                           | 288 |

| Table 133: | QBus Slave Image 0 Control Register                           | 39  |
|------------|---------------------------------------------------------------|-----|
| Table 134: | QSpan II Response to a Single-Read Cycle Access               | 0   |
| Table 135: | QSpan II Response to a Burst-Read Cycle Access                | 0   |
| Table 136: | QSpan II Response to a Single-Write Cycle Access              | 0   |
| Table 137: | QSpan II Response to a Burst-Write Cycle Access               | 0   |
| Table 138: | QBus Slave Image 0 Address Translation Register               | )1  |
| Table 139: | Address Lines Translated as a Function of Block Size          | 92  |
| Table 140: | QBus Slave Image 1 Control Register 29                        | 13  |
| Table 141: | QSpan II Response to a Single-Read Cycle Access               | )4  |
| Table 142: | QSpan II Response to a Burst-Read Cycle Access                | )4  |
| Table 143: | QSpan II Response to a Single-Write Cycle Access              | )4  |
| Table 144: | QSpan II Response to a Burst-Write Cycle Access               | )4  |
| Table 145: | QBus Slave Image 1 Address Translation Register               | 95  |
| Table 146: | QBus Address Lines Compared as a function of Block Size 29    | 96  |
| Table 147: | QBus Error Log Control and Status Register                    | 97  |
| Table 148: | QBus Address Error Log                                        | )8  |
| Table 149: | QBus Data Error Log 29                                        | )9  |
| Table 150: | I20 Outbound Post_List Interrupt Status Register 30           | )() |
| Table 151: | I20 Outbound Post_List Interrupt Mask Register 30             | )1  |
| Table 152: | I2O Inbound Queue Register                                    | )2  |
| Table 153: | I2O Outbound Queue Register                                   | )3  |
| Table 154: | Timing Parameters for MC68360 Interface                       | )7  |
| Table 155: | Timing Parameters for MPC860 Interface 31                     | 2   |
| Table 156: | Timing Parameters for M68040 Interface 31                     | 6   |
| Table 157: | Timing Parameters for Interrupts and Resets                   | .9  |
| Table 158: | Timing Parameters for Reset Options 31                        | 9   |
| Table 159: | Direction of QBus Signals During MC68360 IDMA Cycles 32       | 28  |
| Table 160: | Direction of QBus Signals During MPC860 IDMA Cycles 34        | 7   |
| Table 161: | Summary of the QSpan II's Miscellaneous Control Register      | \$4 |
| Table 162: | Summary of the QSpan II's Miscellaneous Control Register 2 38 | \$5 |
| Table 163: | PCI Arbiter Control Register Summary 38                       | 6   |
| Table 164: | QBus Slave Channel Programming Summary 38                     | 6   |
| Table 165: | Register Access    38                                         | 37  |
| Table 166: | PCI Target Image Programming Summary 38                       | 37  |
| Table 167: | QBus Error Logging Programming Summary                        | 39  |

| Table 168: | PCI Bus Error Logging Programming Summary            | 9 |
|------------|------------------------------------------------------|---|
| Table 169: | IDMA/DMA Channel Programming Summary                 | 0 |
| Table 170: | PCI Configuration and IACK Cycle Programming Summary | 1 |
| Table 171: | PCI Expansion ROM programming                        | 3 |
| Table 172: | Power Dissipation                                    | 1 |
| Table 173: | 3.3 Volt Absolute Maximum Ratings                    | 2 |
| Table 174: | 3.3 Volt Recommended Operating Conditions            | 2 |
| Table 175: | 3.3 Volt Package Thermal Resistance                  | 3 |
| Table 176: | 256 PBGA — 17 mm Packaging Features                  | 5 |
| Table 177: | 256 PBGA — 27 mm Packaging Features                  | 7 |
| Table 178: | Standard Ordering Information                        | 1 |

## **Corporate Profile**

#### **Tundra Semiconductor Corporation**

Tundra Semiconductor Corporation (TSE:TUN) designs, develops, and markets advanced System Interconnect for use by the world's leading Internet and communications infrastructure vendors. Tundra chips provide the latest interface and throughput features to help these vendors design and deliver more powerful equipment in shorter timeframes. Tundra products are essential to a range of applications, including telecommunications, data communications, wireless communications, industrial automation, and ruggedized systems. Tundra headquarters are located in Kanata, Ontario, Canada, and sales offices are based in Mountain View, California and Maidenhead, U.K. Tundra sells its products worldwide through a network of direct sales personnel, independent distributors, and manufacturers' representatives. More information is available online at www.tundra.com.

#### Greater Demand, Greater Opportunity

The increasingly complex requirements placed on the Internet, intranets and extranets have created an insatiable demand for higher speed and greater capacity in communications networks. The evolution of converging communications networks requires higher levels of security and increasingly sophisticated network intelligence. These network demands, and the user expectations that drive them, have created a global need for well-managed and ever-increasing bandwidth.

Tundra helps meet those demands by creating underlying technology that enables the accelerated flow of voice, data, and video information over communications networks. Tundra products can be found in a broad range of applications, including telecommunications, data communications, wireless communications, industrial automation, and avionics. Communications infrastructure vendors rely on Tundra for off-the-shelf, standards-based, easy-to-deploy and highly scalable System Interconnect products.

#### Tundra System Interconnect

Tundra is *System Interconnect*. Tundra uses the term System Interconnect to refer to the technology used to connect all the components and sub-systems in almost any embedded system. This concept applies to the interfacing of functional elements (CPU, memory, I/O complexes, etc.) within a single-board system, and the interfacing of multiple boards in a larger system.

System Interconnect is a vital enabling technology for the networked world. The convergence of voice, video, and data traffic, the need for more secure communications, and the exploding demand for high-speed network access are putting communications infrastructure vendors under intense pressure to provide faster, well-managed bandwidth that also integrates smoothly with existing technology. Tundra System Interconnect helps these vendors address their customer needs. It enables them to build standards-based network equipment that can scale to multi-gigahertz speeds and also integrate with existing infrastructure.

#### **Partnerships**

Fundamental to the success of Tundra is its partnerships with leading manufacturers, including Motorola, Compaq and Texas Instruments. As a result of these alliances, Tundra devices greatly influence the design of customers' architectures. Customers are changing their designs to incorporate Tundra products. This highlights the commitment Tundra holds to be a significant part of its customers' success.

The Tundra design philosophy is one in which a number of strategic customers are invited to participate in the definition, design, test and early silicon supply phases of product development. Close working relationships with customers and clear product roadmaps ensure that Tundra can anticipate and meet the future directions and needs of communications systems designers and manufacturers.

#### **Tundra Customers**

Tundra semiconductor products are used by the world's leading communications infrastructure vendors, including Cisco, Motorola, Ericsson, Nortel, Lucent, IBM, Xerox, Hewlett-Packard, 3Com, Nokia, Siemens, Newbridge, Alcatel, Matsushita, OKI, Fujitsu, Samsung, and LGS.

#### **Tundra Customer Support**

Tundra is respected throughout the industry for its outstanding commitment to customer support. Tundra ensures that its customers can take immediate advantage of the company's products through its Applications Engineering Group, unmatched Design Support Tools (DST), and full documentation. Customer support also includes Web-based and telephone access to in-house technical resources.

Tundra System Interconnect ... Silicon Behind the Network TM

## **Chapter 1: General Information**

This chapter describes the main functions and features of the QSpan II. It also discusses general document elements and technical support information. The following topics are discussed:

- "What is the QSpan II" on page 28
- "Document Conventions" on page 31
- "Customer Support Information" on page 33
- "Related Documentation" on page 32

## 1.1 What is the QSpan II

The QSpan II<sup>TM</sup> chip is a member of Tundra Semiconductor Corporation's growing family of PCI bus-bridging devices. QSpan II enables board designers to bring PCI-based embedded products to market faster, for less cost, and with high performance.

Developed as part of an ongoing strategic relationship with Motorola®, QSpan II is designed to gluelessly bridge the MC68360 (QUICC<sup>TM</sup>), the MPC860 (PowerQUICC<sup>TM</sup>), other MPCxxx devices, and the M68040/M68060 to PCI (see Figure 1). With additional glue logic, QSpan II can also be connected to lower-end communications controllers and processors, such as the MC68302 and MC68030.

Figure 1: QSpan II Bridging PCI and Processor Buses



### 1.1.1 QSpan II Features

QSpan II has the following features:

- A direct-connect interface to the PCI bus for Motorola's MC68360 and MPC860 communications controllers, and the M68040 Host processor.
- QSpan compatible
- Support for up to 50 MHz MPC8xx bus frequencies (industrial temperature range: -40°C to 85°C)
- Available in two, low thermal resistance packages: 17 mm x 17 mm PBGA; and 27 mm x 27 mm PBGA. Both packages have 3.3V power requirements and are 5V tolerant
- 32-bit PCI interface
- Integrated PCI bus arbiter
- Flexible, high performance DMA engine which operates in both Direct and Scatter/Gather mode
- Five FIFO buffers for multiple transactions in both directions
- Accepts and generates burst reads and writes on the PCI bus
- MPC860 UPM-compliant burst reads and writes as processor bus master
- Separate channel supports MC68360 and MPC860 IDMA
- Flexible address space mapping and translation between the PCI and processor buses
- Programmable endian-byte ordering
- Serial EEPROM interface for Plug and Play compatibility
- Support for PCI and processor bus operation at different clock frequencies
- IEEE 1149.1 JTAG boundary scan support
- CompactPCI Hot Swap Friendly support
- Support for Vital Product Data and Power Management
- I<sub>2</sub>O Messaging Unit
- Mailbox registers for user-designed message passing

#### 1.1.2 QSpan II verses QSpan

The following table summarizes the main QSpan II features that were unavailable in the QSpan device.

#### Table 1: QSpan II New Features and Functional Enhancements

| Description                                                                                           | See                                                             |
|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| Features                                                                                              |                                                                 |
| DMA Channel                                                                                           | "The DMA Channel"<br>on page 99                                 |
| Vital Product Data (PCI Local Bus Specification 2.2 compatible)                                       | "Vital Product Data<br>Support" on<br>page 134                  |
| I <sub>2</sub> O Messaging Unit                                                                       | "I <sub>2</sub> O Messaging<br>Unit" on page 137                |
| Integrated PCI Bus Arbiter                                                                            | "PCI Bus Arbiter" on page 145                                   |
| CompactPCI Hot Swap Friendly                                                                          | "CompactPCI Hot<br>Swap Friendly<br>Support" on<br>page 149     |
| PCI Bus Power Management ( <i>PCI Bus Power Management Interface Specification 1.1</i> compatible)    | "PCI Power<br>Management Event<br>Support" on<br>page 157       |
| Functional Enhancements                                                                               |                                                                 |
| Support for QBus Data Parity Generation and Detection                                                 | "QBus Data Parity<br>Generation and<br>Detection" on<br>page 41 |
| Performance Improvement for QBus Posted Write Transfers                                               | "Writes" on page 52                                             |
| Support for prefetching through the QBus Slave Channel                                                | "Prefetched Reads"<br>on page 54                                |
| Option to Keep Bus Busy (BB_) asserted on Back-to-Back Transfers on the QBus during PCI target cycles | "Bursting on the QBus" on page 79                               |
| Option to use a different prefetch count in the PCI Target Channel based on the Target Image          | "Prefetched Read<br>Transactions" on<br>page 80                 |
| MPC860 UPM-compliant burst reads and writes as processor bus master                                   | "Burst Cycles" on page 102                                      |

## **1.2 Document Conventions**

## 1.2.1 Signals

Signals are either active high or active low. Active low signals are defined as true (asserted) when they are at a logic low. Similarly, active high signals are defined as true at a logic high. Signals are considered asserted when active and negated when inactive, irrespective of voltage levels. For voltage levels, the use of 0 indicates a low voltage while a 1 indicates a high voltage.

The following signal conventions are used:

- SIGNAL#: Active low signals on the PCI bus interface.
- SIGNAL\_: Active low signals on the Host processor bus interface.

### 1.2.2 Bit Ordering

This document adopts the convention that the most significant bit is always the largest number (also referred to as *Little-Endian* bit ordering). For example, the PCI address/data bus consists of AD[31:0], where AD[31] is the most significant bit and AD[0] is the least-significant bit of the field.

#### 1.2.3 Numeric Conventions

The following numeric conventions are used:

- Hexadecimal numbers are denoted by the prefix 0x. For example, 0x004.
- Binary numbers are denoted by the suffix *b*. For example, 010b.

### 1.2.4 Topographic Conventions

The following typographic conventions are used:

- *Italic* type is used for the following purposes:
  - Book titles: For example, *PCI Local Bus Specification (Revision 2.2)*.
  - **Important terms**: For example, when a device is granted access to the PCI bus it is called the bus *master*.
  - Undefined values: For example, the device supports two or three ports depending on the setting of the PCI\_Dx register.
- Courier type is used to represent a file name or text that appears on a computer display. For example, "run loadext.exe by typing it at a command prompt."

#### 1.2.5 Symbols



This symbol directs the reader to useful information or suggestions.



This symbol alerts the reader to procedures or operating levels which may result in misuse or damage to the product.



This symbol alerts the reader to an initialization process that must be performed as a minimum to access the required channel or interface.

#### 1.2.6 Document Status

Tundra technical documentation is classified as either Advance, Preliminary, or Final. These classifications are briefly explained:

- Advance: The Advance manual contains information that is subject to change. The Advance manual exists until device prototypes are available. This type of manual can be downloaded from our website.
- **Preliminary**: The Preliminary manual contains information about a device that is near production-ready, and is revised on an "as needed" basis. The Preliminary manual exists until the device is released to production. This type of manual can be downloaded from our website.
- **Final**: The Final manual contains information about a final, customer-ready device. This type of manual can be downloaded from our website. It also can be ordered in print format by calling 613-592-0714 or 1-800-267-7231.

### 1.3 Related Documentation

Before you read this manual, you should be familiar with the following:

- PCI Local Bus Specification (Revision 2.2)
- CompactPCI Hot Swap Specification (Revision 1.0)
- CompactPCI Specification (Revision 2.1)
- PCI Bus Power Management Interface Specification, (Revision 1.1)
- Intelligent I/O Architecture Specification (Revision 1.5)
- QSpan II/MPC860 CompactPCI Evaluation Board Manual (6091862.MA001.01)
- *QSpan II Software Development Kit Manual (6091862.MA001.01)*
- Motorola M68040 User's Manual
- Motorola MC68360 User's Manual
- Motorola MPC860 (PowerQUICC) User's Manual

## 1.4 Customer Support Information

Tundra is dedicated to providing its customers with superior technical documentation and support. The following types of support are available:

- **QSpan II Web Page**: This web page briefly describes QSpan II's features, benefits, typical applications, and block diagram. For more information, please visit Tundra's website at www.tundra.com.
- **QSpan II Design Support Tools (DST) Web Page**: This web page contains the latest manual, manual addenda, application notes, design notes, and device errata. You can customize how the QSpan II DST web page is presented to you, and also register to receive email notification when a documentation resource changes.
- **Phone Support**: Technical support staff can be reached at 613-592-0714 or 1-800-267-7231. Please ask for QSpan II technical support.
- **support@tundra.com**: You can also send technical questions and feedback to Tundra using this email address. Please include QSpan II in the subject header of your message.
- **Sales Support**: Tundra has an extensive and experienced sales network that communicates information about its products. If you would like to locate a sales representative near you, please visit our website at www.tundra.com.

## **Chapter 2: Functional Overview**

This chapter briefly discusses the main functional components (also referred to as channels) of the QSpan II. Please see the following chapters for a detailed explanation of each component:

- Chapter 3: "The QBus Slave Channel" on page 39
- Chapter 4: "The PCI Target Channel" on page 61
- Chapter 5: "The IDMA Channel" on page 89
- Chapter 6: "The DMA Channel" on page 99
- Chapter 7: "The Register Channel" on page 109
- Chapter 8: "The Interrupt Channel" on page 119
- Chapter 9: "The EEPROM Channel" on page 127
- Chapter 10: "I<sub>2</sub>O Messaging Unit" on page 137
- Chapter 11: "PCI Bus Arbiter" on page 145
- Chapter 12: "CompactPCI Hot Swap Friendly Support" on page 149
- Chapter 13: "PCI Power Management Event Support" on page 157
- Chapter 14: "Reset Options" on page 159
- Chapter 15: "Hardware Implementation Issues" on page 163

### 2.1 Overview

QSpan II has two interfaces: a PCI Bus Interface and a QBus Interface (see Figure 2). The PCI Interface connects the QSpan II to the PCI bus. The QBus Interface connects the QSpan II to the processor bus. Both interfaces support master and slave transactions. The QBus Interface can be directly connected to an MC68360 (QUICC) bus, an MPC860 (PowerQUICC) bus, or an M68040 bus. The QBus Interface can also be connected to other buses with glue logic.

Each interface has two functional modules: a Master Module and a Slave/Target Module. These modules are connected to QSpan II's functional channels.



Figure 2: QSpan II Functional Diagram

## 2.2 The QBus Slave Channel

The QBus Slave Channel transfers data between the QBus and the PCI bus (see Figure 2). It supports posted writes, prefetched reads, and delayed single reads and writes. Write transactions from the QBus to the PCI bus can be posted or delayed. Posted writes are queued in the Qx-FIFO with immediate data acknowledgment on the QBus. QSpan II then completes the write on the PCI bus. For delayed reads, the data is prefetched on the PCI bus and stored in the Qr-FIFO. Subsequent reads retrieve the data from the Qr-FIFO. Delayed transactions — both reads and writes — require data acknowledgment on the PCI bus before data acknowledgment is provided on the QBus.

PCI Memory and I/O spaces are accessible through two Slave images associated with the QBus Slave Channel. Configuration space is accessible through the CON\_DATA register (see Table 117 on page 264). The QBus Slave images are selected using a pair of chip-select signals on the QSpan II (for information, see Chapter 3: "The QBus Slave Channel" on page 39).

# 2.3 The PCI Target Channel

The PCI Target Channel transfers data between the PCI bus and the QBus (see Figure 2). It supports posted writes — to ensure zero-wait state bursting — prefetched reads, and delayed single reads and writes. The 256-byte Px-FIFO supports the queuing of long PCI burst writes.

Delayed reads and writes must complete on the QBus before data acknowledgment occurs on the PCI bus. Reads are executed as delayed transactions, but the QSpan II can be configured to prefetch read data. Prefetched reads are queued in a 256-byte Pr-FIFO.

QSpan II provides two programmable Target images on the PCI bus. These images can be mapped anywhere in Memory or I/O space (for information, see Chapter 4: "The PCI Target Channel" on page 61).

# 2.4 The IDMA Channel

QSpan II can operate as an IDMA peripheral for data transfer between the QBus and the PCI bus (see Figure 2). For transfers going to or from PCI, software can perform bulk data movement using the QSpan II's IDMA Channel. The IDMA Channel supports single- and dual-address cycles, and fast-termination. A separate set of IDMA handshake signals are provided on the QBus. The IDMA Channel can be used by external QBus masters to read data from or write data to a PCI target in one direction at a time. The IDMA Channel contains a 256-byte I-FIFO and a set of IDMA registers (for information, see Chapter 5: "The IDMA Channel" on page 89).

# 2.5 The DMA Channel

QSpan II has a DMA Channel for high performance data transfer between the QBus and the PCI bus (see Figure 2). The DMA controller uses the existing IDMA registers — as well as a few additional registers — and shares the 256-byte I-FIFO with the IDMA Channel. Because of the shared FIFO, the QSpan II cannot use its IDMA and DMA Channels at the same time.

The DMA Channel operates in two modes: Direct Mode and Linked List Mode. In Direct Mode, the DMA registers are programmed directly by an external master. In Linked List Mode, the DMA registers are loaded from PCI bus memory or QBus memory by the QSpan II (for information, see Chapter 6: "The DMA Channel" on page 99).

# 2.6 The Register Channel

QSpan II provides 4 Kbytes of Control and Status Registers (QCSRs) to program PCI settings, as well as the QSpan II's device specific parameters (see Figure 2). QCSR space is accessible from the PCI bus and the QBus.

An internal arbitration mechanism grants access to the QCSRs. The access mechanisms for the QCSRs, including the arbitration protocol, differ depending on whether the registers are accessed from the PCI bus or the QBus.

PCI Configuration cycles can be generated from the QBus by accessing QSpan II registers. The cycles proceed as delayed transfers (for information, see Chapter 7: "The Register Channel" on page 109).

# 2.7 The Interrupt Channel

QSpan II can generate interrupts based on hardware or software events (see Figure 2). Two bidirectional interrupt pins are provided: one on the PCI Interface; the other on the QBus Interface. Interrupt registers track the status of errors. They also allow users to enable, clear, and map errors. Interrupts can be generated using one of the four available software interrupt sources (for information, see Chapter 8: "The Interrupt Channel" on page 119).

QSpan II also contains four mailbox registers which can be used for message passing (for information, see "Mailbox Registers" on page 118). These mailbox registers can generate an interrupt when data is written to them.

# 2.8 The EEPROM Channel

Some of QSpan II's registers can be programmed by data in an EEPROM at system reset. This allows board designers to set identifiers for their cards on the PCI bus at reset. The identifiers enable the PCI Bus Expansion ROM Control Register (PBROM\_CTL) and set various address and image parameters. If the QSpan II is configured with an EEPROM, the QSpan II can boot-up as a Plug and Play compatible device; local processor initialization is also possible.

QSpan II supports reads from and writes to the EEPROM. The EEPROM device is not included with the QSpan II (for more information, see Chapter 9: "The EEPROM Channel" on page 127).

# Chapter 3: The QBus Slave Channel

This chapter describes the QSpan II's QBus Slave Channel. The following topics are discussed:

- "QBus Slave Channel Architecture" on page 40
- "Channel Description" on page 42
- "Address Phase" on page 43
- "Data Phase" on page 50
- "Termination Phase" on page 57
- "PCI Master Retry Counter" on page 60

# 3.1 Overview

The QBus direct-connects to an MC68360 (QUICC) bus, an MPC860 (PowerQUICC) bus, or an M68040 bus (see Figure 3). The QBus can also be direct-connected to a combination of buses, such as an MC68360 bus and an MPC860 bus. A QBus master uses the QBus Slave Channel or IDMA/DMA Channel to access a PCI target.



#### Figure 3: QBus Slave Channel — Functional Diagram

# 3.2 QBus Slave Channel Architecture

Figure 3 shows the QBus Slave Channel in relation to the QBus and the PCI bus. The QBus is shown with an MPC860 processor; the PCI bus is shown with a single PCI device. The arrows represent data flow. The QBus Slave Channel has the following components:

- QBus Slave Module
- Qx-FIFO
- Qr-FIFO
- PCI Master Module

The QBus Slave Module and PCI Master Module are shared between the QBus Slave Channel and the IDMA/DMA Channel. These components are discussed in the following sections.

## 3.2.1 QBus Slave Module

The QBus Slave Module is a non-multiplexed 32-bit address, 32-bit data interface. The QBus Slave Module accepts MC68360 cycles, and either MPC860 or M68040 cycles. The QBus Slave Module's mode is set by the SIZ[1] signal at reset. This reset option is summarized in Table 2 (for more information, see Chapter 14: "Reset Options" on page 159). The MSTSLV[1:0] field in the Miscellaneous and Control Status register (MISC\_CTL) indicates the slave (and master) mode of the QBus (see Table 127 on page 280). The connections required for interfacing the QSpan II to an MC68360, MPC860, and/or M68040 are described in Appendix C: "Typical Applications" on page 365.

#### Table 2: Reset Options for QBus Slave Modes

| Reset sampling of SIZ[1] | Slave Mode         |
|--------------------------|--------------------|
| 0                        | MC68360 and M68040 |
| 1                        | MC68360 and MPC860 |

#### 3.2.1.1 QBus Data Parity Generation and Detection

The QBus Slave Module (QSM) supports the generation and detection of QBus data parity. The use of QBus data parity is optional. Data parity is valid on the same clock cycle as the QBus data. QSpan II supports Odd and Even parity, and is controlled by QBUS\_PAR in the MISC\_CTL2 register (see Table 130 on page 284). Even parity is the default setting, which is the same as the PCI bus. The detection of a QBus data parity error does not affect the operation of the QSpan II. The PCI bus parity generation and detection is independent of the QBus data parity generation and detection.

Four pins are used for the QBus Data Parity signals: DP[3:0]. When parity is set to Even, the number of 1s on the QBus Data lines (D[7:0]) and DP[0] equal an even number. Similarly, for Odd parity, the number of 1s on D[7:0] and DP[0] equal an odd number. The following list shows which data parity signals DP[3:0] are used for which data lines:

- DP[0] contains the parity for data lines D[7:0]
- DP[1] contains the parity for data lines D[15:8]
- DP[2] contains the parity for data lines D[23:16]
- DP[3] contains the parity for data lines D[31:24]

The QBus Slave Module generates the data parity when it completes a slave read cycle. If it detects a parity error during a slave write cycle, it sets the QBus Data Parity Error Status bit (QDPE\_S) in the Interrupt Status (INT\_STAT) register (see Table 119 on page 266). QSpan II can generate an external interrupt (INT# or QINT\_) depending on the setting of QBus Data Parity Error Interrupt Enable (QDPE\_EN) bit and QBus Data Parity Error Interrupt Direction (QDPE\_DIR) bit in INT\_EN and INT\_DIR registers, respectively. Writing a 1 to the QDPE\_S bit negates the interrupt and clears the status bit.

When the QBus Slave Module detects a parity error it sets the QDPE\_S bit but continues the transfer as if there were no parity error. For example, if a write is directed to the QSpan II with a data parity error, the QBus Slave Module terminates the cycle normally and passes it onto the QSpan II's PCI interface. QSpan II's PCI master generates the write cycle with the correct parity for the data on the PCI bus.

QSpan II only checks data parity on valid bytes of data. If a single byte transfer is completed on the QBus, only the valid byte on the data bus is checked (for example, D[31:24]).

# 3.2.2 Qx-FIFO and Qr-FIFO

The Qx-FIFO is a 256-byte buffer for posted writes from the QBus to the PCI bus. The Qx-FIFO supports sixty-four 32-bit entries. The Qx-FIFO accepts data from an external QBus master while transferring data to a PCI target (for information, see "Writes" on page 52).



The Qx-FIFO is on the data path for single delayed writes. A delayed write must be completed before the following write can be posted.

The Qr-FIFO is a 32-byte buffer which stores data read from PCI Targets.

## 3.2.3 PCI Master Module

The PCI Master Module is a 32 bit/33MHz *PCI 2.2 Specification* compliant master interface. PCI signals supported by the QSpan II are outlined in "PCI Bus Signals" on page 178.

QSpan II masters the PCI bus through its PCI Master Module. The PCI Master Module is available to the QBus Slave Channel (access from a remote QBus master) and the IDMA/DMA Channel.

# 3.3 Channel Description

The operation of the QBus Slave Channel is described in the following sections by tracing the path of a transaction from the QBus to the PCI bus. This is completed by dividing a transaction into three phases:

- Address Phase: This section describes transaction decoding and how address information from the QBus is passed to a corresponding address space on the PCI bus.
- **Data Phase**: This section describes endian mapping and byte-lane translation through the QBus Slave Channel. This section also describes the methods that data is buffered in the QBus Slave Channel depending on the programming of the QBus Slave images.
- **Termination Phase**: This section discusses how terminations from a PCI target are communicated to the master on the QBus. It also describes how the QSpan II PCI Master Module handles terminations (for example, retries or Target-Aborts). We also describe the terminations the QSpan II issues as a QBus slave device.

# 3.4 Address Phase

## 3.4.1 Transaction Decoding and QBus Slave Images

QSpan II accepts a transaction through its QBus Slave Module when one of its chip selects is asserted along with the Address Strobe (AS\_) or Transaction Start signal (TS\_). The chip selects, CSREG\_ and CSPCI\_, do not need to be detected asserted on the same clock edge as TS\_ for QBus Slave Channel accesses. This allows for wait states to be inserted to perform address decoding. However, the IDMA Channel requires that CSPCI\_ be detected asserted on the same clock edge as TS\_ for QBus Slave Channel accesses IDMA transfers.



Single address IDMA transfers do not require CSPCI\_ to be asserted.

If CSREG\_ is asserted, then the transaction is decoded as a QSpan II register access (if the address 0x504 is a PCI Configuration cycle, see Chapter 7: "The Register Channel" on page 109). In order to access the PCI bus, the QBus master (or address decoder circuitry) asserts the PCI chip-select pin (CSPCI\_) and the QBus Slave Module claims the cycle for the QBus Slave Channel. One of the two QBus Slave Images is selected during this transaction. The QBus Slave Image is qualified by the Image Select Signal (IMSEL).

The type of PCI cycle generated by the QSpan II depends on the following:

- which QBus Slave Image is selected
- the type of transaction initiated by the external QBus master

The level of IMSEL determines which of the two QBus Slave Images is used. If IMSEL is 0, QBus Slave Image 0 is selected (see Table 133 on page 289 and Table 138 on page 291); if IMSEL is 1, QBus Slave Image 1 is selected (see Table 140 on page 293 and Table 145 on page 295). The levels of BURST\_ and R/W\_ determine whether the QSpan II will generate a single PCI cycle or a burst, a PCI read or a write, respectively. There is some interaction between images and hardware signals, as described in Tables 133 to 145.

A Slave Image is a set of parameters which are encoded in QSpan II registers. A Slave Image controls transfers between the QBus and the PCI bus. Similar Target Images are provided in the PCI Target Channel. Two QBus Slave images of equal capability are provided so that designers can quickly access — on the basis of hardware rather than software — PCI addresses from the QBus, or access addresses in different ways. The two Slave Images are completely independent from one another.

For example, the designer can set-up QBus Slave Image 0 to access a hard-disk using 128 Mbytes of memory in PCI memory space. The designer can simultaneously have QBus Slave Image 1 available to access a different device, with its own memory size. The designer can access the first device with posted writes — Posted Write Enable (PWEN) bit set to 1 — and the other with delayed writes — PWEN set to 0. For a third type of access, it would be necessary to share one of the Slave Images.

The following tables summarize the QBus Slave Image control and address fields.

| Table 3: Address | Fields | for QBus | Slave | Image |
|------------------|--------|----------|-------|-------|
|------------------|--------|----------|-------|-------|

| Field                         | Abbreviation and<br>Register Page                        | Description                                                          |
|-------------------------------|----------------------------------------------------------|----------------------------------------------------------------------|
| Block Size                    | BS (Table 138 on page 291 and<br>Table 145 on page 295)  | Amount of PCI memory<br>accessible from QBus                         |
| PCI Address Space             | PAS (Table 133 on page 289 and<br>Table 140 on page 293) | Mapping to PCI memory<br>space or I/O space                          |
| Translation Address           | TA (Table 138 on page 291 and<br>Table 145 on page 295)  | Address bits that are substituted to<br>generate the PCI bus address |
| Enable Address<br>Translation | EN (Table 138 on page 291 and<br>Table 145 on page 295)  | Enables address translation<br>using TA field                        |

#### Table 4: Control Fields for QBus Slave Image

| Field         | Abbreviation and Register Page                            | Description              |
|---------------|-----------------------------------------------------------|--------------------------|
| Posted Write  | PWEN (Table 133 on page 289 and<br>Table 140 on page 293) | Posted write enable bit  |
| Prefetch Read | PREN (Table 133 on page 289 and<br>Table 140 on page 293) | Prefetch read enable bit |

The QBus Slave Channel allows a QBus master to access a range of addresses in PCI Memory or I/O space. The PCI address space bit (PAS) of the selected image determines whether the current transfer is directed towards PCI Memory or I/O space. The range of addresses that can be accessed through a Slave Image is controlled by the block size (BS) field. Up to 2 Gbytes of PCI Memory or I/O space can be accessed from the QBus in one Slave Image if address translation is required. The use of the Block Size, PCI Address Space, Translation Address and Enable Address Translation fields is discussed in "Address Translation" on page 46, and "Address Phase on the PCI Bus" on page 49.

The QBus Slave Image Control registers specify how writes are processed (see Table 133 on page 289 and Table 140 on page 293). If the PWEN bit is 1, the QSpan II will perform posted writes when the specific QBus Slave Image is accessed with a single write. Otherwise writes are handled as single delayed transactions. If the PREN bit is 1, the QSpan II will perform a burst read on the PCI bus when the MPC860 or MC68360 performs a single 32-bit read on the QBus. Otherwise, the QSpan II will handle this as a single delayed read transaction.

QBus Slave Image 0 can also be programmed from an external EEPROM (for information, see "Mapping of EEPROM Bits to QSpan II Registers" on page 130.

## 3.4.1.1 MPC860 Cycles

QSpan II behaves as an MPC860 slave in response to the assertion of the TS\_ signal when it is powered-up as an MPC860 slave (see "QBus Slave Module" on page 41). When the QBus Slave Module receives TS\_ it responds with DSACK1\_/TA\_, BERR/TEA\_, or HALT\_/TRETRY\_. QSpan II acknowledges the transaction if either CSREG\_ or CSPCI\_ is sampled active in conjunction with TS\_. QSpan II samples the address bus and control signals on the same rising edge of QCLK in which it samples either CSPCI\_ or CSREG\_ asserted.

If BURST\_/TIP\_ is asserted at the beginning of the bus cycle, along with the address, the QSpan II accepts the incoming cycle as a burst. During bursts, the QSpan II monitors BDIP\_, which when negated, indicates the current data phase is second last.



When the QSpan II operates as an MPC860 slave for non-IDMA transfers, it functions as a 32-bit peripheral and must be addressed as a 32-bit peripheral. External QBus masters must comply with the MPC860 timing specification.

## 3.4.1.2 MC68360 Cycles

QSpan II behaves as a MC68360 slave in response to the assertion of the Address Strobe (AS\_) signal. When it receives AS\_ it asserts a subset of DSACK1\_/TA\_, DSACK0\_, BERR\_/TEA\_ and HALT\_/TRETRY\_. QSpan II acknowledges the transaction if either CSREG\_ or CSPCI\_ is sampled active in conjunction with AS\_. QSpan II does not require that the input signals qualified by AS\_ be valid when AS\_ is asserted — it requires only that they meet the set-up time before the same falling clock edge when AS\_ is first sampled asserted.

When the QSpan II operates as a MC68360 slave, it functions as a 32-bit peripheral in synchronous mode. As a master, the QSpan II also operates synchronously and therefore the Bus Synchronous Timing mode (BSTM) bit in the MC68360 must be set to 1 (for more information, see the *Motorola MC68360 User's Manual*). External QBus masters must comply with the MC68360 timing specification.

## 3.4.1.3 M68040 Cycles

QSpan II behaves as an M68040 slave in response to the assertion of the TS\_ signal when it is powered-up as an M68040 slave (see "QBus Master and Slave Modes" on page 162). When the QBus Slave Module receives TS\_ it responds with DSACK1\_/TA\_ or BERR\_/TEA\_. QSpan II recognizes a transaction as intended for it, and acknowledges it accordingly, only if one of CSREG\_ or CSPCI\_ is sampled active in conjunction with TS\_. QSpan II samples the address bus and other TS\_ qualified signals on the same rising edge of QCLK in which it samples TS\_ asserted. The QBus Slave Module accepts bursting of incoming data.



When the QSpan II operates as an M68040 slave, it functions as a 32-bit peripheral in synchronous mode and must be addressed as a 32-bit peripheral. External QBus masters must comply with the M68040 timing specification.

## 3.4.2 PCI Bus Request

The PCI Master Module requests the PCI bus when one of the following occurs:

- write data is received in the Qx-FIFO
- after the last data phase of a burst write is received in the Qx-FIFO
- if there is a read request

If the QSpan II is powered up to use an external PCI bus arbiter when it requires control of the PCI bus, it asserts REQ# and gains bus mastership when the PCI arbiter asserts grant. If the QSpan II is powered up to use the internal PCI bus arbiter, the request-grant signals are internal. If the arbiter removes grant after the QSpan II has begun its PCI transaction, the QSpan II completes the current cycle and releases the PCI bus. This means that the QSpan II PCI Master Module will have to re-arbitrate for the PCI bus after every cycle if its grant is removed. QSpan II performance as PCI master can be enhanced through bus parking, as defined in the *PCI Local Bus Specification 2.2* (for more information about bus parking, see "Bus Parking" on page 148).



QSpan II cannot be master and target on the PCI bus at the same time.

## 3.4.3 Address Translation

The QBus Slave Channel contains an Address Generator (see Figure 4) which is used if address translation is enabled (EN bit in Table 138 or Table 145). The Address Generator produces the PCI address using three inputs: the address of the QBus signal (A[31:0]), the block size of the QBus Slave Image (BS field of the QBSIx\_AT register), and the translation address of the QBus Slave Image (TA field of the QBSIx\_AT register). The translation address is a 16-bit number whose upper bits specify the location of the Target Image on the PCI bus. The correlation between BS and the number of TA bits to use in generating the PCI address is shown in Table 5 on page 48.

For example, with a 64 Kbyte block size, the Address Generator copies the entire translation address into the PCI address, but only copies the lower 16 bits from the QBus address signals. With a 2 Gbyte block size, the Address Generator copies all but bit 31 from the QBus address signal. For example, the Address Generator translates A[31] only while copying A[30:0]), and uses the top translation address bit as bit 31 of the PCI address.



#### Figure 4: Address Generator for QBus Slave Channel Transfers



This manual adopts the convention that the most significant bit (address or data) is always the largest number. MPC860 designers must ensure that they connect their pins accordingly. For example, pin A[31] on the QSpan II connects to pin A[31] on the MC68360 bus, but connects to pin A[0] on the MPC860 bus. This applies to all MPC860 buses (D[31:0], AT[3:0], TSIZ[1:0]) not only the address bus.

| BS in QBSI0_CTL or<br>QBSI1_CTL | Block Size | Address Lines<br>Translated | Translation Address Bits<br>Copied |
|---------------------------------|------------|-----------------------------|------------------------------------|
| 0000                            | 64 Kbytes  | A31–A16                     | TA31–TA16                          |
| 0001                            | 128 Kbytes | A31–A17                     | TA31–TA17                          |
| 0010                            | 256 Kbytes | A31–A18                     | TA31–TA18                          |
| 0011                            | 512 Kbytes | A31–A19                     | TA31–TA19                          |
| 0100                            | 1 Mbyte    | A31–A20                     | TA31–TA20                          |
| 0101                            | 2 Mbytes   | A31–A21                     | TA31–TA21                          |
| 0110                            | 4 Mbytes   | A31–A22                     | TA31–TA22                          |
| 0111                            | 8 Mbytes   | A31–A23                     | TA31–TA23                          |
| 1000                            | 16 Mbytes  | A31–A24                     | TA31–TA24                          |
| 1001                            | 32 Mbytes  | A31–A25                     | TA31–TA25                          |
| 1010                            | 64 Mbytes  | A31–A26                     | TA31–TA26                          |
| 1011                            | 128 Mbytes | A31–A27                     | TA31–TA27                          |
| 1100                            | 256 Mbytes | A31–A28                     | TA31–TA28                          |
| 1101                            | 512 Mbytes | A31–A29                     | TA31–TA29                          |
| 1110                            | 1 Gbyte    | A31–A30                     | TA31–TA30                          |
| 1111                            | 2 Gbytes   | A31                         | TA31                               |

Table 5: Translation of QBus Address to PCI Address

# 3.4.4 Address Phase on the PCI Bus

The address supplied on the AD[31:0] lines on the PCI bus is the result of the address translation described in the previous section. The PCI command encoding on the C/BE#[3:0] lines is determined by the type of transaction on the QBus, and the programming of the PCI Bus Address Space (PAS) and Prefetch Read Enable (PREN) bits in the QBus Slave Image Control Registers (see Table 133 on page 289 or Table 140 on page 293). The following table lists the C/BE encoding supported by the QSpan II.

| C/BE# [3:0] | Command Type                | QSpan II Capability                           |
|-------------|-----------------------------|-----------------------------------------------|
| 0000        | Interrupt Acknowledge       | See "Interrupt Acknowledge Cycle" on page 125 |
| 0001        | Special Cycle               | N/A                                           |
| 0010        | I/O Read                    | Target/Master                                 |
| 0011        | I/O Write                   | Target/Master                                 |
| 0100        | Reserved                    | N/A                                           |
| 0101        | Reserved                    | N/A                                           |
| 0110        | Memory Read                 | Target/Master                                 |
| 0111        | Memory Write                | Target/Master                                 |
| 1000        | Reserved                    | N/A                                           |
| 1001        | Reserved                    | N/A                                           |
| 1010        | Configuration Read          | Target/Master                                 |
| 1011        | Configuration Write         | Target/Master                                 |
| 1100        | Memory Read Multiple        | Target <sup>a</sup> /Master                   |
| 1101        | Dual Address Cycle          | N/A                                           |
| 1110        | Memory Read Line            | Targeta/Master                                |
| 1111        | Memory Write and Invalidate | Target <sup>b</sup> /Master                   |

#### Table 6: Command Type Encoding for Transfer Type

a. These commands are aliased to a memory read.

b. This command is aliased to a memory write.

PCI Targets are expected to assert DEVSEL# if they have decoded the access. If a target does not respond with DEVSEL# within 6 clocks, a Master-Abort is generated by the QSpan II. The following shows the mapping from QBus transaction type to PCI transaction type as a function of PAS programming.

| QBus transaction received | PAS bit programming | PCI transaction type |
|---------------------------|---------------------|----------------------|
| Single or Burst Read      | Memory              | Memory Read          |
| Single Read               | I/O                 | I/O Read             |
| Burst Read                | I/O                 | None <sup>a</sup>    |
| Single or Burst Write     | Memory              | Memory Write         |
| Single Write              | I/O                 | I/O Write            |
| Burst Write               | I/O                 | None <sup>a</sup>    |

Table 7: Translation from QBus Transaction to PCI Transaction Type

a. In this case an error is signaled on the QBus.

# 3.5 Data Phase

This section describes how endian mapping is executed in the QBus Slave Channel. It also discusses the data path for different transaction types.

## 3.5.1 Endian Mapping

The PCI bus and Motorola processors differ in the way they order and address bytes. These differences are explained in Appendix E: "Endian Mapping" on page 395. This section describes how the QSpan II translates cycles from the QBus to the PCI bus.

The PCI bus is always a Little-Endian environment. The QBus can be configured as Little-Endian or Big-Endian, depending on the value of the QBus Byte Ordering Control bit (QB\_BOC) in the MISC\_CTL register (see Table 127 on page 280). The default mode for the QBus is Big-Endian. QSpan II translates byte-lane ordering when the QBus is Big-Endian, while preserving the addressing of bytes. When the QBus is Little-Endian, the QSpan II preserves byte-lane ordering, while translating the addressing of bytes. Note that the QB\_BOC bit affects transactions in all channels.

The following tables describe cycle mapping for Little-Endian and Big-Endian of all sizes (8, 16, 24, or 32 bits).

|          | QBus   |             |          | PCI Bus     |
|----------|--------|-------------|----------|-------------|
| SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]# | D[31:0]     |
| 01       | 00     | B3 xx xx xx | 0111     | B3 xx xx xx |
| 01       | 01     | xx B2 xx xx | 1011     | xx B2 xx xx |
| 01       | 10     | xx xx B1 xx | 1101     | xx xx B1 xx |
| 01       | 11     | xx xx xx B0 | 1110     | xx xx xx B0 |
| 10       | 00     | B3 B2 xx xx | 0011     | B3 B2 xx xx |
| 10       | 01     | xx B2 B1 xx | 1001     | xx B2 B1 xx |
| 10       | 10     | xx xx B1 B0 | 1100     | xx xx B1 B0 |
| 10       | 11     | xx xx xx B0 | 1110     | xx xx xx B0 |
| 11       | 00     | B3 B2 B1 xx | 0001     | B3 B2 B1 xx |
| 11       | 01     | xx B2 B1 B0 | 1000     | xx B2 B1 B0 |
| 11       | 10     | xx xx B1 B0 | 1100     | xx xx B1 B0 |
| 11       | 11     | xx xx xx B0 | 1110     | xx xx xx B0 |
| 00       | 00     | B3 B2 B1 B0 | 0000     | B3 B2 B1 B0 |
| 00       | 01     | xx B2 B1 B0 | 1000     | xx B2 B1 B0 |
| 00       | 10     | xx xx B1 B0 | 1100     | xx xx B1 B0 |
| 00       | 11     | xx xx xx B0 | 1110     | xx xx xx B0 |

| Table 8: Little-Endian   | QBus | Slave | Channel | Cycle | Manning |
|--------------------------|------|-------|---------|-------|---------|
| Table 0. Little-Litulati | QDus | Jiave | Ghannei | Cycle | mapping |

| QBus     |        |             |          | PCI Bus     |
|----------|--------|-------------|----------|-------------|
| SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]# | D[31:0]     |
| 01       | 00     | B0 xx xx xx | 1110     | xx xx xx B0 |
| 01       | 01     | xx B1 xx xx | 1101     | xx xx B1 xx |
| 01       | 10     | xx xx B2 xx | 1011     | xx B2 xx xx |
| 01       | 11     | xx xx xx B3 | 0111     | B3 xx xx xx |
| 10       | 00     | B0 B1 xx xx | 1100     | xx xx B1 B0 |
| 10       | 01     | xx B1 B2 xx | 1001     | xx B2 B1 xx |
| 10       | 10     | xx xx B2 B3 | 0011     | B3 B2 xx xx |
| 10       | 11     | xx xx xx B3 | 0111     | B3 xx xx xx |
| 11       | 00     | B0 B1 B2 xx | 1000     | xx B2 B1 B0 |
| 11       | 01     | xx B1 B2 B3 | 0001     | B3 B2 B1 xx |
| 11       | 10     | xx xx B2 B3 | 0011     | B3 B2 xx xx |
| 11       | 11     | xx xx xx B3 | 0111     | B3 xx xx xx |
| 00       | 00     | B0 B1 B2 B3 | 0000     | B3 B2 B1 B0 |
| 00       | 01     | xx B1 B2 B3 | 0001     | B3 B2 B1 xx |
| 00       | 10     | xx xx B2 B3 | 0011     | B3 B2 xx xx |
| 00       | 11     | xx xx xx B3 | 0111     | B3 xx xx xx |

Table 9: Big-Endian QBus Slave Channel Cycle Mapping

## 3.5.2 Data Path

### 3.5.2.1 Writes

If the PWEN bit is set in the QBSIx\_CTL register, single write transactions from the QBus will be posted (see Table 133 on page 289 and Table 140 on page 293). The level of IMSEL determines which QBSIx\_CTL register is used (see "Transaction Decoding and QBus Slave Images" on page 43). If the PWEN bit is cleared — this is the default setting — single write transactions are treated as delayed transactions. Burst write transfers are always treated as posted writes.

Both posted and delayed writes travel through the Qx-FIFO. With posted writes, data acknowledgment is provided on the QBus as soon as the write data is queued in the Qx-FIFO. Multiple posted writes can be queued up to the 256-byte capacity of the Qx-FIFO. With delayed writes, data acknowledgment is provided on the QBus after completion on the PCI bus. This means only one delayed write at a time. Additional writes are retried while a delayed write is in progress.

Posted write transfers are stored in the Qx-FIFO. Address and data are stored as separate entries in the Qx-FIFO. For example, one single cycle data beat transaction is stored as two Qx-FIFO entries: one entry for the address of the transaction, and one for the data. The address entry contains the translated PCI address space and command information mapping relevant to the QBus Slave Image which is accessed (see "Address Phase" on page 43). The data entry contains the data and the byte enables. Thus, any reprogramming of QBus Slave Image attributes will only be reflected in Qx-FIFO entries queued after the reprogramming. Transactions queued before the reprogramming are delivered to the PCI bus with the QBus Slave Image attributes that were in use before the reprogramming. QSpan II never packs data in the Qx-FIFO. For example, two 16-bit data beats are not packed as a single 32-bit data entry but as four separate entries in the Qx-FIFO (address, data, address, data).

If a QBus master attempts to post a write transaction when the Qx-FIFO does not have enough space, the QBus Slave Channel retries the master. The exact manner in which the master is retried depends on whether the master is an MC68360, MPC860 or M68040 device (see "Termination Phase" on page 57. Since single transfers require two entries in the Qx-FIFO, two entries must be available before the QBus Slave Module accepts a single write transaction. However, the 256-byte depth of the Qx-FIFO ensures a very low probability that the Qx-FIFO is too full to accept write transactions.

The PCI Master Module requests the PCI bus when there is a complete transaction in the Qx-FIFO. During write transactions, the PCI Master Module uses transactions queued in the Qx-FIFO to generate transactions on the PCI bus. No address phase deletion is performed; thus, the length of a transaction on the PCI bus corresponds to the length of the queued QBus transaction.

Only MPC860 and M68040 Masters are capable of initiating burst transactions. Incoming burst write transactions comprise five entries in the Qx-FIFO: one entry for address and command information, and four data entries. The QBus Slave Module accepts bursts if the Qx-FIFO has enough room for the entire burst. Burst transfers are never retried while they are in progress. The MPC860 and M68040 perform bursts of 16 bytes. Bursts accepted from the QBus are translated to the PCI bus as one or more burst transactions. QSpan II always bursts using linear increment addressing.

Burst transactions are always posted, regardless of the programming of the PWEN bit in the selected QBSIx\_CTL register. QSpan II accepts bursts targeted to Memory space, but not to I/O or Configuration space. If the PCI address space (PAS) bit of the selected image is set to I/O space and a burst is initiated by a QBus master, then the QSpan II signals a bus error. Similarly, if a burst is attempted to the QSpan II registers, a bus error is signaled by the QSpan II (see "Termination Phase" on page 57).



To improve performance of posted write transfers, set the QSC\_PW bit in the MISC\_CTL2 register (see Table 130 on page 284). This configuration reduces the number of idle PCI clocks between posted write transfers initiated by the QSpan II's PCI master.

#### 3.5.2.2 Read Transactions — Burst and Single Cycle

During a read transaction, address, data, size and transaction code signals are latched by the QBus Slave Module. After latching the information, the QSpan II retries all incoming QBus cycles, but does not latch them until the read completes on the QBus. QSpan II becomes PCI bus master and performs a read transaction on the PCI bus. The read data is queued in the Qr-FIFO. If the PCI transaction completes normally, then the QBus master is provided with the data from the Qr-FIFO and the transaction terminates normally on the QBus (see "Termination Phase" on page 57).

If the QBus master attempts a burst read to the QBus Slave Module, and the Slave Image is programmed for PCI Memory Space, then the QSpan II initiates a read cycle. If the read is attempted to a Slave Image programmed for PCI I/O Space, or to QSpan II registers, then the QBus Slave Module terminates the access with a bus error.



A burst read is four beats in length (16 bytes).

### 3.5.2.3 Prefetched Reads

QSpan II supports prefetched reads in the QBus Slave Channel for MPC860 and MC68360 cycles; M68040 cycles are not supported. To enable prefetching on an image basis, set the PREN bit in QBSI0\_CTL or QBSI1\_CTL. When this bit is set, and the QSpan II decodes a single 32-bit aligned, 4-byte read on the QBus from an external master, it initiates a prefetch of 32 bytes on the PCI bus using linear-address incrementing. Once all 32 bytes are available in the Qr-FIFO, the external QBus master receives the first four bytes of read data. If a subsequent read is performed at the next address, which is the current address +0x4, the QSpan II returns the data from Qr-FIFO instead of completing another read on PCI.

Transaction ordering is strictly enforced for the first data read. Before the read is completed on the PCI bus, any posted writes in the Qx-FIFO are emptied on the PCI bus. Before the first read data is returned on the QBus, any posted writes in the Px-FIFO are emptied on the QBus. When reading subsequent prefetched data from the Qr-FIFO, the QSpan II does not check whether the posted FIFOs (Qx-FIFO and Px-FIFO) are empty.

The prefetched data, not including the first 4 bytes, is invalidated under the following conditions:

- QBus discard timer expires: 32768 QCLKs after the first read data is available
- Delayed write cycle is latched in the QBus Slave Channel
- Delayed read cycle to an address that is not the current address +0x4, or a non 4-byte access through the QBus Slave Channel
- Burst MPC860 read cycle through the QBus Slave Channel

When the QSpan II detects a single read cycle that is not 32-bit aligned or is not a 4-byte access, it performs a single read on the PCI bus with the appropriate byte enables.

If the QSpan II detects a prefetchable cycle when it is active during an MPC860 IDMA transfer (DREQ\_ asserted), it converts the prefetch cycle into a normal delayed read cycle because the DACK\_ can be delayed with respect to TS\_. QSpan II does not need to convert prefetchable cycles of the MC68360 because DACK\_ has the same timing as AS\_.

During a burst read on the PCI bus (which is a result of a prefetch) if one of the data beats is terminated with an error, the 32 bytes are invalidated and the QSpan II terminates the cycle on the QBus with a Bus Error.

### 3.5.2.4 Delayed Reads and PCI Transaction Ordering

In order to satisfy PCI Transaction Ordering requirements, the rules described in this section are implemented in the QSpan II (see "Delayed Reads" in the *PCI 2.2 Specification*). These rules affect the relation between delayed reads and posted writes in the QBus Slave Channel. The rules also affect the relation between delayed reads in the QBus Slave Channel and posted writes in the PCI Target Channel.

The following list summarizes the sequence of QSpan II events:

- 1. The QBus Slave Module receives a read request.
- 2. The QBus Slave Channel empties the Qx-FIFO of any writes or completes any current reads.
- 3. The QBus Slave Module latches the read request.
- 4. The QBus Slave Module retries subsequent non-register accesses.
- 5. The PCI Master Module completes the read on the PCI bus.
- 6. The PCI Target Module retries all non-register accesses.
- 7. The Px-FIFO is emptied.

In the case of QBus Slave Channel burst reads:

- 8. The PCI Target Module allows posted writes to the Px-FIFO.
- 9. The QBus Slave Module allows the burst read to complete on the QBus.
- 10. The QBus Slave Module accepts new accesses.

In the case of QBus Slave Channel single reads:

- 8. The QBus Slave Module allows the read to complete on the QBus.
- 9. The QBus allows posted writes to the Qx-FIFO, even if the single read has not completed.
- 10. The PCI Target Module allows posted writes to the Px-FIFO.

### Transaction Ordering Disable Option

The No Transaction Ordering (NOTO) bit in the MISC\_CTL2 register disables transaction ordering between the QBus Slave Channel and the PCI Target Channel (see Table 130 on page 284). When this bit is set, a read in one channel is unaffected by posted writes in the other channel.

This feature improves system performance, especially when using the DMA and where strict transaction ordering is not required.

## 3.5.3 PCI Target Channel Reads

In PCI Target Channel reads, the PCI Target Module latches the read request even when there is data in the Px-FIFO. The PCI Target Module only passes the information onto the QBus Master Module when the Px-FIFO is empty (see "Reads and PCI Transaction Ordering" on page 81).

## 3.5.4 Parity Monitoring by PCI Master Module

QSpan II monitors the Parity signal (PAR) when it accepts data as a PCI master during a read, and drives PAR when it provides data as a PCI master during a write. QSpan II also drives PAR during the address phase of a transaction when it is a PCI master. In both address and data phases, the PAR signal provides even parity for C/BE#[3:0] and AD[31:0].

The PERESP (Parity Error Response) bit in the PCI\_CS (PCI Configuration Space Control and Status register) determines whether or not the QSpan II responds to parity errors as PCI master (see Table 70 on page 207). Data parity errors are reported through the assertion of PERR# if the PERESP bit is set.

The Detected Parity Error (D\_PE) bit in the PCI\_CS register is set if the QSpan II encounters one of the following situations:

- a parity error during an address phase
- a parity error during a write when QSpan II is the target
- a parity error during a read when QSpan II is the master

The Master Data Parity Error Detect (MD\_PED) bit in the PCI\_CS register is set if parity checking is enabled through the PERESP bit, and the QSpan II detects a parity error while it is PCI master (for example, it asserts PERR# during a read transaction or receives PERR# during a write). If the QSpan II sets the MD\_PED bit while the MDPED\_EN (Data Parity Detected Interrupt Enable) bit in the INT\_CTL register is set (see Table 120 on page 269), then the QSpan II asserts an interrupt on the QBus or PCI bus interface (see Chapter 8: "The Interrupt Channel" on page 119).

QSpan II continues the transaction regardless of any parity errors reported during the transaction.

# 3.6 Termination Phase

Except during posted writes, the termination generated by the QBus Slave Module is determined by the termination on the PCI bus (see "Posted Write Termination" on page 59). For read transactions and delayed write transactions, the QBus master is retried until the PCI transaction is complete. Once the PCI transaction is complete, the QBus master receives a translated version of the PCI termination. The following table shows how PCI terminations are translated to the QBus Slave Module during delayed transactions, such as delayed single reads, delayed single writes and reads.

| PCI Bus Termination Received | QBus Termination Issued                                                                                                                                       |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master-Completion            | Normal                                                                                                                                                        |
| Master-Abort                 | Bus Error if MA_BE_D bit is 0.<br>Normal if MA_BE_D bit is 1 (reads return all<br>1s, write data flushed).                                                    |
| Target-Retry                 | N/A <sup>b</sup>                                                                                                                                              |
| Target-Disconnect            |                                                                                                                                                               |
| Target-Abort                 | Bus Error if MA_BE_D bit is 1 and the<br>TA_BE_EN bit is 1.<br>Normal if MA_BE_D bit is 1 and the<br>TA_BE_EN bit is 0 (reads all 1s; write data<br>flushed). |

#### Table 10: Translation of Cycle Termination<sup>a</sup> from PCI Bus to QBus

a. This table applies to delayed transfers.

b. These cycles are not translated. The QBus Slave Module retries the master during delayed transactions until one of the other terminations is received.

The QBus Slave Module retries accesses under the following conditions:

- A QBus master attempts to post another write to the QBus Slave Channel and the Qx-FIFO does not have enough room for the write.
- A QBus master attempts a burst write transfer and there is not enough room in the Qx-FIFO for the complete burst. The QBus Slave Module never retries an ongoing burst transaction.
- A prefetched read is in progress in the QBus Slave Channel.
- A delayed transfer read or write is in progress in the QBus Slave Channel.

The QBus Slave Module generates a bus error under the following conditions:

• A QBus master attempts to burst to a Slave Image whose transfers have been set to I/O space.

- A delayed transfer or a prefetched read results in a Target-Abort and the MA\_BE\_D bit in the MISC\_CTL register is 0, or the MA\_BE\_D bit is 1 and the TA\_BE\_EN bit in the MISC\_CTL2 register is 1.
- A delayed transfer results in a Master-Abort and the MA\_BE\_D bit in the MISC\_CTL register is 0.



Set the MA\_BE\_D (see Table 127 on page 280) and TA\_BE\_EN (see Table 130 on page 284) bits if the QSpan II is used as a host bus bridge. This is in compliance with the *PCI Local Bus Specification 2.2*.

The mapping of the QBus terminations to the MC68360, MPC860, and M68040 buses is shown in Tables 11 to 13.

| Termination Type | DSACK0_,<br>DSACK1_/TA_ | BERR_/TEA_              | HALT_/TRETRY_     |
|------------------|-------------------------|-------------------------|-------------------|
| Normal           | Asserted                | Tri-stated <sup>a</sup> | Tri-stated        |
| Bus Error        | Asserted                | Asserted                | <b>Tri-stated</b> |
| Retry            | Asserted                | Asserted                | Asserted          |

#### Table 11: MC68360 Cycle Terminations of QBus Slave Module

a. External pull-ups bring tri-stated signals to the non-asserted state.

#### Table 12: MPC860 Cycle Terminations of QBus Slave Module

| Termination Type | DSACK1_/TA_       | BERR_/TEA_              | HALT_/TRETRY_ |
|------------------|-------------------|-------------------------|---------------|
| Normal           | Asserted          | Tri-stated <sup>a</sup> | Tri-stated    |
| Bus Error        | <b>Tri-stated</b> | Asserted                | Tri-stated    |
| Retry            | Tri-stated        | Tri-stated              | Asserted      |

a. External pull-ups bring tri-stated signals to the non-asserted state.

#### Table 13: M68040 Cycle Terminations of QBus Slave Module

| Termination Type | DSACK1_/TA_ | BERR_/TEA_              |
|------------------|-------------|-------------------------|
| Normal           | Asserted    | Tri-stated <sup>a</sup> |
| Bus Error        | Negated     | Asserted                |
| Retry            | Asserted    | Asserted                |

a. External pull-ups bring tri-stated signals to the non-asserted state.

The following table summarizes the QSpan II's response to abnormal terminations on the PCI bus.

| Transfer-<br>type | PCI Error Type | MA_BE_D in<br>MISC_CTL | TA_BE_EN in<br>MISC_CTL2 | Flush FIFO <sup>a</sup>                                       | QBus<br>Termination      |
|-------------------|----------------|------------------------|--------------------------|---------------------------------------------------------------|--------------------------|
| read              | Master-Abort   | 0                      | х                        | Yes                                                           | Bus error                |
|                   |                | 1                      | x                        | Yes                                                           | Normal<br>(return all 1) |
|                   | Target-Abort   | 0                      | х                        | Yes                                                           | Bus error                |
|                   |                | 1                      | 0                        | Yes                                                           | Normal<br>(return all 1) |
|                   |                |                        | 1                        | Yes                                                           | Bus error                |
| posted<br>write   | Master-Abort   | 0                      | x                        | No. Lose one<br>entry, continue<br>sinking data. <sup>b</sup> | Normal                   |
|                   |                | 1                      | x                        | No. Lose one<br>entry, continue<br>sinking data. <sup>b</sup> | Normal                   |
|                   | Target-Abort   | 0                      | x                        | No. Lose one<br>entry, continue<br>sinking data. <sup>b</sup> | Normal                   |
|                   |                | 1                      | х                        | No. Lose one<br>entry, continue<br>sinking data. <sup>b</sup> | Normal                   |

**Table 14: QBus Slave Channel Error Responses** 

a. This column pertains to Qr-FIFO for reads, and Qx-FIFO for writes.

b. If a single posted write transfer results in a Master-Abort, then this complete transaction is lost and the QSpan will continue sinking any subsequent posted write entries.
If a burst write results in a Master-Abort on the first data beat, then this data entry is lost. It is likely that the second, third and fourth entries of the burst will also result in a Master-Abort and this data will be lost as well.

## 3.6.1 **Posted Write Termination**

QBus terminations of posted writes are not influenced by the PCI bus termination. If a posted write is terminated by a Target-Abort or Master-Abort on the PCI bus, this termination is not signaled on the QBus to the QBus master. However, errors on the PCI bus are accessible to external QBus Masters through error logging. Error logging is enabled by the EN bit of the PCI Bus Error Log Control and Status Register (PB\_ERRCS) register. Errors can be enabled to cause interrupts (see Table 98 on page 240).

QSpan II can record the address, command, data, and byte enables of a posted write transaction that results in a Master-Abort or Target-Abort. The EN bit of the PB\_ERRCS register enables error recording. If enabled, the occurrence of an error is indicated by the ES bit of the PB\_ERRCS register. Transfers in the QBus Slave Channel are suspended until the ES bit is cleared if the Unlock QBus Slave Channel (UNL\_QSC) bit in the PB\_ERRCS register is set to 0 (see Table 98 on page 240). Tundra recommends that the UNL\_QSC bit always be set to 1 if error logging is enabled. If enabled, the PB\_ERRCS register latches the command information of the transaction error (CMDERR field) as well as the byte enables of the transaction error (BE\_ERR field). The address of the transaction error is latched in the PCI Bus Address Error Log (PB\_AERR) register. The data of the transaction error is latched in the PCI Bus Data Error Log Register (PB\_DERR) register.

If error logging is enabled with UNL\_QSC set to 1, and the QBus Slave Channel is errored, the QSpan II's PCI bus Master interface is not halted. However, the error logs are frozen with the first failed transaction until the status bit is cleared.

If error logging is not enabled and the QBus Slave Channel incurs an error while dequeuing data, the errored transfer is lost and the Qx-FIFO operation continues with the next enqueued transfer.

An interrupt will be generated upon the logging of an error (ES bit in PB\_ERRCS) only if the PCI Bus Error Log Interrupt Enable (PEL\_EN) bit in the INT\_CTL register is set (see Table 119 on page 266). If generated, the interrupt is directed to the QBus or the PCI bus, depending on the PCI Error Log Interrupt Direction (PEL\_DIR) bit in the INT\_DIR register (see Table 121 on page 272). Interrupts are described in Chapter 8: "The Interrupt Channel" on page 119.

# 3.7 PCI Master Retry Counter

QSpan II PCI master limits the number of times a cycle is repeated on the PCI bus due to an external PCI target terminating the cycle with a retry. QSpan II can be programmed to accept the following number of retires: 128, 256, 384, or indefinitely, depending on the setting of the MAX\_RTRY in the MISC\_CTL2 register (see Table 130 on page 284). Once the maximum number of retries is completed, the QSpan II discards the cycle and terminates the cycle on the QBus. Read cycles and delayed write cycles on the QBus Slave Channel are terminated on the QBus with a bus error. For posted writes to the Qx-FIFO, and if error logging is enabled, the QSpan II captures the discarded transfer in the PCI Error log.

# Chapter 4: The PCI Target Channel

This chapter describes the QSpan II's PCI Target Channel. The following topics are discussed:

- "PCI Target Channel Architecture" on page 62
- "Channel Description" on page 64
- "Address Phase" on page 65
- "Data Phase" on page 72
- "Reads and PCI Transaction Ordering" on page 81
- "QBus Arbitration and Sampling" on page 82
- "Terminations" on page 84

## 4.1 Overview

An external PCI bus master can access a QBus slave through the QSpan II using its PCI Target Channel (see Figure 5). The initialization of this channel is discussed in "PCI Target Channel Initialization" on page 387.



#### Figure 5: PCI Target Channel — Functional Diagram

# 4.2 PCI Target Channel Architecture

Figure 5 shows the PCI Target Channel in relation to the QBus and the PCI bus. The arrows represent data flow. The QBus is shown as having one slave; the PCI bus is shown with a single PCI master. The PCI Target Channel has the following components:

- PCI Target Module
- Px-FIFO
- Pr-FIFO
- QBus Master Module

### 4.2.1 PCI Target Module

QSpan II's PCI Target Interface is a *PCI Local Bus Specification 2.2* compliant port. QSpan II does not implement SBO#, SDONE or PCI LOCK# functionality. A list of the PCI signals supported by the QSpan II is in "PCI Bus Signals" on page 178.

The PCI Target Module accepts Type 0 Configuration cycles and ignores Type 1 Configuration cycles. Configuration cycles are not passed to the QBus (for information, see "PCI Configuration Cycles Generated from the QBus" on page 114).

# 4.2.2 Px-FIFO and Pr-FIFO

The Px-FIFO is a 256-byte buffer for posted writes from the PCI bus to the QBus. The Px-FIFO can accept data from a PCI master while writing data to a QBus slave (see "Posted Writes" on page 78).

The Pr-FIFO is a separate 256-byte buffer for read data from the QBus (see "Prefetched Read Transactions" on page 80).

## 4.2.3 QBus Master Module

The QBus Master Module is a non-multiplexed 32-bit address, 32-bit data interface. This module can be treated as a 32-bit, 16-bit, or 8-bit interface by programming the DSIZE field of the PCI Target Image (see Table 17 on page 66).

The QBus Master Module can generate MC68360 (QUICC), MPC860 (PowerQUICC), or M68040 cycles depending on the QBus Master mode selected at reset. This reset option is determined jointly by the value of BDIP\_ and SIZ[1] at reset. Table 15 presents the QBus Master mode options. For completeness, this table also includes the QBus Slave Module options. The Master/Slave mode (MSTSLV) field in the MISC\_CTL register indicates the Master and Slave modes of the QBus (see Table 127 on page 280). The connections required for interfacing the QSpan II to an MC68360, MPC860, and/or M68040 are given in Appendix C: "Typical Applications" on page 365.



The QBus Master Module supports bursts reads and burst writes in MPC860 mode only.

| Reset sampling |        |             |                          |
|----------------|--------|-------------|--------------------------|
| BDIP_          | SIZ[1] | Master Mode | Slave Modes <sup>a</sup> |
| 0              | 0      | MC68360     | MC68360 and<br>M68040    |
| 0              | 1      | MC68360     | MC68360 and<br>MPC860    |
| 1              | 0      | M68040      | MC68360 and<br>M68040    |
| 1              | 1      | MPC860      | MC68360 and<br>MPC860    |

a. This column is included because the Master mode options can restrict which slave option that can be used: the M68040 Master mode is incompatible with the MPC860 Slave mode.

#### 4.2.3.1 QBus Data Parity Generation and Detection

The QBus Master Module supports the generation and detection of QBus data parity. The use of QBus data parity is optional. The data parity is valid on the same clock cycle as the QBus data. QSpan II supports Odd and Even parity, and is controlled by the QBus Parity Encoding (QBUS\_PAR) bit the in MISC\_CTL2 register (see Table 130 on page 284). The default is Even parity, which is the same as the PCI bus. The detection of a QBus data parity error does not affect the operation of the QSpan II. PCI bus parity generation and detection is independent of QBus data parity generation and detection.

Four pins are used for the QBus Data Parity signals: DP[3:0]. When parity is set to Even, the number of ones on the QBus Data lines (D[7:0]) and DP[0] equal an even number. Similarly, for Odd parity, the number of ones on D[7:0] and DP[0] equal an odd number.

- DP[0] contains the parity for Data lines D[7:0]
- DP[1] contains the parity for Data lines D[15:8]
- DP[2] contains the parity for Data lines D[23:16]
- DP[3] contains the parity for Data lines D[31:24]

The QBus Master Module generates the data parity when it completes a master write cycle. If it detects a parity error during a master read cycle, it sets the QBus Data Parity Error Status (QDPE\_S) bit in the INT\_STAT register (see Table 119 on page 266). QSpan II can generate an external interrupt (INT# or QINT\_) depending on the settings of the QDPE\_EN bit in the INT\_EN register, and the QDPE\_DIR bit in the INT\_DIR register (see Table 121 on page 272). Writing a 1 to the QDPE\_S bit in the INT\_STAT register negates the interrupt and clears the status bit (see Table 119 on page 266).

QSpan II only checks data parity on valid data. If a single byte transfer is completed on the QBus, only the valid byte on the data bus is checked; for example, D[31:24].

# 4.3 Channel Description

The operation of the PCI Target Channel is described in the following sections by tracing the path of a transaction from the PCI bus to the QBus. This is completed by dividing a transaction into the following components:

- Address Phase: This section describes how PCI bus accesses are decoded and how address information from the PCI bus is passed through to the QBus.
- **Data Phase**: This section describes endian mapping and byte-lane translation through the PCI Target Channel.
- **QBus Arbitration and Sampling**: This section describes QBus arbitration.
- **Terminations**: This section explains how terminations from the QBus are communicated back to the master on the PCI bus. It describes how the PCI Target Module handles different terminations (for example, retries or target-aborts). This section also explains the conditions that drive the terminations the QSpan II issues as a PCI target, and error logging mechanisms for posted writes.

# 4.4 Address Phase

# 4.4.1 Transaction Decoding

All decoding by the PCI Target Module is based on the address and command information produced by a PCI bus master. The PCI Target Module claims a cycle if there is an address driven on the PCI bus that matches an image programmed into the PCI Target Image registers. The parameters of a Target Image must not overlap with the 4 Kbytes of QSpan II Register Space or the other target image. The parameters for register accesses are discussed in "Register Access from the PCI Bus" on page 111.)

The type of cycle generated on the QBus is determined by the Target Image selected and C/BE[3:0]. A Target Image is a set of parameters that determines what addresses are decoded on the PCI bus and how cycles are translated from the PCI bus to the QBus. Two Target Images of equal capability are provided so that PCI Masters can quickly access different QBus devices, or the same device in different ways without having to reconfigure QSpan II registers. The two Target Images are independent from one another.

For example, one Target Image can be set-up to access 1 Mbyte of 16-bit SRAM on the QBus using delayed writes, while the other can access 64 Mbytes of 32-bit SDRAM on the QBus with posted writes. PCI Masters do not need to reconfigure QSpan II registers to access either of these devices. For a third type of access, it would be necessary to share one of the Target Images.

The following tables summarize the PCI Target Image control and address fields.

| Field                                                                                        | Description                        | Image     | Register                 | See                                                   |
|----------------------------------------------------------------------------------------------|------------------------------------|-----------|--------------------------|-------------------------------------------------------|
| Base Address<br>(BA[31:16])                                                                  | Address lines compared in decoding | 0         | PCI_BST0 or<br>PBTI0_ADD | Table 75 on<br>page 214 or<br>Table 90 on<br>page 230 |
|                                                                                              |                                    | 1         | PCI_BST1 or<br>PBTI1_ADD | Table 77 on<br>page 216 or<br>Table 93 on<br>page 234 |
| Block Size<br>(BS[3:0]) Determines the number of AD lines<br>that are examined when decoding | 0                                  | PBTI0_CTL | Table 89 on page 228     |                                                       |
|                                                                                              | accesses from the PCI bus.         | 1         | PBTI1_CTL                | Table 92 on<br>page 232                               |

| Field                              | Description                                                    | Image | Register                 | See                                                   |
|------------------------------------|----------------------------------------------------------------|-------|--------------------------|-------------------------------------------------------|
| PCI Address Space<br>(PAS)         | Memory space or I/O space                                      | 0     | PCI_BST0 or<br>PBTI0_CTL | Table 75 on<br>page 214 or<br>Table 89 on<br>page 228 |
|                                    |                                                                | 1     | PCI_BST1 or<br>PBTI1_CTL | Table 77 on<br>page 216 or<br>Table 92 on<br>page 232 |
| Translation Address<br>(TA[31:16]) | Address bits that are substituted to generate the QBus address | 0     | PBTI0_ADD                | Table 90 on<br>page 230                               |
|                                    |                                                                | 1     | PBTI1_ADD                | Table 93 on<br>page 234                               |

Table 16: Address Fields for PCI Target Image (Continued)

## Table 17: Control Fields for PCI Target Image

| Field                          | Description                                                 | Image | Register  | See                     |
|--------------------------------|-------------------------------------------------------------|-------|-----------|-------------------------|
| Image Enable (EN)              | Enable bit                                                  |       | PBTI0_CTL | Table 89 on<br>page 228 |
|                                |                                                             | 1     | PBTI1_CTL | Table 92 on<br>page 232 |
| Posted Write Enable<br>(PWEN)  |                                                             |       | PBTI0_CTL | Table 89 on<br>page 228 |
|                                |                                                             |       | PBTI1_CTL | Table 92 on<br>page 232 |
| Transaction Code<br>(TC[3:0])  | Transaction code generated on the QBus                      | 0     | PBTI0_CTL | Table 89 on<br>page 228 |
|                                |                                                             | 1     | PBTI1_CTL | Table 92 on<br>page 232 |
| Port Size (DSIZE)              | QBus destination port size                                  | 0     | PBTI0_CTL | Table 89 on<br>page 228 |
|                                |                                                             | 1     | PBTI1_CTL | Table 92 on<br>page 232 |
| Prefetch Read Enable<br>(PREN) | Determines whether the QSpan II prefetches data on the QBus | 0     | PBTI0_CTL | Table 89 on<br>page 228 |
|                                |                                                             | 1     | PBTI1_CTL | Table 92 on<br>page 232 |

| Field                                                        | Description                                                                                                          | Image         | Register  | See                      |
|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------------|-----------|--------------------------|
| Burst Write Enable<br>(BRSTWREN)                             | Determines whether the QSpan II burst writes data on the QBus                                                        | 0             | PBTI0_CTL | Table 89 on<br>page 228  |
|                                                              |                                                                                                                      | 1             | PBTI1_CTL | Table 92 on<br>page 232  |
| Invert Endianness<br>(INVEND)                                | Determines whether the QSpan II<br>inverts the endian setting of the                                                 | 0             | PBTI0_CTL | Table 89 on<br>page 228  |
|                                                              | QB_BOC bit in the MISC_CTL register                                                                                  | 1             | PBTI1_CTL | Table 92 on<br>page 232  |
| Prefetch Count<br>(PRCNT[5:0])                               | Determines the amount of data the QSpan II prefetches on the QBus.                                                   | 0 and/or<br>1 | MISC_CTL  | Table 127 on page 280    |
| PCI Target Channel<br>Prefetch is<br>image-based<br>(PTP_IB) | Determines whether image-based prefetching is enabled                                                                | 1             | MISC_CTL2 | Table 130 on<br>page 284 |
| Prefetch Count<br>(PR_CNT2[5:0])                             | Determines the amount of data that<br>the QSpan II prefetches on the<br>QBus for accesses to Image 1, if<br>PTP_IB=1 | 1             | MISC_CTL2 | Table 130 on<br>page 284 |
| QBus Burst 4 Data<br>Phases (BURST_4)                        | Determines whether the QBus<br>bursts four data phases, versus two<br>or three data phases                           | 0 and 1       | MISC_CTL2 | Table 130 on page 284    |
| QBus Prefetch Single<br>Dataphase (PR_SING)                  | Determines whether the QSpan II<br>will generate single cycles to<br>prefetch data as an MPC860<br>master            | 0 and 1       | MISC_CTL2 | Table 130 on<br>page 284 |
| Keep Bus Busy for<br>Back-to-back cycles<br>(KEEP_BB)        | Determines whether Bus Busy is<br>asserted for multiple cycles on the<br>QBus                                        | 0 and 1       | MISC_CTL2 | Table 130 on page 284    |

Table 17: Control Fields for PCI Target Image (Continued)



PCI Target Images can be enabled or disabled by using the image enable bit. Disabling both PCI Target Images disables the PCI Target Channel.



For more information about register settings that affect the PCI Target Channel's operation, see the Miscellaneous Control registers — MISC\_CTL (see Table 127 on page 280) and MISC\_CTL2 (see Table 130 on page 284).

A PCI Target Image occupies a range of addresses within PCI Memory or I/O space. The PCI Address Space bit determines whether the Target Image lies in PCI Memory or I/O space. The range of addresses is specified by the base address field and the block size field. Up to 2 Gbytes of PCI memory per image can reside on the QBus.

There are constraints on the possible values of the block size and the base address. The block size must be one of the 16 block sizes listed in Table 18 on page 70. The base address must be aligned to a combination of the upper address lines between AD31 and AD16. The base address must be a multiple of the block size. For example, a 128-Mbyte image must be aligned to a 128-Mbyte boundary.

Address decoding is performed by decoding the most significant address lines as a function of the block size. For a 128-Mbyte PCI Target Image, the PCI Target Module only needs to decode the top five PCI address lines to know whether this image has been accessed. For a 64 Kbyte image, the PCI Target Module needs to decode the top 16 PCI address lines.

When one of its PCI Target Images is accessed, the QSpan II responds with DEVSEL# within two clocks of FRAME#. This makes the QSpan II a medium-speed device, as indicated by the Device Select (DEVSEL) field in the PCI\_CS register (see Table 70 on page 207).

As a PCI target, the QSpan II responds to the following command types:

- I/O Read
- I/O Write
- Memory Read
- Memory Write
- Configuration Type 0 Read
- Configuration Type 0 Write
- Memory Read Multiple (aliased to Memory Read)
- Memory Read Line (aliased to Memory Read)
- Memory Write and Invalidate (aliased to Memory Write)

### 4.4.2 Address Translation

Figure 6 illustrates the general implementation of address translation in the QSpan II PCI Target Channel.



#### Figure 6: Address Generator for PCI Target Channel Transfers

The Address Generator produces the QBus address using three inputs: the address generated by the PCI master (AD[31:0]), the block size of the PCI Target Image (BS field of the Target Image), and the translation address of the PCI Target Image (TA). The translation address is a 16-bit number whose upper bits specify the location of the Target Image on the QBus. If the translation address is programmed with the same value as that of the base address, then the PCI address is not translated but applied directly to the QBus transaction.

The most significant bits of the translation address are used by the Address Generator as determined by the programming of the image's block size. The number of these bits used depends on the programming of the BS bit. The correlation between block size and the number of most significant TA bits used in generating the QBus address is shown in Table 18. With a 64 Kbyte block size, the Address Generator copies the entire translation address into the QBus address, but only copies the lower 16 bits from the PCI address signal (for example, the Address Generator translates AD[31:16]). With a 2 Gbyte block size, the Address Generator copies all but bit 31 from the PCI address signal (for example, the Address Generator translates AD[31] only), and uses the top translation address bit as bit 31 of the QBus address.



This manual adopts the convention that the most significant bit is always the largest number. MPC860 designers must ensure that they connect their pins accordingly. For example, pin A[31] on the QSpan II connects to pin A[31] on the MC68360 bus, but connects to pin A[0] on the MPC860 bus. This applies to all MPC860 buses (D[31:0], AT[3:0], TSIZ[1:0]) not only the address bus.



The QSpan II's chip select inputs (CSREG\_, CSPCI\_) must not be asserted when the QSpan II is initiating a cycle on the QBus.

| BS in PBTI0_CTL or<br>PBTI1_CTL | Block Size | PCI Address Bits<br>Translated | Translation Address Bits<br>Copied |
|---------------------------------|------------|--------------------------------|------------------------------------|
| 0000                            | 64 Kbytes  | AD31–AD16                      | TA31–TA16                          |
| 0001                            | 128 Kbytes | AD31–AD17                      | TA31–TA17                          |
| 0010                            | 256 Kbytes | AD31–AD18                      | TA31–TA18                          |
| 0011                            | 512 Kbytes | AD31–AD19                      | TA31–TA19                          |
| 0100                            | 1 Mbyte    | AD31–AD20                      | TA31–TA20                          |
| 0101                            | 2 Mbytes   | AD31–AD21                      | TA31–TA21                          |
| 0110                            | 4 Mbytes   | AD31–AD22                      | TA31-TA22                          |
| 0111                            | 8 Mbytes   | AD31–AD23                      | TA31-TA23                          |
| 1000                            | 16 Mbytes  | AD31–AD24                      | TA31-TA24                          |
| 1001                            | 32 Mbytes  | AD31–AD25                      | TA31-TA25                          |
| 1010                            | 64 Mbytes  | AD31–AD26                      | TA31-TA26                          |
| 1011                            | 128 Mbytes | AD31–AD27                      | TA31-TA27                          |
| 1100                            | 256 Mbytes | AD31–AD28                      | TA31–TA28                          |
| 1101                            | 512 Mbytes | AD31–AD29                      | TA31–TA29                          |
| 1110                            | 1 Gbyte    | AD31–AD30                      | TA31-TA30                          |
| 1111                            | 2 Gbytes   | AD31                           | TA31                               |

Table 18: Translation of PCI Bus Address to QBus Address

## 4.4.3 Transaction Codes on the QBus

The address supplied on the A[31:0] lines on the QBus is the result of the address translation described in the previous section. QSpan II also allows the user flexibly to generate various encodings on the QSpan II's TC[3:0] lines. The TC[3:0] lines can be connected to the FC[3:0] lines of the MC68360 bus, the AT[0:3] lines of the MPC860 bus, and a subset of the TT[1:0] and TM[2:0] lines of the M68040 bus. QSpan II copies the values from the TC field of the PCI Target Image of the current transaction to the TC[3:0] lines of the QBus. This gives the user additional control over the address information provided on the QBus.

## 4.4.4 PCI BIOS Memory Allocation

The PCI Target Image registers used by the QSpan II to decode PCI accesses work differently depending on the EEPROM implementation and the use of the PCI Access Disabled (PCI\_DIS) bit in MISC\_CTL2 (see Table 130 on page 284). There are three possible cases:

- 1. Case 1: The PCI\_BSTx register is enabled by the EEPROM (see Table 75 on page 214 and Table 77 on page 216). For PCI Target Image 0, this means that bit 5 of byte 7 in the EEPROM is 1. For PCI Target Image 1, this means that bit 7 of byte 8 in the EEPROM is 1 (see Table 44 on page 131).
- 2. Case 2: The PCI\_BSTx register is not enabled (see Table 75 on page 214 and Table 77 on page 216). For PCI Target Image 0, this means that bit 5 of byte 7 in the EEPROM is 0. For PCI Target Image 1, this means that bit 7 of byte 8 in the EEPROM is 0 (see Table 44 on page 131).
- 3. Case 3: By setting the power-up option, PCI\_DIS, the QSpan II will retry all PCI accesses, and the QBus Host can program the registers and then clear the PCI\_DIS bit in MISC\_CTL2. Once cleared, this enables the PCI Host to read the Configuration registers.

#### 4.4.4.1 Block Size and PCI Address Space

If PCI address programming from the EEPROM is enabled (Case 1), the Block Size and PCI Address Space (PAS) fields are set from the EEPROM, and they are read only. (The PAS bit can be read from either the PCI\_BSTx or the PBTIx\_CTL register.)

If the reset state of the Block Size and Address Space fields is zero (Case 2), these fields are only writable from the PBTIx\_CTL registers.

#### 4.4.4.2 Base Address

If PCI address information is loaded from an EEPROM (Case 1), the base address of the Target Image can only be set through the PCI\_BSTx register (for example, BA[31:16] of PCI\_BST0 or PCI\_BST1). The base address can be read from either the PCI\_BSTx register or the PBTIx\_ADD register.

The PCI BIOS uses the PCI\_BSTx registers to determine the address allocation for the QSpan II-based board. It does this by writing all 1s to the BA field of the PCI\_BSTx register and then reading back from the same location. The number of bits in the BA field of the PCI\_BSTx register that are writable is determined by the Target Image's block size (BS[3:0] field in the PBTIx\_CTL register).

For example, if the PCI Target Image is programmed to a block size of 128 Mbytes, then the BS field in the PBTIx\_CTL register has been programmed to all 1s (see Table 18 on page 70). This means that only the most significant five bits of the BA field of PCI\_BSTx register are writable. When the BIOS reads back from the BA field in the PCI\_BSTx register, the read returns only the most significant five bits of BA as 1, indicating a 128 Mbyte image size.

When PCI address information is not loaded from an EEPROM or initiated by the processor on the QBus; the base address can only be set through the PBTIx\_ADD registers. The PBTIx\_ADD registers do not support the image-sizing functionality described in the previous paragraph.

# 4.5 Data Phase

## 4.5.1 Endian Mapping

This section describes how the QSpan II translates cycles from the PCI bus to the QBus.



The PCI bus and Motorola processors differ in the way they order and address bytes. These differences are explained in Appendix E: "Endian Mapping" on page 395.

The PCI bus is always a Little-Endian environment. The QBus can be configured as Little-Endian or Big-Endian, depending on the value of the QBus Byte Ordering Control bit (QB\_BOC) in the MISC\_CTL register (see Table 127 on page 280). The default mode for the QBus is Big-Endian. This global ordering can be inverted on an image-by-image basis by programming the INVEND bit of the PBTIx\_CTL register. QSpan II translates byte-lane ordering when the QBus is Big-Endian, while preserving the addressing of bytes.

When the QBus is Little-Endian — according to QB\_BOC and INVEND — the QSpan II preserves byte-lane ordering, while translating the addressing of bytes. (The QB\_BOC bit affects transactions in all channels whereas the INVEND bit only affects the PCI Target Channel.)

PCI bus transactions have the following characteristics:

- They can be translated as 32-bit, 16-bit, or 8-bit on the QBus.
- The data width of the QBus transaction is controlled by the DSIZE field of the PCI bus Target Image Control register.
  - With 16-bit peripherals, they can be 8-bits or 16-bits wide.
  - With 8-bit peripherals, they can be 8-bits wide.
- Packing and unpacking of data performed by the QBus Master Module is a function of byte-enables (BE[3:0]) and the port size.

#### 4.5.1.1 Write Cycle Mapping for PCI Target Channel

This section describes write cycle mapping as a function of port size.



All tri-byte, misaligned and non-contiguous byte write operations on the PCI bus are performed as a series of 8-bit write operations on the QBus.

#### 32-Bit QBus Port

Tables 19 and 20 describe write transfers of various sizes to 32-bit peripherals on the QBus.

The following table describes mapping of 8, 16, and 32-bit write transfers through the PCI Target Channel with the QBus set to Little-Endian. (The byte lane ordering is preserved in Little-Endian mode.)

|               | PCI bus  |             | QBus     |        |             |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 00     | B3 xx xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 01     | B2 B2 xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 10     | B1 xx B1 xx |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 11     | B0 B0 xx B0 |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 00     | B3 B2 xx xx |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 10     | B1 B0 B1 B0 |
| 32 bits       | 0000     | B3 B2 B1 B0 | 00       | 00     | B3 B2 B1 B0 |

 Table 19: Little-Endian PCI Target Write Cycle Mapping — 32-Bit QBus Port

The following table describes mapping of 8, 16, and 32-bit write transfers through the PCI Target Channel in Big-Endian mode to 32-bit QBus peripherals. (The addressing of bytes is preserved in Big-Endian mode.)

Table 20: Big-Endian PCI Target Write Cycle Mapping — 32-Bit QBus Port

|               | PCI bus  |             | QBus     |        | s           |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 00     | B0 xx xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 01     | B1 B1 xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 10     | B2 xx B2 xx |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 11     | B3 B3 xx B3 |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 00     | B0 B1 xx xx |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 10     | B2 B3 B2 B3 |
| 32 bits       | 0000     | B3 B2 B1 B0 | 00       | 00     | B0 B1 B2 B3 |

#### 16-Bit QBus Port

16-bit QBus port transfers are explained in terms of the 32-bit transfers described in Tables 19 and 20. The first of these operations involves unpacking data.

- A 32-bit write operation to a QBus peripheral with a 16-bit QBus port size is performed as two 16-bit write operations to a 32-bit peripheral.
- A 16-bit write operation to a QBus peripheral with a 16-bit QBus port size is performed as a 16-bit write operation to a 32-bit peripheral.
- An 8-bit write operation to a QBus peripheral with a 16-bit QBus port size is performed as an 8-bit write operation to a 32-bit peripheral.

#### 8-bit QBus port

8-bit QBus port transfers are explained in terms of the 32-bit transfers described in Tables 19 and 20. The first two operations involve unpacking data.

- A 32-bit write operation to a QBus peripheral with an 8-bit QBus port size is performed as four 8-bit write operations to a 32-bit peripheral.
- A 16-bit write operation to a QBus peripheral with an 8-bit QBus port size is performed as two 8-bit write operations to a 32-bit peripheral.
- An 8-bit write operation to a QBus peripheral with an 8-bit QBus port size is performed as an 8-bit write operation to a 32-bit peripheral.
- All tri-byte, misaligned and non-contiguous byte write operations are performed as a series of 8-bit write operations to a 32-bit peripheral.

#### 4.5.1.2 Read Cycle Mapping for PCI Target Channel

This section describes cycle mapping and packing of data by the QBus Master Module.

#### 32-bit QBus Port

Tables 21 and 22 describe transfers of various sizes to 32-bit peripherals.

The following table describes mapping of 8-bit, 16-bit, and 32-bit read transfers through the PCI Target Channel in Little-Endian mode to 32-bit QBus peripherals. The byte-lane ordering is preserved in Little-Endian mode.

|               | PCI bus  |             | QBus     |        | S           |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 00     | B3 xx xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 01     | xx B2 xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 10     | xx xx B1 xx |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 11     | xx xx xx B0 |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 00     | B3 B2 xx xx |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 10     | xx xx B1 B0 |
| 32 bits       | 0000     | B3 B2 B1 B0 | 00       | 00     | B3 B2 B1 B0 |

 Table 21: Little-Endian PCI Target Read Cycle Mapping — 32-Bit QBus Port

The following table describes mapping of 8-bit, 16-bit, and 32-bit read transfers through the PCI Target Channel in Big-Endian mode from 32-bit QBus peripherals. The addressing of bytes is preserved in Big-Endian mode.

|               | PCI bus  |             | QBus     |        | s           |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 00     | B0 xx xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 01     | xx B1 xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 10     | xx xx B2 xx |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 11     | xx xx xx B3 |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 00     | B0 B1 xx xx |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 10     | xx xx B2 B3 |
| 32 bits       | 0000     | B3 B2 B1 B0 | 00       | 00     | B0 B1 B2 B3 |

Table 22: Big-Endian PCI Target Read Cycle Mapping — 32-Bit QBus Port



All tri-byte, misaligned and non-contiguous byte delayed read operations from a peripheral with a 32-bit QBus port size are performed as a series of 8-bit read operations would be from a 32-bit peripheral.

#### 16-Bit QBus Port

Tables 23 and 24 describe 8-bit and 16-bit read transfers from 16-bit QBus peripherals.

The following table describes mapping of 8-bit and 16-bit read transfers through the PCI Target Channel in Little-Endian mode from 16-bit QBus peripherals. The byte lane ordering is preserved in Little-Endian mode.

|               | PCI bus  |             | QBus     |        |             |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 00     | B3 xx xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 01     | xx B2 xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 10     | B1 xx xx xx |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 11     | xx B0 xx xx |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 00     | B3 B2 xx xx |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 10     | B1 B0 xx xx |

 Table 23: Little-Endian PCI Target Read Cycle Mapping — 16-Bit QBus Port

The following table describes mapping of 8-bit and 16-bit read transfers through the PCI Target Channel in Big-Endian mode from 16-bit QBus peripherals. The addressing of bytes is preserved in Big-Endian mode.

 Table 24: Big-Endian PCI Target Read Cycle Mapping — 16-Bit QBus Port

|               | PCI bus  |             | QBus     |        |             |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 00     | B0 xx xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 01     | xx B1 xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 10     | B2 xx xx xx |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 11     | xx B3 xx xx |
| 16 bits       | 1100     | xx xx B1 B0 | 10       | 00     | B0 B1 xx xx |
| 16 bits       | 0011     | B3 B2 xx xx | 10       | 10     | B2 B3 xx xx |



All tri-byte, misaligned and non-contiguous byte read operations from a peripheral with a 16-bit QBus port size are performed like a series of 8-bit read operations from a 16-bit peripheral.

A 32-bit read operation from a peripheral with a 16-bit QBus port size is performed as two 16-bit read operations from a peripheral with a 16-bit QBus port size.

#### 8-Bit QBus Port

The following table describes mapping of 8-bit read transfers through the PCI Target Channel in Little-Endian mode from 8-bit QBus peripherals. The byte-lane ordering is preserved in Little-Endian mode.

|               | PCI bus  |             |          | S      |             |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 00     | B3 xx xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 01     | B2 xx xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 10     | B1 xx xx xx |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 11     | B0 xx xx xx |

 Table 25: Little-Endian PCI Target Read Cycle Mapping — 8-Bit QBus Port

The following table describes mapping of 8-bit read transfers through the PCI Target Channel in Big-Endian mode from 8-bit QBus peripherals. The addressing of bytes is preserved in Big-Endian mode.

 Table 26: Big-Endian PCI Target Read Cycle Mapping — 8-Bit QBus Port

|               | PCI bus  |             | QBus     |        |             |
|---------------|----------|-------------|----------|--------|-------------|
| Transfer size | BE[3:0]# | D[31:0]     | SIZ[1:0] | A[1:0] | D[31:0]     |
| 8 bits        | 1110     | xx xx xx B0 | 01       | 00     | B0 xx xx xx |
| 8 bits        | 1101     | xx xx B1 xx | 01       | 01     | B1 xx xx xx |
| 8 bits        | 1011     | xx B2 xx xx | 01       | 10     | B2 xx xx xx |
| 8 bits        | 0111     | B3 xx xx xx | 01       | 11     | B3 xx xx xx |



All tri-byte, misaligned and non-contiguous byte read operations from a peripheral with an 8-bit QBus port size are performed like a series of 8-bit read operations from an 8-bit peripheral.

A 32-bit read operation from a peripheral with an 8-bit QBus port size is performed as four 8-bit read operations from a peripheral with an 8-bit QBus port size.

A 16-bit read operation from a peripheral with an 8-bit QBus port size is performed as two 8-bit read operations from a peripheral with an 8-bit QBus port size.

## 4.5.2 Data Path

This section explains how data flows between the PCI bus and the QBus through the PCI Target Channel.

#### 4.5.2.1 Posted Writes

If the Posted Write Enable (PWEN) bit in the Target Image is 1, writes to the PCI Target Module are posted into the Px-FIFO (see "Transaction Decoding" on page 65). If the bit is cleared, writes are treated as delayed transactions. The default setting for the PWEN bit is 0, which is delayed transactions.

Write transfers are stored in the Px-FIFO (see "Px-FIFO and Pr-FIFO" on page 63). Address and data are stored as separate entries in the Px-FIFO. For example, a single data transaction is stored as two entries in the Px-FIFO — one for the translated address and one for the data (see "Address Translation" on page 68). Any reprogramming of PCI Target Image attributes will only be reflected in Px-FIFO entries queued after the reprogramming. Transactions queued before the reprogramming are delivered to the PCI bus with the PCI Target Image attributes that were in use before the reprogramming.

QSpan II never packs data in the Px-FIFO. For example, two non-burst 16-bit data beats are not packed as a single 32-bit data entry but as four separate entries in the Px-FIFO (32-bit address, 16-bit data, 32-bit address, 16-bit data).

#### Acceptance of Burst Writes by the PCI Target Module

The PCI Target Module can accept burst write transactions from PCI bus Masters. This section explains the following about PCI burst writes: when PCI bursts are accepted, how they are stored, and how data is transferred on the QBus.

QSpan II will not accept a PCI burst write under the following conditions:

- 1. If posted writes for the selected Target Image are disabled (see Table 84 on page 223 or Table 92 on page 232), then each successive data phase is processed as a delayed single write. When the write completes on the QBus, the QSpan II issues a Target-Completion the next time the transfer is attempted by the external PCI master. Therefore, for each data phase in the burst, the external PCI master will see a series of retries and then one Target-Completion.
- 2. If the Px-FIFO fills while a burst is in progress, the PCI Target Module generates a Target-Disconnect.
- 3. If there are fewer data entries available in the Px-FIFO than specified by the cacheline CLINE[1:0] field of the PCI\_MISC0 register and a PCI master attempts a new burst to the QSpan II, the external PCI master is retried.
- 4. The PCI Target Module only accepts linear burst address incrementing. Any transfers requiring other addressing modes are disconnected after the first data phase.

For more information, see "Terminations driven by the PCI Target Module" on page 86.

The Px-FIFO stores the address and data entries of PCI bursts. For example, if a burst of four is received by the PCI Target Module, the QSpan II stores the burst as five new entries of the following types: address, data, data, data, data. Because the QBus Master Module can write data at the same time as the PCI Target Module accepts data, the Px-FIFO might not contain these five entries by the end of the burst — some of the data may already have been written to the QBus before the burst completes on the PCI bus.

#### Bursting on the QBus

If the Burst Write Enable (BRSTWREN) bit of the selected PCI Target Image is 1, the QSpan II will burst data from the Px-FIFO onto the QBus. When enabled, all byte-lanes are assumed to be active for data written to the image. Generation of burst writes is only supported while in MPC860 Master mode (see Table 15 on page 63).

Burst length on the QBus is controlled by the BDIP\_ signal: by negating BDIP\_ the QSpan II signals the QBus slave that the current data beat is the second last beat of the transaction. This allows the QSpan II to perform bursts of two, three, or four data beats. QSpan II can be programmed to generate a burst of four data beats to be compatible with the MPC860's memory controller (UPM). This can be completed by setting the QBus Burst Four Dataphases (BURST\_4) bit in the MISC\_CTL2 register (see Table 130 on page 284).

If the write transfer is not cacheline aligned, then the QSpan II will perform single writes up until a cacheline boundary. Similarly, if a PCI write transaction completes, the QSpan II will perform single write cycles for the entries that remained in the Px-FIFO at a non-cacheline aligned address.



The KEEP\_BB bit in the MISC\_CTL2 register (see Table 130 on page 284) is not supported for DMA operation. As such, do not set this bit when the QSpan II DMA channel is used with the PowerQUICC memory controller (UPM).

## 4.5.2.2 Delayed Writes

If a write is attempted when posted writes are disabled for the PCI Target Image (PWEN is set to 0), or the address space bit is set to 1 (for I/O transfers), then write cycles are treated as delayed transactions. During a delayed write transaction the PCI master is retried until the transaction completes on the QBus. If the PCI transaction completes normally on the QBus, then when the PCI bus master retries the same transaction — qualified by the latched address and command information — the original PCI master is given a normal cycle termination. If the QBus transaction does not complete normally, then the appropriate termination is communicated back to the PCI master (see "Terminations" on page 84).

#### 4.5.2.3 Single Read Transactions

When the QSpan II receives a target read request, it latches the address and C/BE# information and retries the PCI master. QSpan II then becomes QBus master and initiates a read on the QBus. The external PCI master is retried until the read is completed on the QBus. When the external PCI master retries the same transaction — qualified by the latched information — it is provided with the data and the transaction terminates normally on the PCI bus. If the QBus transaction does not complete normally, then the appropriate termination is communicated back to the PCI bus master (see "Terminations" on page 84).

#### 4.5.2.4 Prefetched Read Transactions

QSpan II supports different prefetch data amounts based on the PCI target image accessed during a read of the PCI Target Channel. QSpan II initiates a prefetch read transaction on the QBus if the following conditions are met:

- 1. The PREN bit in the selected Target Image must be 1.
- 2. The Prefetch Read Byte Count (PRCNT[5:0]) bit in the MISC\_CTLx register must be programmed. The PRCNT2[5:0] and PTP\_IB bits in the MISC\_CTL2 register can also be programmed to enable image-based prefetching (see Table 130 on page 284).
- 3. The PCI master must keep FRAME# asserted when IRDY# is asserted (for example, PCI burst read cycle).

QSpan II will read the amount of data specified in the appropriate PRCNTx[5:0] field of the MISC\_CTLx register (see Table 127 on page 280 and Table 130 on page 284). QSpan II retries the PCI master until read data is available in the Pr-FIFO.

If the PREN bit is cleared, which is the default setting, the transfer is processed as a delayed single read (see "Single Read Transactions" on page 80). QSpan II will prefetch whether it is in MC68360, MPC860, or M68040 Master mode (see "QBus Master Module" on page 63). However, it will only prefetch with burst reads on the QBus when it is MPC860 Master mode. If the external QBus slave does not support bursting, setting the QBus Prefetch Signal Dataphase (PR\_SING) bit will cause the QSpan II to prefetch in MPC860 mode using only single reads.

If a read-request is not cacheline aligned, then the QSpan II will perform single beat transactions on the MPC860 bus until it reaches a cacheline boundary. The QBus Master Module, as MPC860 master, only performs burst reads at cacheline boundaries. This feature makes QSpan II burst reads compatible with the MPC860 UPM. The module requests the bus for a burst when there is enough room in the Pr-FIFO for an entire cacheline of data.

The PR\_SING bit in the MISC\_CTL2 register supports QSpan II prefetching as single or burst cycles in the PCI Target Channel. The PR\_SING bit should be set to a 1 if the QBus memory does not support bursting when the QSpan II is powered up as an MPC860 master (see Table 130 on page 284).

## 4.5.3 Parity Monitoring by PCI Target Module

The PCI Target Module monitors parity during the address phase of transactions and during the data phase of write transfers. For example, the QSpan II compares the PAR signal with the parity of AD[31:0] and C/BE[3:0]. The PAR signal provides even parity for C/BE#[3:0] and AD[31:0]. QSpan II drives PAR when it provides data as a target during a read.

If the PCI Target Module detects an address or data parity error during a write, it sets the Detected Parity Error (D\_PE) bit in the PCI\_CS register (see Table 70 on page 207) regardless of the PERESP setting in the PCI\_CS register. For more information about parity errors and the D\_PE bit, see "Parity Monitoring by PCI Master Module" on page 56. If the QSpan II signals SERR#, it sets the S\_SERR bit in the PCI\_CS register.

Address parity errors are reported if Parity Error Response (PERESP) and SERR# Enable (SERR\_EN) are set in the PCI\_CS register (see Table 70 on page 207). Address parity errors are reported by the QSpan II by asserting the SERR# signal and setting the S\_SERR (signaled SERR#) bit in the PCI\_CS register. Assertion of SERR# can be disabled by clearing the SERR\_EN bit in the PCI\_CS register. An interrupt may be generated, and regardless of whether assertion of SERR# is enabled or not, the QSpan II does not respond to the access with DEVSEL#. Normally, the master of the transaction terminates the cycle with a Master-Abort.

The PERESP bit in the PCI\_CS register affects how the QSpan II responds to PCI parity errors. If the PERESP bit and the SERR\_EN bit are set, the QSpan II reports address parity errors by asserting SERR# and setting the S\_SERR bit in the PCI\_CS register. If the PERESP bit is set the QSpan II reports data parity errors (during writes) by asserting PERR#.

# 4.6 Reads and PCI Transaction Ordering

PCI Transaction Ordering rules affect the relationship between delayed reads in the PCI Target Channel and posted writes in the PCI Target Channel. These rules also affect the relation between delayed reads in the PCI Target Channel and posted writes in the QBus Slave Channel.

When a read request is latched, the PCI Target Module retries non-register accesses to the PCI Target Module until the read completes on the QBus. Once the read completes on the QBus, the QSpan II ensures that all writes previously posted in the Qx-FIFO complete on the PCI bus before the read data is passed back to the PCI bus master that initiated the read transaction. During the period when the Qx-FIFO is being emptied, attempts to access the QBus Slave Channel are retried (register accesses are not affected).

The following list summarizes the sequence of events:

- 1. The PCI Target Module receives a read request from a PCI master, which it latches.
- 2. The PCI Target Module retries all non-register accesses.
- 3. The PCI Target Channel empties the Px-FIFO.

- 4. The QBus Master Module completes the read on the QBus.
- 5. The QBus Slave Module retries all non-register accesses.
- 6. The Qx-FIFO is emptied.
- 7. The PCI Target Module allows the read to complete on the PCI bus.
- 8. The PCI Target Module allows posted writes to the Px-FIFO, even if the delayed read has not completed.
- 9. The QBus Slave Module allows posted writes to the Qx-FIFO.

Similar principles apply to QBus Slave Channel reads (see "Delayed Reads and PCI Transaction Ordering" on page 55). The IDMA Channel is independent from the PCI transaction ordering rules that affect the QBus Slave Channel and the PCI Target Channel.

## 4.6.1 Transaction Ordering Disable Option

QSpan II has a register option to disable transaction ordering between the PCI Target Channel and the QBus Slave Channel. The No Transaction Ordering (NOTO) bit in MISC\_CTL2 register is used for this purpose (see "MISC\_CTL2 Description" on page 284). When this bit is set, a read in one channel is unaffected by posted writes in the other channel. This feature improves system performance, especially when using the DMA and where strict transaction ordering is not required.

# 4.7 QBus Arbitration and Sampling

The QBus Master Module requests the QBus when there is a read request or when there is a sufficient number of entries in the Px-FIFO (see "Acceptance of Burst Writes by the PCI Target Module" on page 78).

## 4.7.1 MC68360 Bus Arbitration

When the QSpan II requires control of the MC68360 bus, it requests the bus by asserting Bus Request (BR\_). When the QSpan II samples Bus Grant (BG\_) asserted and Bus Grant Acknowledge (BB\_/BGACK\_) negated, the QSpan II asserts BB\_/BGACK\_ and negates BR\_.

The QBus (MC68360) Master Module's default arbitration mode is asynchronous: it double-samples the BG\_ and BB\_/BGACK\_ inputs using the falling and rising edge of QCLK. The default mode of operation can be modified with the QSpan II in order to save one clock cycle during arbitration. To enable synchronous arbitration, set the Synchronous Bus Grant (S\_BG) bit and the Synchronous Bus Grant Acknowledge (S\_BB) bit to 1 in the MISC\_CTL register (see Table 127 on page 280). The Arbitration Synchronous Timing Mode (ASTM) bit in the MC68360 must be set for asynchronous mode of operation by setting the ASTM bit to 0 in the MCR register.

QSpan II can operate synchronously because all timing parameters can be met by the MC68360. However, the MC68360 must be programmed for asynchronous mode in order for the QSpan II to meet the MC68360's input setup requirements. See Appendix B: "Timing" on page 305 for the arbitration timing waveform.



If the MC68360's processing core is disabled (Companion mode, Slave mode) an external arbiter must be implemented to support arbitration between the MC68360 and the QSpan II (for more information, see Appendix C: "Typical Applications" on page 365).

QSpan II can hold onto the QBus for multiple transactions if the KEEP\_BB bit is set in the MISC\_CTL2 register (see Table 130 on page 284). If set, this configuration improves the performance of the PCI Target Channel and the DMA Channel by eliminating the arbitration delay.

## 4.7.2 MPC860 Bus Arbitration

When the QSpan II requires control of the MPC860 bus, it arbitrates for the bus by asserting BR\_. When the QSpan II samples BG\_ asserted and BB\_/BGACK\_ negated, the QSpan II asserts BB\_/BGACK\_ and negates BR\_.



QSpan II asserts BB\_ one clock after BG\_ in accordance with MPC860 arbitration requirements.

The MPC860 Master Module's default arbitration mode is synchronous. This default mode can be overridden by setting S\_BG and S\_BB to 0 in the MISC\_CTL register (see Table 127 on page 280). Note that, except for termination signals with an MC68360, and for arbitration, the QBus is always synchronous. See Appendix B: "Timing" on page 305 for the arbitration timing waveform.

QSpan II can hold onto the QBus for multiple transactions if the KEEP\_BB bit is set in the MISC\_CTL2 register (see Table 130 on page 284). If set, this configuration improves the performance of the PCI Target Channel by eliminating the arbitration delay.



The KEEP\_BB bit in the MISC\_CTL2 register (see Table 130 on page 284) is not supported for DMA operation. As such, do not set this bit when the QSpan II DMA channel is used with the PowerQUICC memory controller (UPM).

## 4.7.3 M68040 Bus Arbitration

When the QSpan II requires control of the M68040 bus, it arbitrates for the bus by asserting BR\_. When the QSpan II samples BG\_ asserted and BB\_/BGACK\_ negated, the QSpan II asserts BB\_/BGACK\_ and negates BR\_.

The M68040 Master Module's default operation is synchronous. This default mode can be overridden by setting S\_BG and S\_BB to 0 in the MISC\_CTL register (see Table 127 on page 280). Note that, except for termination signals with an MC68360 and arbitration, the QBus is always synchronous. See Appendix B: "Timing" on page 305 for the arbitration timing waveform.

QSpan II can hold onto the QBus for multiple transactions if the KEEP\_BB bit is set in the MISC\_CTL2 register (see Table 130 on page 284). If set, this configuration improves the performance of the PCI Target Channel and the DMA Channel by eliminating the arbitration delay.

# 4.8 Terminations

## 4.8.1 QBus Master Module Terminations

This section explains the QBus Master Module's handling of cycle termination for the MC68360, MPC860 and M68040 buses.

## 4.8.2 MC68360 Cycle Terminations

When a transaction is completed, BB\_/BGACK\_ is negated by the QBus Master Module on the rising clock edge and tristated on the next falling clock edge. Termination of MC68360 cycles is described in Table 27. The QBus Master Module samples all of the MC68360 termination signals on the falling edge of QCLK. In contrast, the QBus Master Module samples the MPC860 termination signals on the rising edge of QCLK.

The MC68360 termination inputs to the QBus Master Module can be skewed by as much as one clock period. However, they must meet the required setup and hold time required with respect to the falling edge of QCLK. HALT\_/TRETRY\_ is ignored if asserted alone. In a Normal and Halt condition, the QBus Master Module delays the termination until HALT\_/TRETRY\_ is negated. This feature of the MC68360 allows software to verify the internal state of the MC68360 during an error. During MC68360 Retry terminations the QBus master negates BB\_/BGACK\_, and will re-request the bus (assert BR\_) when HALT\_/TRETRY\_ is negated.

|                                 | DSACK0_, DSACK1_/TA_     |                              | BERR                | BERR_/TEA_           |                          | HALT_/TRETRY_        |  |
|---------------------------------|--------------------------|------------------------------|---------------------|----------------------|--------------------------|----------------------|--|
| Termination<br>Type             | t <sub>o</sub>           | t <sub>1</sub>               | t <sub>0</sub>      | t <sub>1</sub>       | t <sub>0</sub>           | t <sub>1</sub>       |  |
| Normal                          | Asserted                 | Asserted                     | Negated             | Negated              | Negated                  | Don't Care           |  |
| Normal & Halt <sup>a</sup>      | Asserted                 | Asserted                     | Negated             | Negated              | Asserted                 | Asserted             |  |
| Bus Error                       | Don't Care<br>Don't Care | Don't Care<br>Don't Care     | Asserted<br>Negated | Asserted<br>Asserted | Negated<br>Negated       | Negated<br>Negated   |  |
| Retry                           | Don't Care<br>Don't Care | Don't Care<br>Don't Care     | Asserted<br>Negated | Asserted<br>Asserted | Don't Care<br>Don't Care | Asserted<br>Asserted |  |
| t <sub>0</sub> : First sample o | n falling edge o         | of QCLK t <sub>1</sub> : Sec | cond sample or      | n falling edge o     | f QCLK                   |                      |  |

Table 27: MC68360 Cycle Terminations of QBus Master Module

a. QSpan II as QBus master will sample DSACKx 2 QCLK rising edges after HALT negation.

## 4.8.3 MPC860 Cycle Terminations

When MPC860 transfers are completed, BB\_/BGACK\_ is negated by the QBus Master Module on the rising clock edge and tristated on the next falling clock edge to terminate the transaction currently in progress (see Table 28).

#### Table 28: MPC860 Cycle Terminations of QBus Master Module

| Termination Type | DSACK1_/TA_ | BERR_/TEA_ | HALT_/TRETRY_ |
|------------------|-------------|------------|---------------|
| Normal           | Asserted    | Negated    | Don't Care    |
| Bus Error        | Don't Care  | Asserted   | Don't Care    |
| Retry            | Negated     | Negated    | Asserted      |

## 4.8.4 M68040 Cycle Terminations

When M68040 transfers are completed, BB\_/BGACK\_ is negated by the QBus Master Module on the rising clock edge and tristated on the next falling clock edge (see Table 29).

#### Table 29: M68040 Cycle Terminations of QBus Master Module

| Termination Type | DSACK1_/TA_ | BERR_/TEA_ |
|------------------|-------------|------------|
| Normal           | Asserted    | Negated    |
| Bus Error        | Negated     | Asserted   |
| Retry            | Asserted    | Asserted   |

## 4.8.5 Terminations driven by the PCI Target Module

This section lists the terminations generated by the PCI Target Module, and summarizes the conditions under which the various terminations are issued.



Under most conditions, the target is able to source or sink the data requested by the master until the master terminates the transaction. But when the target is unable to complete the request, it can use the STOP# signal to initiate termination of the transaction.

QSpan II PCI Target Module generates the following PCI terminations:

- Target-Disconnect
- Target-Retry
- Target-Abort

#### 4.8.5.1 Target-Disconnect

During a Target-Disconnect, a termination is requested by the target because it is unable to respond within the latency requirements of the *PCI 2.2 Specification*, or it requires a new address phase. This termination is signaled when the target holds TRDY# and STOP# asserted. Target-Disconnect means that the transaction is terminated after data is transferred. Target-Disconnects can be issued by the QSpan II under the following conditions:

- A PCI master attempts to burst to a Target Image whose transfers are set to I/O space. In this case, a target-disconnect is issued after the first data phase.
- A PCI master attempts to burst to a Target Image with posted writes disabled and the current data phase processed as a delayed write has completed on the QBus (see "Acceptance of Burst Writes by the PCI Target Module" on page 78).
- A PCI master has attempted a burst read and the QBus Master Module has completed the single transfer.
- A 128 byte boundary is reached.
- The Px-FIFO fills during a burst write.
- A burst transfer requiring non-linear burst address incrementing is attempted.
- TRDY# is negated for eight PCLKs during a PCI burst read. This is optional (for more information, see "PCI Target Prefetch Disconnect" on page 86).

#### PCI Target Prefetch Disconnect

QSpan II can be programmed to perform a Target-Disconnect while completing prefetch reads in the PCI Target Channel. To enable this feature, set the PCI Target Channel Prefetch Disconnect (PTC\_PD) bit in the MISC\_CTL2 register (see Table 130 on page 284).

A disconnect is issued if the TRDY# signal is negated for eight PCI clock cycles during a target prefetch read transaction. A new prefetch is started on the QBus when the master continues the disconnected read.

#### 4.8.5.2 Target-Retry

During a Target-Retry, a termination is requested by the target because it cannot currently process the transaction. This termination is communicated by the target asserting STOP# while not asserting TRDY#. Target-Retry means that the transaction is terminated after the address phase without any data transfer. The PCI Target Module retries accesses under the following conditions:

- An external PCI bus master attempts to post a single write or the first phase of a burst write and the Px-FIFO does not have the number of data entries free that are specified by the cacheline (CLINE[1:0] in the PCI\_MISC0 register). This Target-Retry only occurs if the PWEN bit is set to 1.
- A delayed transaction is in progress in the PCI Target Channel.
- A burst read is requested but the ensuing read has not terminated on the QBus.
- A PCI bus master attempts a write through the PCI Target Channel while a read is in progress (in either the QBus Slave Channel or the PCI Target Channel) and that read has not completed on the read-destination bus (for example, the PCI bus or the QBus, respectively) For more information, see "Reads and PCI Transaction Ordering" on page 81.

#### 4.8.5.3 Target-Abort

During a Target-Abort, a termination is issued by a target for a transaction which it can not respond to, or during which a fatal error occurred. This is signaled by the target asserting STOP# and negating DEVSEL#. Although there may be a fatal error for the initiating application, the transaction completes gracefully, ensuring normal PCI operation for other PCI resources.

Except during posted writes (see "Terminations of Posted Writes" on page 88), the termination generated by the PCI Target Module is determined by the termination on the QBus. For read transactions and delayed write transactions, the master is retried until the QBus transaction is complete. Once the QBus transaction is complete, the PCI bus master receives a translated version of the QBus termination.

The following table shows how QBus terminations are translated to the PCI bus in the case of delayed transactions. As this table shows, the PCI Target Module generates a Target-Abort when a delayed transfer results in a bus error on the QBus.

| QBus Termination Received | PCI Bus Termination Issued |
|---------------------------|----------------------------|
| Normal                    | Master-Completion          |
| Bus Error                 | Target-Abort               |
| Retry                     | None <sup>b</sup>          |

#### Table 30: Translation of Cycle Termination<sup>a</sup> from QBus to PCI Bus

a. This table applies to read transactions and delayed write transactions.

b. This cycle is not translated. The PCI Target Module retries the PCI bus master during delayed transactions until the QBus Master Module receives a normal termination or a bus error.

## 4.8.6 Terminations of Posted Writes

PCI bus terminations of posted writes are not influenced by QBus terminations. If a posted write leads to a bus error on the QBus, this termination is not signalled on the PCI bus to the PCI bus master. However, errors on the QBus are accessible to PCI Masters through error logging registers (if error logging is enabled by the EN bit of the QB\_ERRCS register). QBus errors can be configured as a source of interrupts.

If the EN bit in the QB\_ERRCS register (see Table 147 on page 297) is set, then the QSpan II records the address, transaction code, data, and size of a posted write transaction that results in a bus error. In this case, an error is indicated by the ES bit of the QB\_ERRCS register. Transfers in the PCI Target Channel are suspended until the ES bit is cleared. The QB\_ERRCS register also records the TC and SIZ information of the transaction error. The address of the transaction error is latched in the QB\_AERR register (see Table 148 on page 298). The data of the transaction error is latched in the QB\_DERR register (see Table 149 on page 299).

If error logging is enabled and the PCI Target Channel is errored, the Px-FIFO is frozen until the ES bit in the QB\_ERRCS register is cleared. Posted write operation continues with the next enqueued posted write once the ES bit of the QB\_ERRCS is cleared. However, if error logging is not enabled and the PCI Target Channel is errored, the errored transfer is lost and posted write operation continues with the next enqueued transfer.

An interrupt is generated upon the logging of an error (ES bit in QB\_ERRCS) only if the QEL\_EN bit in INT\_CTL register is set (see Table 120 on page 269). If generated, the interrupt is directed to the QBus or the PCI bus, depending on the QEL\_DIR bit in the INT\_DIR register (see Table 121 on page 272). Interrupts are described in Chapter 8: "The Interrupt Channel" on page 119.



Figure 7: IDMA Channel — Functional Diagram

The IDMA Channel contains a bi-directional 256-byte (64-entry deep) FIFO called I-FIFO. IDMA transactions are initiated on the QBus. The IDMA Channel can only access PCI Memory space — it cannot access I/O or Configuration space. The QBus Slave Module accepts IDMA read and write transfers of 16 or 32 bits. The MPC860's IDMA must be programmed for level-sensitive mode with the QSpan II; edge-sensitive mode is not supported.

When programmed to perform writes to the PCI bus, the QSpan II requests transfers from the processor's IDMA on the QBus. Once the processor's IDMA is requested for write data, it loads posted writes into the I-FIFO. When sufficient data is available in the I-FIFO, the QSpan II requests the PCI bus and begins bursting data to the PCI target. This process continues until the number of transfers programmed in the QSpan II's IDMA/DMA Transfer Count register completes (see Table 111 on page 256).

When programmed to perform IDMA transfers from the PCI bus to the QBus, the QSpan II reads data from a PCI target and loads the data into the I-FIFO. As the I-FIFO fills, the QSpan II requests the processor's IDMA to transfer data from the QSpan II to the destination on the QBus. The processor's IDMA then transfers data from the QSpan II's I-FIFO until the number of transfers programmed into the QSpan II's IDMA registers completes, or the QSpan II signals to the processor's IDMA that there is no additional data in the I-FIFO.

QSpan II can be programmed to operate as a QBus IDMA peripheral. Although the QBus Master and Slave mode is determined at reset, this does not affect the QBus Slave Module which dynamically accepts MC68360 (QUICC) or MPC860 (PowerQUICC) IDMA cycles. The following list defines the IDMA Channel's features:

- The IDMA Mode (IMODE) bit of the IDMA/DMA\_CS register (see Table 109 on page 252) must be set to indicate whether or not the IDMA Channel functions as an MC68360 or an MPC860 IDMA peripheral.
- QSpan II only supports level-sensitive handshaking with the MPC860.
- QSpan II supports single-address and dual-address IDMA transfers.
- QSpan II determines the type of IDMA transfer by detecting the state of the CSPCI\_ pin when the IDMA cycle begins.

If CSPCI\_ is negated when AS\_ (MC68360 applications) or TS\_ (MPC860 applications) is asserted, then single-address mode is selected. CSPCI\_ must be detected asserted when the cycle begins in order to use dual-address IDMA transfer mode. This requires that the address programmed in the MPC860's or MC68360's buffer pointer register cause the QSpan's CSPCI\_ chip select to be activated. QSpan II does not latch the address off the QBus during dual-address IDMA transfers.

# 5.2 PCI Read Transactions

This section describes the operation and programming of the QSpan II to move data from the PCI bus to the QBus using the processor's IDMA. The IDMA registers within the QSpan II need to be programmed for a read transaction as follows:

- The direction of the transfer must be set for reads. To do this, set the IDMA Direction (DIR) bit to 0 in the IDMA/DMA\_CS register (see Table 109 on page 252). The IDMA Channel can operate in one direction at a time.
- The QBus Port 16 (PORT16) bit of the IDMA/DMA\_CS register indicates whether IDMA transfers will be 16 or 32-bit on the QBus (see Table 109 on page 252).
- MC68360 users can indicate whether fast termination mode is to be used for dual-address or single-address IDMA cycle (bits QTERM and STERM in the IDMA/DMA\_CS register; see Table 109 on page 252).
- The Programmable I-FIFO Watermark (IWM) field controls the burst read length on the PCI bus if it is set to a non-zero value (see Table 113 on page 258). If IWM equals 0, then the QSpan II PCI burst read length equals the CLINE setting (see Table 113 on page 258).
- The CLINE[1:0] field of the PCI\_MISC0 register (see Table 72 on page 211) determines how much data is read by the PCI Master Module (either four or eight 32-bit transfers within a burst read if the IWM is set to zero).
- The IDMA/DMA\_PADD register contains the absolute PCI address for an IDMA transaction (see Table 110 on page 255). This address is aligned to a 4-byte boundary (A1 and A0 always equal 0). If an IDMA transfer is required to cross an A24 boundary, it must be programmed as two separate transactions.

- The CMD bit in the IDMA/DMA\_CS register determines whether the read transaction on PCI proceeds as a Memory Read Line transaction or a Memory Read Multiple transaction (see Table 109 on page 252).
- The IDMA/DMA\_CNT register must be programmed to indicate the amount of data to transfer (see Table 111 on page 256).



The MC68360's IDMA count register and the QSpan II's IDMA/DMA\_CNT register must be programmed with the same value.

Once all the relevant data is programmed into the IDMA register, the IDMA/DMA Go (GO) bit in the IDMA/DMA\_CS register must be set to 1 to initiate the IDMA transfer. Any status bit (IRST, DONE, IPE, or IDE) affected by a previous transfer must be cleared prior to or while the GO bit is set.

## 5.2.1 Data Path

The PCI Master Module performs burst reads on the PCI bus to fill the I-FIFO. When data is available in the I-FIFO, the QSpan II asserts DREQ\_ to request IDMA service. The processor acknowledges with DACK\_/SDACK\_, at which point the QSpan II drives the data onto the QBus. With a 16-bit QBus port, the QSpan II unpacks each 32-bit read data from the PCI into two 16-bit transfers on the QBus.

The IDMA/DMA\_CNT register indicates the number of bytes to transfer in an IDMA transaction (see Table 111 on page 256). QSpan II decreases the transfer count by four with every 32-bit transfer on the PCI bus: the IDMA Channel on the PCI Interface only transfers 32-bit data. The maximum amount of data that can be transferred within an IDMA transaction is 16 Mbytes (for example, 2<sup>22</sup> 32-bit transfers). QSpan II can prefetch data up to the next cacheline boundary and discard the extra data.

When the IDMA/DMA\_CNT expires, the QSpan II sets the IDMA/DMA Done Status (DONE) bit in the IDMA/DMA\_CS register. The MC68360 IDMA asserts the DONE\_ signal when its transfer counter expires. If the MC68360 is programmed with a larger transfer count than the QSpan II, the QSpan II will prematurely assert the DONE bit. If this happens, the MC68360 must reprogram the QSpan II's IDMA/DMA\_CNT register to complete the remainder of the transaction. If the MC68360 is programmed with a smaller transfer count than the QSpan II, the MC68360 will assert the DONE\_ signal when its IDMA count reaches zero, causing the QSpan II to negate DREQ\_. The MC68360 will then have to assert the IDMA/DMA Reset Request (IRST\_REQ) bit in the IDMA/DMA\_CS register to reset the QSpan II's IDMA Channel.

During MPC860 IDMA transfers, the QSpan II ignores the DONE\_ signal.

# 5.3 PCI Write Transactions

This section describes the operation and programming of the QSpan II to move data from the QBus to the PCI bus using the MC68360 or MPC860 IDMA. IDMA registers need to be programmed for a write transaction as follows:

- The direction of the transfer must be set for writes (DIR bit in the IDMA/DMA\_CS register set to 1; see Table 109 on page 252). The IDMA Channel operates in one direction at a time.
- MC68360 users can indicate whether fast termination mode is used for dual-address or single-address IDMA cycle (bits QTERM and STERM in the IDMA/DMA\_CS register; see Table 109 on page 252).
- The PORT16 bit of the IDMA/DMA\_CS indicates whether IDMA transfers will be 16-bit or 32-bit on the QBus (see Table 109 on page 252).
- The IWM field of the IDMA/DMA\_CS register determines when the QSpan II will begin to burst the data onto the PCI bus (Table 109 on page 252). Once the I-FIFO contents equal IWM, the QSpan II burst writes up to the values of IWM throttled only by the PCI target. The IWM must not be programmed with a value greater than the IDMA transfer byte count.
- The CLINE[1:0] field of the PCI\_MISC0 register determines the length of the burst writes initiated by the PCI Master Module (see Table 72 on page 211). The burst writes are either four or eight 32-bit transfers if the IWM bit is set to zero.
- The IDMA/DMA\_PADD register (see Table 110 on page 255) contains the absolute PCI address for an IDMA transaction. This number is aligned to a 4-byte boundary. An IDMA transfer wraps-around at the A24 boundary. If an IDMA transfer is required to cross an A24 boundary, it must be programmed as two separate transactions. The IWM must not be programmed with a value greater than the IDMA transfer byte count.
- The IDMA/DMA\_CNT register indicates the number of bytes to transfer in an IDMA transaction (see Table 111 on page 256).
- The CMD bit in the IDMA/DMA\_CS register determines whether the write transaction on PCI proceeds as a Memory Write Invalidate or a Memory Write transfer (see Table 109 on page 252).

Once all the relevant data is programmed in the IDMA register, the GO bit in the IDMA/DMA\_CS register must be set to 1 to initiate the IDMA transfer. Any status bit (IRST, DONE, IPE, or IQE) affected by a previous transfer must be cleared prior to or while the GO bit is set.

## 5.3.1 Data Path

QSpan II requests data from the IDMA by asserting DREQ\_. By asserting DACK\_/SDACK\_, the IDMA acknowledges that data is being written to the I-FIFO. With a 16-bit QBus port, the QSpan II packs two 16-bit transfers from the QBus into one 32-bit entry in the I-FIFO. When the I-FIFO is full the QSpan II negates DREQ\_.

QSpan II requests the PCI bus when there is as much data in the I-FIFO as is specified by the IWM field of the IDMA/DMA\_CS register (if the IWM equals 0, the QSpan II requests the PCI bus when a cacheline is queued in the I-FIFO). QSpan II burst writes data to the PCI target.

The IDMA/DMA\_CNT register indicates the number of bytes to transfer in an IDMA transaction (see Table 111 on page 256). QSpan II decreases the transfer count by four with every 32-bit transfer on the PCI bus; the IDMA Channel on the PCI Interface transfers 32-bit data. The amount of data that can be transferred within an IDMA transaction is 16 Mbytes (for example, 2<sup>22</sup> 32-bit transfers).

When the IDMA/DMA\_CNT expires, the QSpan II sets the DONE bit in the IDMA/DMA\_CS register. The MC68360 IDMA asserts the DONE\_ signal when its transfer counter expires. If the MC68360 is programmed with a larger transfer count than the QSpan II, the QSpan II will prematurely assert the DONE bit. This will require the MC68360 to reprogram the QSpan II's IDMA/DMA\_CNT register in order to complete the remainder of the transaction. If the MC68360 is programmed with a smaller transfer count than the QSpan II, the MC68360 will assert the DONE\_ signal when its IDMA count reached zero, causing the QSpan II to negate DREQ\_. The MC68360 must then assert the IRST\_REQ bit in the IDMA/DMA\_CS register to reset the QSpan II's IDMA Channel.

During MPC860 IDMA transfers, the QSpan II ignores the DONE\_ signal.

# 5.4 TC[3:0] Encoding with MPC860 IDMA

If the MPC860's I/O Port pins are being shared between multiple functions (for example, IDMA and Ethernet) then the TC[3:0] decoding must be implemented. This allows peripheral devices (QSpan II or Ethernet devices) to determine when they are involved in a transaction.

QSpan II's TC[3:0] inputs can be used with SDACK\_ to decode IDMA transactions. The value that is decoded is programmed by the user through the TC[3:0] field in the IDMA/DMA\_CS register. QSpan II will decode the TC[3:0] lines for IDMA transactions if the TC Encoding Enable (TC\_EN) bit in the IDMA/DMA\_CS register is set to 1. If the TC\_EN bit is set and an IDMA transfer is attempted where the TC[3:0] input does not match the TC[3:0] IDMA/DMA\_CS field, the QSpan II will not accept the IDMA transaction.



This manual adopts the convention that the most significant bit is always the largest number. MPC860 designers must ensure that they connect their pins accordingly. For example, pin A[31] on the QSpan II connects to pin A[31] on the MC68360 bus, but connects to pin A[0] on the MPC860 bus. This applies to all MPC860 buses (D[31:0], AT[3:0], TSIZ[1:0]) not only the address bus.

# 5.5 IDMA Status Tracking

The following bits in the IDMA/DMA\_CS register record the status of the transaction:

- The IDMA/DMA Active Status (ACT) bit in the IDMA/DMA\_CS is set by the QSpan II to indicate that an IDMA transfer is in progress.
- The IDMA/DMA Done Status (DONE) bit indicates that the IDMA transfer is complete.
- The IDMA/DMA PCI Bus Error Status (IPE) bit is asserted when an error is signaled on the PCI bus during an IDMA transfer.
- The IDMA/DMA QBus Error Status (IQE) bit is asserted when an error is signaled on the QBus during an IDMA transfer.
- The IDMA/DMA Reset Status (IRST) bit is asserted when the QSpan II has reset the IDMA Channel.

For more information about errors and resets, see "IDMA Errors, Resets, and Interrupts" on page 95.

# 5.6 IDMA Errors, Resets, and Interrupts

This section describes how the QSpan II responds to PCI bus errors and QBus errors during IDMA reads and writes. This section also discusses IDMA resets and interrupts.

When there is an error on either bus during IDMA transfers, the QSpan II will assert an IDMA error status bit. If the error is on the PCI bus, then the IPE bit in the IDMA/DMA\_CS register is set (see Table 109 on page 252). If the error is on the QBus, then the IQE bit is set. How the transfer proceeds following the error depends on whether the transfer is a read or a write, and on what bus the error occurred. Table 31 summarizes the sequence of events following bus errors for each of these four cases.

If a QBus bus error occurs during an IDMA write transfer, the QSpan II continues to write data until the IWM level is reached. This is possible because the QSpan only initiates PCI activity once the IWM value is queued in the I-FIFO. Once the IWM amount is transferred, the QSpan responds to the bus error on the QBus as indicated in the following table.

The assertion of IRST, IPE, IQE and DONE can be mapped to the interrupt pins on either bus using the QSpan II's Interrupt Control Register (bits IRST\_EN, IPE\_EN, IQE\_EN and DONE\_EN, see Table 120 on page 269). The bus that is interrupted depends on the Interrupt Direction Register INT\_DIR (see Table 121 on page 272). The status of the individual interrupt sources can be determined by reading the corresponding status bit (see Table 42 on page 122 and Table 119 on page 266). To clear the interrupt, the original interrupt source must be cleared. For example, to clear the IDMA Reset Interrupt, the IRST bit in the IDMA/DMA\_CS register must be cleared (see Table 109 on page 252). The following table is extracted from Chapter 8: "The Interrupt Channel" on page 119.

| PCI Bus<br>Transfer | PCI Bus Error                                                                                                                                                                      | QBus Error                                                                                                                                                                                                                                                                                                    |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read                | Prefetching stops.<br>IPE is set in the IDMA/DMA_CS register.<br>Then the QSpan II negates DREQ If<br>enabled, an interrupt is generated on the<br>PCI bus or the QBus.            | QSpan II negates DREQ<br>Transfers on QBus stop.<br>IQE is set in the IDMA/DMA_CS register.<br>If enabled, an interrupt is generated on the<br>PCI bus or the QBus.<br>Prefetching stops when the current IDMA<br>PCI transfer (if any) is complete.                                                          |
| Write               | PCI writes from I-FIFO are halted.<br>IPE is set in the IDMA/DMA_CS register.<br>If enabled, an interrupt is generated on the<br>PCI bus or the QBus.<br>The QSpan II negates DREQ | QSpan II negates DREQ<br>IQE is set in the IDMA/DMA_CS register.<br>If enabled, an interrupt is generated on the<br>PCI bus or the QBus.<br>If a PCI transfer from the I-FIFO is in<br>progress, any complete CLINE of data in the<br>I-FIFO is transferred to the PCI target. (See<br>the following section) |

## Table 32: IDMA Interrupt Source, Enabling, Mapping, Status and Clear bits

| Source                | Source Bits<br>IDMA/DMA_CS<br>(Table 109 on<br>page 252)<br>Write 1 to clear | Enable Bits<br>INT_CTL<br>(Table 120 on<br>page 269) | Mapping Bits<br>INT_DIR<br>(Table 121 on<br>page 272) | Interrupt Status<br>Bits<br>INT_STAT<br>(Table 119 on<br>page 266) |
|-----------------------|------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------|
| IDMA QBus<br>Error    | IQE in<br>IDMA/DMA_CS                                                        | IQE_EN                                               | IQE_DIR                                               | IQE_IS                                                             |
| IDMA PCI Bus<br>Error | IPE in<br>IDMA/DMA_CS                                                        | IPE_EN                                               | IPE_DIR                                               | IPE_IS                                                             |
| IDMA Reset            | IRST in<br>IDMA/DMA_CS                                                       | IRST_EN                                              | IRST_DIR                                              | IRST_IS                                                            |
| IDMA Done             | DONE in<br>IDMA/DMA_CS                                                       | DONE_EN                                              | DONE_DIR                                              | DONE_IS                                                            |

An IDMA transfer that is halted due to an IDMA error (IPE or IQE asserted), will not resume once the error condition is cleared. The IDMA Channel needs to be reset by setting the IRST\_REQ bit of the IDMA/DMA\_CS (see Table 109 on page 252). The IRST status bit is set when the QSpan II has reset the IDMA Channel. Then a new IDMA transfer can be programmed (either from where the error happened or the previous transfer can be attempted again). The QBus Slave Channel is not affected by IDMA Channel errors.

The IDMA Channel can be reset by setting the IRST\_REQ bit in the IDMA/DMA\_CS register, depending on the value of the ACT bit in the IDMA/DMA\_CS register (see Table 109 on page 252). If the ACT bit is 0, then setting IRST\_REQ to 1 has no effect. If the ACT bit is 1, then setting the IRST\_REQ bit has the following effects:

- 1. QSpan II negates DREQ\_, which halts transfers on the QBus.
- 2. If the QSpan II is writing IDMA data on the PCI bus, the QSpan II will terminate the transfer by negating FRAME# at the next cacheline; if the QSpan II is reading data, FRAME# is negated immediately.
- 3. QSpan II flushes the I-FIFO (after negating FRAME#).
- 4. The ACT bit in the IDMA/DMA\_CS register is set to 0 while the IRST bit is set to 1 (see Table 109 on page 252). Note that the IDMA/DMA\_PADD register, the IDMA/DMA\_CNT register and the rest of the IDMA/DMA\_CS register are not reset.
- 5. If enabled, an interrupt is generated on the QBus or the PCI bus (see Chapter 8: "The Interrupt Channel" on page 119).

# 5.7 IDMA Endian Issues

The PCI bus and Motorola processors differ in the way they order and address bytes. These differences are explained in Appendix A: "Registers" on page 199. This section describes how the QSpan II translates cycles from the QBus to the PCI bus in the IDMA Channel.

The PCI bus is always a Little-Endian environment. The QBus can be configured as Little-Endian or Big-Endian, depending on the value of the QBus Byte Ordering Control bit (QB\_BOC) in the MISC\_CTL register (see Table 127 on page 280). The default mode for the QBus is Big-Endian. QSpan II translates byte-lane ordering when the QBus is Big-Endian, while preserving the addressing of bytes. When the QBus is Little-Endian (according to QB\_BOC), the QSpan II preserves byte-lane ordering, while translating the addressing of bytes. Note that the QB\_BOC bit affects transactions in all channels.

Table 33 describes mapping of 16-bit QBus transactions in Little-Endian mode. The byte lane ordering is preserved in Little-Endian mode. During a read transaction, a full 32-bit PCI transaction is unpacked into two 16-bit QBus transfers. During a write transaction, two 16-bit QBus transactions are packed into the I-FIFO for one PCI transfer. The table also shows the order in which the 16-bit QBus cycles appear.

|                            | QBus     |        |             | PCI bus                      |             |  |
|----------------------------|----------|--------|-------------|------------------------------|-------------|--|
| QBus Timing                | SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]#                     | D[31:0]     |  |
| First 16-bit transfer:     | 10       | 00     | B3 B2 xx xx | Full 32-bit PCI bus Transfer |             |  |
| Second 16-bit<br>transfer: | 10       | 10     | B1 B0 xx xx | 0000                         | B3 B2 B1 B0 |  |

Table 33: 16-Bit Little Endian IDMA Cycle Mapping

The following table describes mapping of 16-bit QBus transactions in Big-Endian mode. The addressing of bytes is preserved in Big-Endian mode. During a read transaction, a full 32-bit PCI transaction is unpacked into two 16-bit QBus transfers. During a write transaction, two 16-bit QBus transactions are packed into the I-FIFO for one PCI transfer. The table also shows the order in which the 16-bit QBus cycles appear.

Table 34: 16-Bit Big-Endian IDMA Cycle Mapping

|                            | QBus     |        |             | PCI bus    |                    |
|----------------------------|----------|--------|-------------|------------|--------------------|
| QBus Timing                | SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]#   | D[31:0]            |
| First 16-bit transfer:     | 10       | 00     | B0 B1 xx xx | Full 32-bi | t PCI bus Transfer |
| Second 16-bit<br>transfer: | 10       | 10     | B2 B3 xx xx | 0000       | B3 B2 B1 B0        |

The following table describes mapping of 32-bit QBus transactions in Little-Endian mode. The byte lane ordering is preserved in Little-Endian mode.

Table 35: 32-Bit Little-Endian IDMA Cycle Mapping

| QBus     |        |             | PCI bus  |             |  |
|----------|--------|-------------|----------|-------------|--|
| SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]# | D[31:0]     |  |
| 00       | 00     | B3 B2 B1 B0 | 0000     | B3 B2 B1 B0 |  |

The following table describes mapping of 32-bit QBus transactions in Big-Endian mode. The addressing of bytes is preserved in Big-Endian mode.

Table 36: 32-Bit Big-Endian IDMA Cycle Mapping

| QBus     |        |             | PCI bus  |             |  |
|----------|--------|-------------|----------|-------------|--|
| SIZ[1:0] | A[1:0] | D[31:0]     | BE[3:0]# | D[31:0]     |  |
| 00       | 00     | B0 B1 B2 B3 | 0000     | B3 B2 B1 B0 |  |

# Chapter 6: The DMA Channel

This chapter examines the function of the QSpan II's DMA Channel. The following topics are discussed:

- "DMA Registers" on page 101
- "Direct Mode DMA Operation" on page 103
- "Linked List Mode DMA Operation" on page 104

## 6.1 Overview

QSpan II has a DMA Channel for high performance data transfer between the PCI bus and the QBus (see Figure 8). The DMA Channel functions similarly to the IDMA Channel in that it uses the existing IDMA registers (and some additional registers), and shares the 256-byte I-FIFO with the IDMA Channel. Because of the shared FIFO, the QSpan II cannot use its IDMA and DMA Channels at the same time.



Tundra recommends using the DMA Channel over the IDMA Channel because it supports higher rates of data transfer between the PCI bus and the QBus.



Figure 8: DMA Channel — Functional Diagram

There are two modes of operation for the DMA Channel: Direct Mode and Linked List Mode (also called Scatter/Gather mode). In Direct Mode, the DMA registers are programmed directly by an external master. In Linked List Mode, the DMA registers are loaded from PCI Bus memory or QBus memory by the QSpan II. This allows the QSpan II to follow a list of buffer descriptors established by the local controller or the system host.

A block of DMA register contents stored in memory is called a Command Packet. A command packet can be linked to another command packet. When the DMA has completed the operations described by one command packet, it automatically moves to the next command packet in the Linked List of command packets. A command packet cannot initiate an IDMA transfer; it can only initiate a DMA transfer.

# 6.2 DMA Registers

The DMA Channel uses the IDMA registers (starting at Register offset 400), as well as three additional registers: DMA\_QADD (see Table 112 on page 257), DMA\_CS (see Table 113 on page 258) and DMA\_CPP (see Table 114 on page 261).

The PCI address for the DMA transfer resides in IDMA/DMA Address Register (IDMA/DMA\_PADD). The QBus address for the DMA transfer resides in DMA QBus Address Register (DMA\_QADD). The PCI and QBus addresses are aligned to a four-byte boundary. If a DMA transfer is required to cross an A24 boundary, it must be programmed as two separate transactions.

The IDMA/DMA Transfer Count Register (IDMA/DMA\_CNT) contains the number of bytes to be transferred during the DMA transfer (see Table 111 on page 256). The minimum value for the transfer count is 16 bytes, and it must be a multiple of four bytes.

The DMA Command Packet Pointer (DMA\_CPP) points to a 16-byte aligned address location. This location is in QBus memory or PCI bus memory that contains the command packet to be loaded for Linked List DMA.

Some of the register bits in the IDMA/DMA Control and Status (IDMA/DMA\_CS) register are used by the DMA Channel. The following bits are not used by the DMA Channel because they are only used during IDMA transfers:

- IWM
- TC
- TC\_EN
- IMODE
- QTERM
- STERM
- PORT16

The IDMA/DMA\_CS register uses two additional bits to support a DMA transfer: DMA, which indicates a DMA transfer is requested; and CHAIN, which indicates a Linked List DMA transfer is requested. All other register bits have the same function in a DMA transfer as in an IDMA transfer.

An additional register, DMA Control and Status Register (DMA\_CS) defines other fields to control the QBus transaction generated by the QSpan II during DMA transfers. QSpan II generates DMA transfers on the QBus as an MC68360 (QUICC) master, as an MPC860 (PowerQUICC) master, or as an M68040 master, depending on the QBus Master mode selected at reset (MSTSLV field in MISC\_CTL). The QBus master only generates burst cycles as an MPC860 master. The Transaction Code (TC) field determines the transaction code generated on the QBus during a DMA transfer. The INVEND bit inverts the endian setting of the QB\_BOC setting in MISC\_CTL. The QBus Destination Size (DSIZE) determines the destination port size of the external QBus slave. The three fields described in the previous paragraph are similar to the fields of the same name in PCI Target Image registers (PBTIx\_CTL). The IWM field controls the burst size on PCI. If the IWM is set to zero, the burst length stored in the CLINE field, which is stored in the PCI\_MISC0 register, is used. The maximum burst size on PCI during DMA transfers is 128 bytes.

The QBus OFF (Q\_OFF) timer, which is set in the DMA\_CS register (see Table 113 on page 258), limits the DMA Channel's access to the QBus during DMA transfers. For large DMA transfers, set this field to a non-zero value to allow the PCI Target Channel regular access to the QSpan II's QBus master. Depending on the value programmed in the Q\_OFF field, the DMA Channel will not request the QBus for the programmed number of QBus clocks when the DMA transfer on the QBus crosses the following: any 256-byte address boundary, or a 64-byte boundary, depending on the setting of Maximum DMA Burst Size on QBus (MDBS) bit in the DMA\_CS register (see Table 113 on page 258).

To temporarily stop a DMA transfer in order to free up PCI bus or QBus bandwidth, the DMA Stop (STOP) bit in DMA\_CS can be set (see Table 113 on page 258). The DMA transfer is stopped once any active DMA transfers are completed. Once the DMA is stopped on the PCI and QBus, the STOP\_STAT bit is set in DMA\_CS. To restart a stopped DMA transfer, the STOP bit must be cleared by writing a zero to the STOP bit. The DMA Channel restarts from where it stopped once the STOP bit is cleared and the Q\_OFF counter has expired; if this function is enabled.

The Command Packet Location (CP\_LOC) field is used during Linked List mode operation to determine if the command packets reside in QBus memory or PCI Bus memory. All the command packets in a Linked List must reside in QBus memory or PCI Bus memory, but not in both.

## 6.2.1 Burst Cycles

The BURST\_4 field in DMA\_CS enables the QSpan II to generate burst cycles with four dataphases on the QBus. This allows the QSpan II to work with the UPM of the MPC860. For DMA transfers that begin at an address that is not 16-byte aligned, the QSpan II generates single QBus cycles until a 16-byte boundary is reached and then performs burst cycles. For DMA write transfers to the QBus which end at an address that is not 16-byte aligned, the QSpan II generates single during the QSpan II generates single write cycles to finish the transfer. For DMA read transfers on the QBus which end at an address not 16-byte aligned, the QSpan II generates a burst cycle to the next 16-byte boundary (for example, prefetch data up to the next cacheline boundary), and discards the extra data.

The Burst Enable (BRSTEN) field in IDMA/DMA\_CS disables QBus burst cycles during DMA transfers when the QSpan II is MPC860 master. This allows the QSpan II to operate in systems where the MPC860 is used with local memory that does not support bursting.

The KEEP\_BB bit in the MISC\_CTL2 register (see Table 130 on page 284) is not supported for DMA operation. As such, do not set this bit when the QSpan II DMA channel is used with the PowerQUICC memory controller (UPM).

## 6.2.2 DMA Cycles on QBus

QSpan II can limit the number of single reads and writes performed on the QBus to service the DMA. QSpan II can complete a maximum of 16 single cycles or 16 burst cycles. If the QBus OFF timer in the DMA\_CS register is set, the OFF timer becomes effective on every 64-byte boundary when completing single cycles on the QBus, and on every 256-byte boundary when completing burst cycles (see Table 113 on page 258).

QSpan II can also limit the number of clocks a DMA burst cycle is active on the QBus. If this option is set through the MDBS bit in the DMA\_CS register, it forces the QSpan II to perform four burst cycles (64 bytes) at a time on the QBus (see Table 113 on page 258). This allows the PCI Target Channel or an external QBus master to access the QBus with lower latency. In this case, the QBus OFF timer becomes effective on every 64-byte boundary.

# 6.3 Direct Mode DMA Operation

When operated in Direct Mode, the DMA is initiated by programming the QSpan II's registers. The following fields in the listed registers must be set to the appropriate values:

- IDMA/DMA\_CS (see Table 109 on page 252): CMD, DMA, CHAIN, DIR
- DMA\_CS (see Table 113 on page 258): TC, DSIZE, INVEND, IWM, Q\_OFF, BURST\_4, BRSTEN, MDBS
- IDMA/DMA\_PADD (see Table 110 on page 255): ADDR (PCI address)
- DMA\_QADD (see Table 112 on page 257): Q\_ADDR (QBus address)
- IDMA/DMA\_CNT (see Table 111 on page 256): CNT (Transfer count)

Interrupts can be produced by enabling the appropriate bits in the INT\_CTL and INT\_DIR registers. Interrupts can be generated to indicate the following:

- the completion of the DMA
- the occurrence of PCI bus or QBus errors

## 6.3.1 Initiating a Direct Mode Transfer

Once all relevant data is programmed, set the GO bit in the IDMA/DMA\_CS register to 1 to initiate the direct mode DMA transfer (see Table 109 on page 252). Any status bit, such as IRST, DONE, IPE or IQE, set by a previous transfer must be cleared prior to, or when the GO bit is set.

QSpan II initiates read transfers on the source bus to fill the I-FIFO. Once data is available in the I-FIFO the destination bus master drains the data from the I-FIFO. The IWM field in DMA\_CS register determines the amount of data transferred on the PCI bus for each DMA transaction initiated by the PCI Master Module.

The IDMA/DMA\_CNT register indicates the number of bytes left to transfer in the DMA transaction. QSpan II decreases this transfer counter by four for every 32-bit transfer on the PCI bus. The maximum amount of data that can be transferred using the DMA is 16 Mbytes.

## 6.3.2 Terminating a Direct Mode Transfer

The completion of the DMA is signaled by an interrupt or is determined by polling the DONE bit in IDMA/DMA\_CS. While the DMA transfer is active, the ACT bit in IDMA/DMA\_CS is set. Any writes to the IDMA/DMA registers when the DMA is active are ignored, except for the IRST\_REQ bit in IDMA/DMA\_CS and the STOP bit in DMA\_CS.

The DMA transfer can be terminated by setting the IDMA/DMA Reset Request (IRST\_REQ) bit in the IDMA/DMA\_CS register to 1. When the DMA transfer is terminated with IRST\_REQ, the IRST status bit is set in IDMA/DMA\_CS once the DMA Channel finishes any active transfer. An interrupt can also be generated by the IRST status bit.

If a QBus or PCI error (Master-Abort or Target-Abort) is encountered during a DMA transfer, the DMA transaction is terminated and the IQE or IPE status bits are set in IDMA/DMA\_CS.

# 6.4 Linked List Mode DMA Operation

Linked List mode allows the DMA Channel to transfer a series of non-contiguous blocks of data without software intervention (see Figure 9 on page 105). Each entry in the Linked List is described by a command packet containing data for the QSpan II's DMA registers. The data structure for each command packet is the same, and contains the necessary information to program the DMA address and control registers. Each command packet is a record of four 32-bit data elements, for a total of 16 bytes. The command packets must be aligned to a 16-byte address boundary.

The fourth word of data in the command packet contains the next command packet pointer (DMA\_CPP). The least significant bit (NULL bit) of the fourth command packet word contains control information for the Linked List processing.

The NULL bit indicates the termination of the entire Linked List. If the NULL bit is set to 0, the DMA processes the next command packet pointed to by the command packet pointer. If the NULL bit is set to 1, then this command packet is considered to be the last command packet in the Linked List, and the DMA stops at the completion of the transfer described by this command packet. The DONE bit in IDMA/DMA\_CS is set upon the completion of the final command packet.







The maximum data transfer size for a Linked List DMA is 1 Mbyte because only CNT[19:2] bits are loaded from the command packet.

## 6.4.1 Initiating a Linked List Mode DMA Operation

To initiate a Linked List Mode DMA, the command packets described in the previous section must be set up in QBus memory or PCI bus memory. The final command packet must have the NULL bit set to 1. The following fields in the DMA\_CS register (see Table 113 on page 258) must be programmed to the appropriate values:

- IWM, Q\_OFF
- BURST\_4
- BRSTEN
- CP\_LOC
- MDBS
- TC
- DSIZE
- INVEND

The DMA\_CPP must be programmed to point to the first command packet. The following fields in the IDMA/DMA\_CS register (see Table 109 on page 252) must be programmed to the appropriate values:

- CMD
- DMA
- CHAIN

To enable an interrupt upon the completion of the Linked List DMA or due to PCI bus or QBus errors, the appropriate bits must be set in the INT\_CTL and INT\_DIR registers.

Once all relevant data is programmed, the GO bit in the IDMA/DMA\_CS register must be set to 1 to initiate the Linked List DMA transfer. Any status bit (IRST, DONE, IPE or IQE) set by a previous transfer must be cleared prior to, or when the GO bit is set.

The Linked List DMA Channel ignores the setting of IDMA/DMA\_PADD, DMA\_QADD and IDMA/DMA\_CNT, when the DMA bit and CHAIN bit are set to 1 in IDMA/DMA\_CS. It uses the DMA\_CPP and CP\_LOC to read the first command packet from either QBus or PCI bus memory. If it reads the command packets from the QBus, it saves the setting of TC, DSIZE and INVEND fields in the DMA\_CS register at the start of the Linked List DMA, and uses these values on subsequent loading of the command packets. The command packet may change the values of these fields in DMA\_CS for the DMA transfer initiated by that command packet.

The following registers are updated from the contents of the command packet:

- IDMA/DMA\_PADD[31:2]
- DMA\_QADD[31:2]
- DMA\_CS[31:20]

- IDMA/DMA\_CNT[19:2]
- DMA\_CPP[31:4]

The DMA Channel then starts the DMA transfer described by the command packet.



The command packet pointer register (DMA\_CPP) points to the next command packet, and not to the command packet that is being executed. At the completion of the current command packet, the next command packet is loaded and the sequence continues until a command packet with the NULL bit set to 1 is loaded.

Once the software has set the GO bit, the software can monitor Linked List DMA completion by either waiting for the generation of an interrupt, or by polling for the DONE status bit in IDMA/DMA\_CS. To determine the current command packet being executed, the software can read the DMA\_CPP register to determine whether the command packet previous to this is being executed. The software can also read the IDMA/DMA\_CNT register to determine the amount of data that is left to be transferred in the current command packet.

If the Linked List is set up in a circular queue — where each packet points to the next in the list and the last points to the first, and the software wants the DMA Channel to skip over some of the command packets — the software can set the transfer count in the command packet (bits [19:0] of the third element) to 0. When the DMA Channel reads a command packet that has a transfer count of 0, it reads and processes the next command packet.

If the CP\_LOC is set to 1 — when the Linked List DMA Channel reads the next command packet from the QBus memory — it reads it in a single 16-byte burst if BRSTEN in DMA\_CS is set to 1. Otherwise it takes four single reads to load the command packet. If a QBus error is encountered while reading the command packet, the Linked List DMA is terminated and the IQE status bit in IDMA/DMA\_CS is set. If a QBus or PCI bus error is encountered while a DMA transfer described by the command packet is in progress, the Linked List DMA is terminated and the appropriate status bit (IQE or IPE) is set in the IDMA/DMA\_CS register.

If the CP\_LOC is set to 0, the DMA Channel reads the command packet from PCI memory using a burst read cycle. If a PCI error is encountered during this read, the Linked List DMA is terminated and the IPE status bit in IDMA/DMA\_CS is set.

## 6.4.2 Terminating a Linked List Mode DMA Operation

To terminate a Linked List DMA operation, set the IRST\_REQ bit to 1. In this case, the Linked List DMA is terminated and the IRST status bit is set in the IDMA/DMA\_CS register once the DMA Channel finishes any active transfers.

The STOP bit in DMA\_CS can temporarily stop the Linked List DMA. This can be used to free up PCI bus or QBus bandwidth for time-sensitive data transfers. Any updates to the command packets can be completed before the STOP bit is cleared and the Linked List DMA is resumed. The STOP\_STAT bit in DMA\_CS indicates when the DMA Channel is stopped. At this point any updates to the command packets in memory can be finished.



The ACT bit in IDMA/DMA\_CS is still set when the DMA is temporarily stopped. The ACT bit is cleared when the Linked List DMA is completed, an IRST\_REQ is generated, or a bus error on PCI bus or QBus is encountered.

# Chapter 7: The Register Channel

This chapter describes the QSpan II's Register Channel. The following topics are discussed:

- "Register Access Fairness" on page 110
- "Register Access from the PCI Bus" on page 111
- "Register Access from the QBus" on page 113
- "Register Access Synchronization" on page 117
- "Mailbox Registers" on page 118

## 7.1 Overview

QSpan II provides 4 Kbytes of QSpan II Control and Status Registers (QCSRs). These registers program PCI settings and the QSpan II's operating parameters (see Figure 10). The QCSRs consist of two functional groups: the PCI Configuration Registers and the QSpan II Device Specific Registers (see Figure 11 on page 111). QCSR space is accessible from the PCI bus and the QBus.

Since QSpan II registers can be accessed from either the PCI bus or the QBus, an internal arbitration occurs to indicate ownership. The access mechanisms for the QCSRs, including the arbitration protocol, differ depending on whether the registers are accessed from the PCI bus or the QBus. An internal pointer selects which bus can access the registers. Default ownership of the Register Channel is granted to the QSpan II's PCI Target Module. When ownership of the Register Channel is granted to the QBus Slave Module, register accesses from the PCI bus are retried.



#### Figure 10: Register Channel — Functional Diagram

## 7.2 Register Access Fairness

QSpan II can be configured to make register access fairer by setting the Register Access Control (REG\_AC) bit in MISC\_CTL2 (see Table 130 on page 284). If this bit is set, the register access port is parked at the bus that completed the last register access. For example, if there was a QBus register access, then the register access port defaults to the QBus. Any additional QBus register access receives an immediate response while a PCI register access gets retried first, and then succeeds when the register access port switches to the PCI bus.

If register access is performed mainly from the QBus, set the REG\_AC bit in the MISC\_CTL2 register (see Table 130 on page 284).

### 7.3 Register Access from the PCI Bus

The QCSRs can be accessed through Configuration cycles or in Memory space (see the following figure). These accesses are discussed in the following sections.

Default ownership of the Register Channel is granted to the PCI Target Module. If an external master on the PCI bus attempts to access the registers of the QSpan II, and the ownership has been granted to the QBus Slave Module, the transfer will be retried on the PCI bus.



Figure 11: QSpan II Control and Status Registers

Only the PCI Configuration registers are accessible through PCI Configuration Type 0 cycles. PCI Configuration registers that reside in the lower 256 bytes of QCSR space are accessible in PCI Configuration space. QSpan II's PCI interface decodes AD[7:2] for accesses to its PCI Configuration registers. IDSEL must be asserted for Type 0 Configuration access. Configuration access from the QBus is discussed in "PCI Configuration Cycles Generated from the QBus" on page 114.

QSpan II registers can be accessed in Memory space but not in I/O space. To access QCSRs from PCI bus Memory space, it is necessary to set the Memory Space bit in the PCI\_CS register to 1 (see Table 70 on page 207). This step is required for any PCI Target Module access, including register accesses. The PCI\_BSM SPACE bit is fixed at 0 so that registers can be accessed in PCI Memory space. The BA[31:12] field of the PCI\_BSM register specifies the base address in memory space of the QCSRs. The QCSRs are located in Memory space as address offsets of this base address (see Figure 11).

There is a direct mapping between values on the AD[11:0] lines and the register offsets. The following table illustrates PCI Memory cycle access to bits 15-08 of the PCI\_CLASS register (see Table 71 on page 210). This table shows the AD[11:0] and C/BE#[3:0] signals required to access byte 1. This table also shows how the data is presented to the PCI master.

| AD[11:0] (register offset) | BE[3:0]# | AD[31:0] <sup>a</sup> |
|----------------------------|----------|-----------------------|
| 0x008                      | 1101     | xx xx B1 xx           |

#### Table 37: PCI Memory Cycle Access to bits 15-08 of the PCI\_CLASS register

a. Data phase.

In systems where the QSpan II is on an add-in card, the MPC860 is the QBus Host. An external host will read QSpan II's PCI Configuration registers to program the QSpan II's PCI registers (for example, Base Address Registers). In this case, the QSpan II's Configuration registers can be programmed by reading from an external EEPROM. When the QSpan II loads the registers from EEPROM, all PCI access to QSpan II are retried.

A power-up option pin called PCI Access Disabled (PCI\_DIS), sets a bit in the MISC\_CTL2 register to retry all access to the QSpan II from external PCI Masters. PCI accesses to the QSpan II are retried until the QBus Host programs the QSpan II registers and clears this bit. The host can then read the Configuration registers and program the remaining QSpan II's PCI registers.

Even if an EEPROM is used on the board, the QBus Host can still change certain registers before the PCI host can access the QSpan II registers. In this case, the PCI\_DIS bit can also be loaded from EEPROM, and the QBus Host can clear it after it modifies the QSpan II registers.

The PCI\_DIS pin allows the QBus Host to initialize the QSpan II before the QSpan II will respond to PCI configuration accesses. The serial EEPROM is no longer the only method available to initialize the QSpan II.

## 7.4 Register Access from the QBus

QSpan II's registers can be selected by an external master from the QBus with the CSREG\_ chip-select pin. Since the QSpan II registers span 4K, only the lower 12 bits of the QBus address are used (see Figure 12). Register accesses of 8-bit, 16-bit, or 32-bit size can be preformed. However, the QSpan II is a 32-bit slave device (for more information, see Table 8 on page 51 and Table 9 on page 52).

If an external master on the QBus attempts to access the QSpan II's registers, the transfer is retried on the QBus. QSpan II will then make an internal request for register ownership by the QBus. The request is removed if no register access is attempted within 2<sup>10</sup> QCLK clock cycles. The request is also removed if a register access completes on the QBus without a subsequent register access beginning within 32 QCLK clock cycles of the completion of the previous register access. This type of access is implemented when the Register Access Control (REG\_AC) bit is set to 0 in the MISC\_CTL2 register (see Table 130 on page 284).



QSpan II's registers do not support burst accesses. If a burst to register space is attempted from the QBus, a bus error is issued.





#### 7.4.1 Examples of QBus Register Accesses

The following table illustrates Big-Endian access to bits 15-08 of the PCI\_CLASS register. This table shows the address and size signals required to access this byte. This table also shows how the data is presented to the QBus master.

Table 38: Big-Endian QBus Access to bits 15-08 of the PCI\_CLASS register

| A[11:0] | SIZ[1:0] | A[1:0] <sup>a</sup> | D[31:0]     |
|---------|----------|---------------------|-------------|
| 0x00A   | 01       | 10                  | xx xx B2 xx |

a. This is a subset of A[11:0].

The following table illustrates Little-Endian access to bits 15-08 of the PCI\_CLASS register. There is no real difference between Big-Endian and Little-Endian access to the QSpan II's register. The only difference between Tables 38 and 39 is the name (not the location) of the byte along the data lines.

#### Table 39: Little-Endian QBus Access to bits 15–08 of the PCI\_CLASS register

| A[11:0] | SIZ[1:0] | A[1:0] <sup>a</sup> | D[31:0]     |
|---------|----------|---------------------|-------------|
| 0x00A   | 01       | 10                  | xx xx B1 xx |

a. This is a subset of A[11:0].

#### 7.4.2 PCI Configuration Cycles Generated from the QBus

PCI Configuration cycles of Type 0 or Type 1 can be initiated from the QBus. To initiate Configuration cycles complete the following:

1. Write the Target PCI address in the Configuration Address Register (see Table 115 on page 262).

This step determines how the address of the Configuration cycle is generated on the PCI bus.

2. Access the Configuration Data register (see Table 117 on page 264). A read access generates a Configuration read on the PCI bus; a write access generates a Configuration write on the PCI bus.

This step causes the Configuration cycle to occur on the PCI bus. The following subsections describe these two aspects of Configuration cycles.



The Bus Master (BM) bit in the PCI\_CS register must be set before attempting a PCI configuration cycle (see Table 70 on page 207).

#### 7.4.3 Address Phase of PCI Configuration Cycles

The type of Configuration cycle that is generated on the PCI bus — Type 0 or Type 1 — is determined by the TYPE bit of the CON\_ADD register (see Table 115 on page 262). This determines how the address of the Configuration cycle is generated on the PCI bus. When the QSpan II is being used as a host bridge, the MA\_BE\_D bit in the MISC\_CTL register must be set to a 1. If you set this bit to 1, it allows the QSpan II to signal a successful Configuration cycle to the host processor, even if a Master-Abort occurs on the PCI bus.

If the TYPE bit is set to 1, an access of the CON\_DATA register from the QBus interface performs a corresponding Configuration Type 1 cycle on the PCI bus (see Table 117 on page 264). During the address phase of the Configuration Type 1 cycle on the PCI bus, the PCI address lines carry the values encoded in the CON\_ADD register  $(AD[31:0] = CON_ADDR[31:0])$ .

If the TYPE bit set to 0, an access of the CON\_DATA register from the QBus interface performs a corresponding Configuration Type 0 cycle on the PCI bus. If the Device Number is programmed it causes one of the upper address lines, AD[31:16], to be asserted during the address phase of the Configuration Type 0 cycle; the other lines are negated. (Table 40 shows which PCI address line is asserted as a function of the DEV\_NUM[3:0] field.) The remaining address lines during the address phase of the Configuration cycle are controlled by the Function Number and Register Number fields of the CON\_ADD register:

- AD[15:11] = 00000
- AD[10:8] = FUNC\_NUM[2:0]
- AD[7:2] = REG\_NUM[5:0]
- AD[1:0] = 00

| DEV_NUM[3:0] | AD[31:16]           |
|--------------|---------------------|
| 0000         | 0000 0000 0000 0001 |
| 0001         | 0000 0000 0000 0010 |
| 0010         | 0000 0000 0000 0100 |
| 0011         | 0000 0000 0000 1000 |
| 0100         | 0000 0000 0001 0000 |
| 0101         | 0000 0000 0010 0000 |
| 0110         | 0000 0000 0100 0000 |
| 0111         | 0000 0000 1000 0000 |
| 1000         | 0000 0001 0000 0000 |
| 1001         | 0000 0010 0000 0000 |
| 1010         | 0000 0100 0000 0000 |
| 1011         | 0000 1000 0000 0000 |
| 1100         | 0001 0000 0000 0000 |
| 1101         | 0010 0000 0000 0000 |
| 1110         | 0100 0000 0000 0000 |
| 1111         | 1000 0000 0000 0000 |

Table 40: PCI AD[31:16] lines asserted as a function of DEV\_NUM field

#### 7.4.3.1 Data Phase of PCI Configuration Cycles

PCI Configuration accesses from the QBus proceed as delayed transactions. This is true for Configuration reads as well as writes. When the CON\_DATA register is accessed, the QBus master is retried. QSpan II then initiates a Configuration cycle on the PCI bus.

The PCI byte enable driver is dependent on the attributes of the QBus cycle (for example, QBus address and SIZ signals) during the Configuration cycle. Until the Configuration cycle completes on the PCI bus any further Configuration cycle attempt is retried. In the case of a read (read to CON\_DATA), the data from the PCI bus is stored in the CON\_DATA register. After the Configuration cycle completes on the PCI bus — when the QBus master attempts to access the CON\_DATA register at the same address — the cycle completes successfully on the QBus. In the case of a write (write to CON\_DATA), the cycle completes on the QBus after the Configuration write completes on the PCI bus.

#### 7.4.4 Interrupt Acknowledge Cycle

A mechanism is provided for a QBus register read to generate a PCI Interrupt Acknowledge cycle (see "Interrupt Acknowledge Cycle" on page 125.)

## 7.5 Register Access Synchronization

QSpan II supports non-simultaneous access to its registers from the QBus Interface and the PCI Interface. This feature presents a synchronization issue. QSpan II does not have the ability to lock out register accesses from one interface so that accesses can be performed on the other interface. QSpan II also does not have semaphore capabilities. If a master on one interface is executing a test and set procedure — reading from a register and then setting part or all of the register — there is the possibility that between the test and the set, a master on the other interface sets the same register. This issue is most relevant to the Interrupt Control register (see Table 120 on page 269).

#### Figure 13: Example of a Register-Access Synchronization Problem



Two possible solutions to this problem include the following:

- 1. Perform byte-wide writes on the PCI bus as opposed to 32-bit writes. This does not solve all the register-access synchronization problems because the other 7 bits in the write may change between a read and a write. Since the SI1 bit and the DONE\_EN bit (see Table 120 on page 269) are separated by two bytes, it would solve the problem described in Figure 13.
- 2. Design the system to always set the DONE\_EN bit, or whatever other bit is susceptible to this problem. However, this may lead to the generation of more interrupts, and consequently, an impact on performance.

## 7.6 Mailbox Registers

QSpan II has four 32-bit mailbox registers which provide an additional communication path between the PCI bus and the QBus. The mailboxes support read and write accesses from either bus and can be enabled to generate an interrupt on either bus when they are written to from the other bus.

For example, if mailbox 0 is programmed to generate a QBus interrupt — by setting MB0\_EN to 1 in INT\_CTL register, and MB0\_DIR to 0 in INT\_DIR register — then a PCI write with any of the byte-lanes enabled to mailbox 0 will generate a QBus interrupt (QINT\_). In this case, mailbox 0 can also be written to from the QBus, but this will not generate a QBus interrupt. Likewise, if a mailbox is programmed to generate a PCI interrupt, a PCI interrupt is only generated when that mailbox is written to from the QBus.

To clear an interrupt, write a 1 to the corresponding status bit in INT\_STAT (see Table 119 on page 266).

# Chapter 8: The Interrupt Channel

This chapter describes the function of the QSpan II Interrupt Channel. The following topics are discussed:

- "Hardware-Triggered Interrupts" on page 120
- "Software-Triggered Interrupts" on page 121
- "Interrupt Acknowledge Cycle" on page 125
- "Disabling PCI Interrupts" on page 125

### 8.1 Overview

Certain hardware and software events can trigger interrupts on the QBus and the PCI bus through the Interrupt Channel (see Figure 14). Two bidirectional interrupt pins are provided: INT# for the PCI bus; QINT\_ for the QBus.

### 8.2 Hardware-Triggered Interrupts

In order for an input to trigger an interrupt on the opposite interface, the corresponding enable bit must be set in the INT\_CTL register (see Table 120 on page 269). For example, for INT# to trigger QINT\_, the INT\_EN bit must be set. The status of the interrupt is logged in the INT\_STAT register.



It is only possible to route interrupts in one direction at a time. For example, it is not possible to allow PCI interrupt sources to be mapped to QINT\_ while allowing QINT\_ sources to be mapped to INT#.



#### Figure 14: Interrupt Channel — Functional Diagram

| Input | Enable bits<br>(INT_CTL, see<br>Table 120 on page 269) | Status Bits<br>(INT_STAT, see<br>Table 119 on page 266) | Output |
|-------|--------------------------------------------------------|---------------------------------------------------------|--------|
| INT#  | INT_EN                                                 | INT_IS                                                  | QINT_  |
| PERR# | PERR_EN                                                | PERR_IS                                                 |        |
| SERR# | SERR_EN                                                | SERR_IS                                                 |        |
| QINT_ | QINT_EN                                                | QINT_IS                                                 | INT#   |

| Table 41: Mapping of Hardware-Initiated Interrupts |
|----------------------------------------------------|
|----------------------------------------------------|

If INT\_EN is set, then the assertion of INT# causes QINT\_ to be asserted until INT# is negated and the INT\_IS bit is cleared. Because INT# is level sensitive, if the INT\_IS bit is cleared before INT# is negated, the clearing of the bit will have no affect and QINT\_ will remain asserted.

To negate QINT\_ when its assertion is caused by the assertion of PERR# or SERR#, complete the following procedure:

- 1. Clear the error status bit in the source PCI device.
- 2. Clear the status bit in the INT\_STAT register.

To negate INT# when its assertion is caused by the assertion of QINT\_, negate QINT\_ and then clear the QINT\_IS bit in the INT\_STAT register.

# 8.3 Software-Triggered Interrupts

QSpan II can generate interrupts based upon internal events provided that the interrupt source is enabled in the INT\_CTL register (see Table 120 on page 269). Interrupts can be mapped to an interrupt output pin on the PCI bus (INT#) or the QBus (QINT\_) depending on the value of the interrupt mapping bit in the INT\_DIR register (see Table 121 on page 272). The status of the individual interrupt sources can be determined by reading the corresponding status bit (see Table 119 on page 266). To clear an interrupt, the original interrupt source must be cleared first. For example, to clear the IDMA Reset Interrupt, the IRST bit in the IDMA/DMA\_CS register must be cleared first (see Table 109 on page 252).

| Source                              | Source Bits<br>Write 1 to clear                          | Enable Bits<br>INT_CTL (see<br>Table 120 on<br>page 269) | Mapping Bits<br>INT_DIR (see<br>Table 121 on<br>page 272) | Interrupt Status Bits<br>INT_STAT (see<br>Table 119 on page 266) |
|-------------------------------------|----------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------|
|                                     | QBus Slave                                               | e Channel Errors (Erro                                   | or on the PCI bus)                                        | ·                                                                |
| PCI Bus Error                       | ES in PB_ERRCS<br>(see Table 97 on<br>page 238)          | PEL_EN                                                   | PEL_DIR                                                   | PEL_IS                                                           |
| Data Parity Error                   | MD_PED in PCI_CS<br>(see Table 70 on<br>page 207)        | MDPED_EN                                                 | MDPED_DIR                                                 | MDPED_IS                                                         |
|                                     | PCI Bus 1                                                | Target Channel Errors (Ei                                | rror on the QBus)                                         |                                                                  |
| QBus Error                          | ES in QB_ERRCS<br>(see Table 147 on<br>page 297)         | QEL_EN                                                   | QEL_DIR                                                   | QEL_IS                                                           |
|                                     |                                                          | DMA/DMA Channel E                                        | Events <sup>a</sup>                                       |                                                                  |
| IDMA/DMA<br>QBus Error              | IQE in IDMA/DMA_CS<br>(see Table 109 on<br>page 252)     | IQE_EN                                                   | IQE_DIR                                                   | IQE_IS                                                           |
| IDMA/DMA<br>PCI Bus Error           | IPE in IDMA/DMA_CS<br>(see Table 109 on<br>page 252)     | IPE_EN                                                   | IPE_DIR                                                   | IPE_IS                                                           |
| IDMA/DMA<br>Reset                   | IRST in IDMA/DMA_CS<br>(see Table 109 on<br>page 252)    | IRST_EN                                                  | IRST_DIR                                                  | IRST_IS                                                          |
| IDMA/DMA<br>Done                    | DONE in<br>IDMA/DMA_CS<br>(see Table 109 on<br>page 252) | DONE_EN                                                  | DONE_DIR                                                  | DONE_IS                                                          |
| PCI Bus Error                       | ES in PB_ERRCS<br>(see Table 97 on<br>page 238)          | PEL_EN                                                   | PEL_DIR                                                   | PEL_IS                                                           |
|                                     |                                                          | Miscellaneous Eve                                        | ents                                                      |                                                                  |
| PCI_CS Register<br>Interrupt Status | Status bit(s) in Table 70<br>on page 207 <sup>b</sup>    | PCSR_EN                                                  | PCSR_DIR                                                  | PCSR_IS                                                          |
| MailBox 3<br>Interrupt Status       | -                                                        | MB3_EN                                                   | MB3_DIR                                                   | MB3_IS                                                           |
| MailBox 2<br>Interrupt Status       | -                                                        | MB2_EN                                                   | MB2_DIR                                                   | MB2_IS                                                           |
| MailBox 1<br>Interrupt Status       | -                                                        | MB1_EN                                                   | MB1_DIR                                                   | MB1_IS                                                           |
| MailBox 0<br>Interrupt Status       | -                                                        | MB0_EN                                                   | MB0_DIR                                                   | MB0_IS                                                           |
| QBus Data<br>Parity Error           | -                                                        | QDPE_EN                                                  | QDPE_DIR                                                  | QDPE_S                                                           |

#### Table 42: Interrupt Source, Enabling, Mapping, Status and Clear bits

| Source                                                | Source Bits<br>Write 1 to clear                  | Enable Bits<br>INT_CTL (see<br>Table 120 on<br>page 269) | Mapping Bits<br>INT_DIR (see<br>Table 121 on<br>page 272) | Interrupt Status Bits<br>INT_STAT (see<br>Table 119 on page 266) |
|-------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------|
| Power State<br>Changed<br>Interrupt Status            | PME_EN PCI_PMCS<br>(see Table 85 on<br>page 224) | PSC_EN                                                   | PSC_DIR                                                   | PSC_S                                                            |
| Outbound<br>Post_List Not<br>Empty Status             | -                                                | OPNE_EN                                                  | OPNE_DIR                                                  | OPNE_S                                                           |
| Inbound<br>Post_List New<br>Entry Interrupt<br>Status | -                                                | IPN_EN                                                   | IPN_DIR                                                   | IPN_S                                                            |
| Inbound<br>Free_List Empty<br>Status                  | -                                                | IFE_EN                                                   | IFE_DIR                                                   | IFE_S                                                            |
| Outbound<br>Free_List Empty<br>Status                 | -                                                | OFE_EN                                                   | OFE_DIR                                                   | OFE_S                                                            |
| Inbound<br>Post_List Full<br>Status                   | -                                                | IPF_EN                                                   | IPF_DIR                                                   | IPF_S                                                            |
| Outbound<br>Free_List Full<br>Status                  | -                                                | OFF_EN                                                   | OFF_DIR                                                   | OFF_S                                                            |

| Table 42: Interrupt Source | , Enabling, Ma | apping, Status and | Clear bits (Continued) |
|----------------------------|----------------|--------------------|------------------------|
|----------------------------|----------------|--------------------|------------------------|

a. See also "IDMA Errors, Resets, and Interrupts" on page 95.

b. Any of the following bits in PCI\_CS: D\_PE, S\_SERR, R\_MA, R\_TA, or S\_TA.

Four software interrupt bits are provided: Software Interrupt 0 through 3. Setting a software interrupt bit (SI3, SI2, SI1, or SI0) triggers the interrupt status (see the following table) and causes the QSpan II to generate an interrupt on the QBus (QINT\_) or PCI bus (INT#), depending on the relevant mapping bit. There is no enable bit for software interrupts. The interrupt line will be driven until the status bit is cleared. To clear the status bit write a 1.

|                      | Source Bits                                 | Mapping Bits                               | Interrupt Status Bits <sup>a</sup>          |
|----------------------|---------------------------------------------|--------------------------------------------|---------------------------------------------|
|                      | (INT_CTL, see<br>Table 120 on<br>page 269)  | (INT_DIR, see<br>Table 121 on<br>page 272) | (INT_STAT,<br>see Table 119 on<br>page 266) |
| Source               | (INT_CTL2, see<br>Table 122 on<br>page 275) | -                                          | -                                           |
| Software Interrupt 0 | SI0                                         | SI0_DIR                                    | SI0_IS                                      |
| Software Interrupt 1 | SI1                                         | SI1_DIR                                    | SI1_IS                                      |
| Software Interrupt 2 | SI2                                         | SI2_DIR                                    | SI2_IS                                      |
| Software Interrupt 3 | SI3                                         | SI3_DIR                                    | SI3_IS                                      |

a. Write 1 to clear the interrupt.



Interrupts in one channel do not affect processing in the other channel.

#### 8.3.1 Interrupt Generation due to PCI Configuration Register Status Bits

QSpan II can generate an interrupt (QINT\_ or INT#) when any of the status bits in the PCI\_CS register is set.

The direction of the interrupt is controlled by the PCSR\_DIR bit in the INT\_DIR register (see Table 121 on page 272). QSpan II generates the interrupt and sets the PCSR\_IS bit in the INT\_STAT register when any of the following status bits is set (see Table 119 on page 266):

- D\_PE
- S\_SERR
- R\_MA
- R\_TA
- S\_TA
- excluding MD\_PED

The MD\_PED bit already generates an interrupt, so this functionality will not cause the PCSR\_EN status bit to be set. To clear the interrupt and interrupt status bit, write a 1 to PCSR\_IS in the INT\_STAT (see Table 119 on page 266).

## 8.4 Interrupt Acknowledge Cycle

Reading the IACK\_GEN register from the QBus causes an IACK cycle to be generated on the PCI bus (see Table 118 on page 265). The byte lanes enabled on the PCI bus are determined by SIZ[1:0] and A[1:0] of the QBus read. The address on the QBus used to access the IACK\_GEN register is passed directly over to the PCI bus during the PCI IACK cycle. However, address information is ignored during PCI IACK cycles, so this has no effect.

Reads from this register behave as delayed transfers: the QBus master is retried until the read data is latched from the PCI Target. When the IACK cycle completes on the PCI bus, the data is latched into the IACK\_GEN register, which is returned as read data when the QBus master attempts the cycle again.

Writing to this register from the QBus or PCI bus has no effect. Reads from the PCI bus return all zeros.

# 8.5 Disabling PCI Interrupts

QSpan II is a single function device, so it implements a single PCI interrupt (INT#). One restriction of this option is that it's always enabled: INT\_PIN is set to 1 in the PCI\_MISC1 register. If the system does not require the QSpan II to interrupt on the PCI bus, the QSpan II can be disabled from requesting an interrupt on the PCI bus.

The Interrupt Pin (INT\_PIN) field in PCI\_MISC1 register can be loaded from EEPROM, or programmed from the QBus side before the PCI BIOS can access this register (see Table 83 on page 222). The INT\_PIN setting does not affect the assertion of the QSpan II's INT# output. The INT\_LINE field in PCI\_MISC1 will still be R/W (default=0). Software must set this field to 0xff to indicate "unknown" or "no connection." For more information see the *PCI Local Bus Specification 2.2*.

# Chapter 9: The EEPROM Channel

This chapter describes the QSpan II's EEPROM Channel. The following topics are discussed:

- "EEPROM Configuration and Plug and Play Compatibility" on page 129
- "EEPROM I<sup>2</sup>C Protocol" on page 129
- "Mapping of EEPROM Bits to QSpan II Registers" on page 130
- "Programming the EEPROM from the QBus or PCI Bus" on page 133
- "EEPROM Access" on page 134
- "Vital Product Data Support" on page 134

### 9.1 Overview

Some QSpan II registers can be programmed by data in an EEPROM at system reset (for more information, see Table 44 on page 131). This allows board designers to perform the following:

- set identifiers for their cards on the PCI bus at reset
- enable the PCI Bus Expansion ROM Control Register
- set various address and parameters of images



If the QSpan II is configured with EEPROM or by an external QBus master using the PCI\_DIS pin, the device can boot-up as a Plug and Play compatible device (see "EEPROM Configuration and Plug and Play Compatibility" on page 129).



#### Figure 15: EEPROM Channel — Functional Diagram

QSpan II supports an additional scheme to be Plug and Play compatible without the use of an EEPROM. In this case, the power-up option, PCI Access Disabled (PCI\_DIS) is pulled high during reset (see Table 130 on page 284). This forces the QSpan II to retry all PCI access. During this time, the QBus Host can program the necessary registers for- example, the registers that are normally loaded from the EEPROM — and then write a 0 to the PCI\_DIS bit. This allows the QSpan II to accept PCI cycles.



The PCI\_DIS option can also be enabled by loading from the EEPROM. However, the EEPROM loading cannot clear the PCI\_DIS bit. Therefore, if PCI\_DIS is enabled from the EEPROM loading, then the Host must configure the QSpan II's registers before the QSpan II allows register access from the PCI bus.

QSpan II supports reads from and writes to the EEPROM.

256 bytes of data can be accessed with the EEPROM. QSpan II normally loads the first 12 bytes of data for its own programming. QSpan II can load the next 11 bytes from the EEPROM if the last three bits of the 12th byte are 010.

# 9.2 EEPROM Configuration and Plug and Play Compatibility

There are two ways to configure the EEPROM to allow the QSpan II to boot as a PCI Plug and Play compatible device:

- The EEPROM can be configured before it is placed on the board.
- The EEPROM can be configured after it is installed. In this case, the first time the QSpan II-based board boots, it will not be PCI Plug and Play compatible. You will need to program the EEPROM from either the QBus or the PCI bus (see "Programming the EEPROM from the QBus or PCI Bus" on page 133 for details).

The following sections discuss the implementation of the EEPROM.

# 9.3 EEPROM I<sup>2</sup>C Protocol

QSpan II supports the 2-wire I<sup>2</sup>C protocol, using a clock output (SCL) and a I-directional signal (SDA). If the SDA or ENID pin is asserted as 1 during a PCI bus reset (for example, RST# active), then at the conclusion of this reset the QSpan II reads 12 bytes of data from the EEPROM. QSpan II can also load the next 11 bytes from the EEPROM if the last three bits of the 12th byte are 010b.

The read of the 12 bytes from the EEPROM is performed as a Sequential Read. After the START condition the QSpan II puts out a 7-bit device select code of 1010000. The four most significant bits of the device select code for the  $I^2C$  protocol are required to be 1010. The following three bits are chip-enable signals that are 000. The chip-enable lines on the EEPROM must be tied low. QSpan II expects the data delivered from the EEPROM starting at address zero. Figure 16 shows this Sequential Read transaction.



After reset, the EEPROM port completes a STOP then a START before loading from the EEPROM.

#### Figure 16: Sequential Read from EEPROM



While the registers are being loaded from the EEPROM, all accesses to the QSpan II by an external PCI bus master are terminated with a retry. During this period, write accesses to the EEPROM programmable registers from the QBus have no effect, and reads return all zeros.



Some EEPROM devices require a write control signal. This signal should not be pulled inactive if the intention is to program the EEPROM device with the QSpan II.



If RESETI\_ is asserted when the QSpan II is reading from the EEPROM then the EEPROM's contents may not be loaded correctly.

## 9.4 Mapping of EEPROM Bits to QSpan II Registers

This section describes the mapping between EEPROM bits and the QSpan II's registers. The following registers can be programmed by the EEPROM:

- PCI Configuration (PCI\_SID register): see Table 79 on page 218
- PCI Expansion ROM (PCI\_BSROM and PBROM\_CTL registers): see Table 80 on page 219 and Table 95 on page 236
- PCI Bus Target Image 0 (PCI\_BST0 and PBTI0\_CTL registers): see Table 75 on page 214 and Table 89 on page 228
- PCI Bus Target Image 1 (PCI\_BST1 and PBTI1\_CTL registers): see Table 77 on page 216 and Table 92 on page 232
- QBus Slave Image 0 (QBSI0\_CTL and QBSI0\_AT registers): see Table 133 on page 289 and Table 138 on page 291
- PCI Configuration Space ID (PCI\_ID register): see Table 69 on page 206
- PCI Configuration Class (PCI\_CLASS register): see Table 71 on page 210
- PCI Configuration Miscellaneous 1 (PCI\_MISC1 register): see Table 83 on page 222
- Miscellaneous Control 2 (MISC\_CTL2 register): see Table 130 on page 284
- PCI Power Management Capabilities (PCI\_PMC register): see Table 84 on page 223

- PCI Configuration Base Address for Target 0 (PCI\_BST0 register): see Table 75 on page 214
- PCI Configuration Base Address for Target 0 (PCI\_BST1 register): see Table 77 on page 216

| <b>Table 44: Destination</b> | n of EEPROM Bits Read <sup>a</sup> |
|------------------------------|------------------------------------|
|------------------------------|------------------------------------|

|          | Function                              |                 |                                  |                |                |                |                |               |  |
|----------|---------------------------------------|-----------------|----------------------------------|----------------|----------------|----------------|----------------|---------------|--|
| Byte     | Bit 7                                 | Bit 6           | Bit 5                            | Bit 4          | Bit 3          | Bit 2          | Bit 1          | Bit 0         |  |
|          | PCI_SID                               |                 |                                  |                |                |                |                |               |  |
| 0        | [31]<br>(SID)                         | [30]<br>(SID)   | [29]<br>(SID)                    | [28]<br>(SID)  | [27]<br>(SID)  | [26]<br>SID)   | [25]<br>(SID)  | [24]<br>(SID) |  |
|          | PCI_SID                               |                 |                                  |                |                |                |                |               |  |
| 1        | [23]<br>(SID)                         | [22]<br>(SID)   | [21]<br>(SID)                    | [20]<br>(SID)  | [19]<br>(SID)  | [18]<br>(SID)  | [17]<br>(SID)  | [16]<br>(SID) |  |
|          | PCI_SID                               |                 |                                  |                |                |                |                |               |  |
| 2        | [15]<br>(SVID)                        | [14]<br>(SVID)  | [13]<br>(SVID)                   | [12]<br>(SVID) | [11]<br>(SVID) | [10]<br>(SVID) | [9]<br>(SVID)  | [8]<br>(SVID) |  |
|          | PCI_SID                               |                 |                                  |                |                |                |                |               |  |
| 3        | [7]<br>(SVID)                         | [6]<br>(SVID)   | [5]<br>(SVID)                    | [4]<br>(SVID)  | [3]<br>(SVID)  | [2]<br>(SVID)  | [1]<br>(SVID)  | [0]<br>(SVID) |  |
|          | Enables<br>PCI_<br>BSROM <sup>b</sup> | PBROM_CTL       |                                  |                |                |                |                |               |  |
| 4        |                                       | [22]<br>(BS)    | [21]<br>(BS)                     | [20]<br>(BS)   | [19]<br>(TC)   | [18]<br>(TC)   | [17]<br>(TC)   | [16]<br>(TC)  |  |
|          | PBROM_CTL                             |                 |                                  |                |                |                |                |               |  |
| 5        | [15]<br>(TA)                          | [14]<br>(TA)    | [13]<br>(TA)                     | [12]<br>(TA)   | [11]<br>(TA)   | [10]<br>(TA)   | [9]<br>(TA)    | [8]<br>(TA)   |  |
|          | PBROM_CTL                             |                 |                                  |                |                |                |                |               |  |
| 6        | [7]<br>(TA)                           | [6]<br>(TA)     | [5]<br>(TA)                      | [4]<br>(TA)    | [3]<br>(TA)    | [2]<br>(TA)    | [1]<br>(TA)    | [0]<br>(TA)   |  |
|          | PBROM_CTL                             |                 | Enables<br>PCI BST0 <sup>b</sup> | PBTI0_CTL      |                |                |                |               |  |
| 7        | [25]<br>DSIZE)                        | [24]<br>(DSIZE) | 101_0010                         | [27]<br>(BS)   | [26]<br>(BS)   | [25]<br>(BS)   | [24]<br>(BS)   | [6]<br>(PAS)  |  |
|          | Enables<br>PCI_BST1 <sup>b</sup>      | PBTI1_CTL       |                                  |                |                | QBSI0_CTL      |                |               |  |
| 8        | 101_0011                              | [27]<br>(BS)    | [26]<br>(BS)                     | [25]<br>(BS)   | [24]<br>(BS)   | [6]<br>(PAS)   | [31]<br>(PWEN) | [24]<br>(PAS) |  |
| QBSI0_AT |                                       |                 |                                  |                |                |                |                |               |  |
| 9        | [31]<br>(TA)                          | [30]<br>(TA)    | [29]<br>(TA)                     | [28]<br>(TA)   | [27]<br>(TA)   | [26]<br>(TA)   | [25]<br>(TA)   | [24]<br>(TA)  |  |

|      | Function         |                  |                  |                  |                  |                    |                                         |                  |  |  |
|------|------------------|------------------|------------------|------------------|------------------|--------------------|-----------------------------------------|------------------|--|--|
| Byte | Bit 7            | Bit 6            | Bit 5            | Bit 4            | Bit 3            | Bit 2              | Bit 1                                   | Bit 0            |  |  |
|      | QBSI0_AT         |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 10   | [23]<br>(TA)     | [22]<br>(TA)     | [21]<br>(TA)     | [20]<br>(TA)     | [19]<br>(TA)     | [18]<br>(TA)       | [17]<br>(TA)                            | [16]<br>(TA)     |  |  |
|      | QBSI0_AT         |                  |                  |                  |                  |                    | Enable<br>long EEPROM load <sup>c</sup> |                  |  |  |
| 11   | [7]<br>(BS)      | [6]<br>(BS)      | [5]<br>(BS)      | [4]<br>(BS)      | [1]<br>(EN)      | IONG EERKOWI IDau" |                                         |                  |  |  |
|      | PCI_ID           |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 12   | [15]<br>(DID)    | [14]<br>(DID)    | [13]<br>(DID)    | [12]<br>(DID)    | [11]<br>(DID)    | [10]<br>(DID)      | [9]<br>(DID)                            | [8]<br>(DID)     |  |  |
|      | PCI_ID           |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 13   | [7]<br>(DID)     | [6]<br>(DID)     | [5]<br>(DID)     | [4]<br>(DID)     | [3]<br>(DID)     | [2]<br>(DID)       | [1]<br>(DID)                            | [0]<br>(DID)     |  |  |
|      | PCI_ID           |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 14   | [15]<br>(VID)    | [14]<br>(VID)    | [13]<br>(VID)    | [12]<br>(VID)    | [11]<br>(VID)    | [10]<br>(VID)      | [9]<br>(VID)                            | [8]<br>(VID)     |  |  |
|      | PCI_ID           |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 15   | [7]<br>(VID)     | [6]<br>(VID)     | [5]<br>(VID)     | [4]<br>(VID)     | [3]<br>(VID)     | [2]<br>(VID)       | [1]<br>(VID)                            | [0]<br>(VID)     |  |  |
|      | PCI_CLASS        |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 16   | [7]<br>(BASE)    | [6]<br>(BASE)    | [5]<br>(BASE)    | [4]<br>(BASE)    | [3]<br>(BASE)    | [2]<br>(BASE)      | [1]<br>(BASE)                           | [0]<br>(BASE)    |  |  |
|      | PCI_CLASS        |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 17   | [7]<br>(SUB)     | [6]<br>(SUB)     | [5]<br>(SUB)     | [4]<br>(SUB)     | [3]<br>(SUB)     | [2]<br>(SUB)       | [1]<br>(SUB)                            | [0]<br>(SUB)     |  |  |
|      | PCI_CLASS        |                  |                  |                  |                  |                    |                                         |                  |  |  |
| 18   | [7]<br>(PROG)    | [6]<br>(PROG)    | [5]<br>(PROG)    | [4]<br>(PROG)    | [3]<br>(PROG)    | [2]<br>(PROG)      | [1]<br>(PROG)                           | [0]<br>(PROG)    |  |  |
|      |                  |                  |                  | PCI_I            | MISC1            |                    |                                         |                  |  |  |
| 19   | [7]<br>(MAX_LAT) | [6]<br>(MAX_LAT) | [5]<br>(MAX_LAT) | [4]<br>(MAX_LAT) | [3]<br>(MAX_LAT) | [2]<br>(MAX_LAT)   | [1]<br>(MAX_LAT)                        | [0]<br>(MAX_LAT) |  |  |

## Table 44: Destination of EEPROM Bits Read<sup>a</sup> (Continued)

|      | Function          |                                 |                  |                  |                  |                  |                  |                  |
|------|-------------------|---------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| Byte | Bit 7             | Bit 6                           | Bit 5            | Bit 4            | Bit 3            | Bit 2            | Bit 1            | Bit 0            |
|      | PCI_MISC1         |                                 |                  |                  |                  |                  |                  |                  |
| 20   | [7]<br>(MIN_GNT)  | [6]<br>(MIN_GNT)                | [5]<br>(MIN_GNT) | [4]<br>(MIN_GNT) | [3]<br>(MIN_GNT) | [2]<br>(MIN_GNT) | [1]<br>(MIN_GNT) | [0]<br>(MIN_GNT) |
|      | PCI_MISC1         | MISC_CTL2                       | PCI_PMC          |                  |                  |                  |                  |                  |
| 21   | [7]<br>(INT_PIN0) | [6]<br>(!PCI_DIS <sup>d</sup> ) | [5]<br>(PME_SP)  | [4]<br>(PME_SP)  | [3]<br>(DSI)     | [2]<br>(PM_VER)  | [1]<br>(PM_VER)  | [0]<br>(PM_VER)  |
|      | PCI_BST0          | PCI_BST1                        | Reserved         | Reserved         | Reserved         | Reserved         | Reserved         | Reserved         |
| 22   | [7] (PREF)        | [6] (PREF)                      |                  |                  |                  |                  |                  |                  |

#### Table 44: Destination of EEPROM Bits Read<sup>a</sup> (Continued)

a. The top part of each byte row indicates the register name. Bit locations within the register are in square brackets, and field names are within round brackets.

b. Unlike the other non-reserved bits read from the EEPROM, bit 7 of byte 4, bit 5 of byte 7 and bit 7 of byte 8 are not written to a QSpan II register. These bits determine whether certain other register bits are loaded from the EEPROM.

c. If the last three bits of the 12th byte are 010 then the QSpan II will read the next 11 bytes from the EEPROM. If no further loading is required, these bits must be programmed as 000.

d. PCI\_DIS: If 0, PCI\_DIS in MISC\_CTL2 is set to 1; if 1, it has no effect on the PCI\_DIS setting in the MISC\_CTL2 register.

# 9.5 Programming the EEPROM from the QBus or PCI Bus

EEPROM can be accessed from the QBus or the PCI bus, either by a read or write, using 32-bit writes to the EEPROM\_CS register. EEPROM read and write transactions are described in the following sections.

#### 9.5.1 Writing to the EEPROM

EEPROM values are loaded by the QSpan II when the QSpan II is reset. The user must reset the QSpan II after writing to the EEPROM through the QSpan II in order to load new EEPROM data written to the lower 32 bytes.

To write to the EEPROM, complete the following:

- 1. Read the EEPROM\_CS register and make sure that the EEPROM Active (ACT) bit is set to 0; this indicates prior EEPROM access has completed (see Table 129 on page 283).
- 2. Perform a 32-bit write to the EEPROM\_CS register.

This write cycle should supply the appropriate values for the ADDR[7:0] and DATA[7:0] fields, as well as setting the READ bit to 0.

Writes complete normally on the QBus and the PCI bus regardless of the state of the ACT bit. However, if the ACT bit is to 1, the write does not change the content of the EEPROM\_CS register. The master is not informed that the EEPROM\_CS register access failed due to the status of the ACT bit (see Table 129 on page 283). To make sure that the register write has been successful, the user can read from the EEPROM\_CS register after the write.

#### 9.5.2 Reading from the EEPROM

To read from the EEPROM complete the following:

- 1. Read the EEPROM\_CS register and make sure that the ACT bit is set to 0; this indicates prior EEPROM access has completed (see Table 129 on page 283).
- 2. Write the appropriate address in the ADDR[7:0] field of the EEPROM\_CS register.
- 3. Set the READ bit of the EEPROM\_CS register to 1 (if it has not already been set).

QSpan II initiates a read from the EEPROM at the address specified in the ADDR[7:0] field. The ACT bit is cleared (set to 0) when the read completes. QSpan II stores the read data in the DATA[7:0] field of the EEPROM\_CS register. Only one byte can be read at a time.

4. Read the DATA[7:0] field of the EEPROM\_CS register.

### 9.6 EEPROM Access

QSpan II supports access to the EEPROM after the QSpan II has powered up without loading from the EEPROM. To access the EEPROM using this method, set the EEPROM\_ACC bit in the MISC\_CTL2 register (see Table 130 on page 284). If the EEPROM\_ACC bit is set, the EEPROM related registers are enabled and the QSpan II can read and write to the EEPROM using the EEPROM\_CS register or the Vital Product Data (VPD) registers.

## 9.7 Vital Product Data Support

Vital Product Data (VPD) is a *PCI 2.2 Specification* feature supported by the QSpan II. VPD contains information that defines items such as hardware, software, and microcode elements of a system. VPD also provides a mechanism for storing information such as performance and failure data on a device. VPD resides in a local storage device. With the QSpan II, VPD is supported through the serial EEPROM. If an external EEPROM is not used, the VPD feature is not enabled; VPD will not be a part of the Capabilities List.

Since the lower bytes in the EEPROM contain data for setting up the QSpan II before software initialization, the lower portion of the EEPROM (first 32 bytes) is not accessible through the VPD registers. The upper 224 bytes of the 256-byte EEPROM are designated as read/write through the VPD. Valid VPD byte addresses are 0x0 --> 0xDC, assuming a 2 Kbit serial EEPROM is installed on the board.

VPD access to the EEPROM is similar to the EEPROM access implemented in QSpan II through the EEPROM\_CS register. Since they both access the same resource, only one of these mechanisms can be used at a time to access the EEPROM.

#### 9.7.1 Reading VPD Data

QSpan II implements 8 bits of address for accessing the EEPROM (maximum of 256 bytes). The VPD address must be 32-bit aligned. QSpan II will add 0x20 to the VPD address to generate an EEPROM address in the upper 224 bytes of the EEPROM. A single read access reads four consecutive bytes starting from the VPD address.

During a read access the VPD address and the VPD flag bit are written (see Table 87 on page 226). The VPD flag bit must be set to 0 to indicate a VPD read access. QSpan II sets the VPD flag bit to 1 when it has completed reading the four bytes from the EEPROM. The VPD flag bit must be polled to identify when the read is complete. Byte 0 (bits 7–0) of the VPD data register contains the data referenced by the VPD address; bytes 1–3 contain the successive bytes. If PCI\_VPD register or EEPROM\_CS register is written to prior to the flag bit being set to one, the results of the original read operation are unpredictable.

#### 9.7.2 Writing VPD Data

A write can occur to the upper 224 bytes of the EEPROM. Similar to the read, the QSpan II adds 0x20 to the VPD address to get the EEPROM address. A single write operation writes four consecutive bytes starting from the address specified by the VPD Address.

The VPD data register is written with the 4 bytes of data. Byte 0 (register bits 7–0) contains the data to be written to the location referenced by the VPD address, bytes 1–3 contain the data for the successive bytes. The VPD Address and VPD flag then must be written. The VPD flag bit must be set to 1 to indicate a VPD write. The VPD flag bit must be polled to determine when the write to the EEPROM is completed. QSpan II sets the VPD flag bit to 0 when the write is completed. The PCI\_VPD or EEPROM\_CS register must not be written while a write operation is taking place, otherwise results are unpredictable.

If a read or write is attempted to a VPD address above 0xE0, then the QSpan II does not perform any EEPROM access, and the VPD address will contain the previous value.

# Chapter 10: I<sub>2</sub>O Messaging Unit

This chapter discusses the  $I_2O$  Messaging Unit capabilities of the QSpan II. The following topics are described:

- "Inbound Messaging" on page 138
- "Outbound Messaging" on page 139
- "I<sub>2</sub>O Operation" on page 140
- "Summary of I<sub>2</sub>O Operations" on page 140
- "I<sub>2</sub>O Interrupts" on page 143

### 10.1 Overview

QSpan II's I<sub>2</sub>O Messaging Unit reduces Host processor utilization by using an I/O processor to complete I/O transactions. QSpan II is compliant with  $I_2O$  Specification 1.5.

QSpan II complies with the I<sub>2</sub>O specification by enabling intelligent I/O cards — also called IOP agents — to implement four FIFOs in QBus memory (see Figures 18 and 17). These FIFOs queue Message Frame Addresses (MFAs) which point to message frame locations. There are two FIFOs for inbound messages and two FIFOs for outbound messages: Inbound Free\_List FIFO (IF\_FIFO), Inbound Post\_List FIFO (IP\_FIFO), Outbound Free\_List FIFO (OF\_FIFO), and Outbound Post\_List FIFO (OP\_FIFO).

There are two pointers for each circular FIFO or queue: Top, referred to as Tail in the  $I_2O$  Specification; and Bottom, referred to as Head in the  $I_2O$  Specification. Therefore, there are eight pointer registers for the four FIFOs in QSpan II register space. These pointers are offsets from a fixed QBus address (QBus\_I<sub>2</sub>O\_Base\_Address or QIBA). QIBA is aligned to a 1 Mbyte boundary. The four I<sub>2</sub>O FIFOs must be the same size; the start address for each FIFO must also be aligned to the FIFO size boundary. Writes to the queue add an MFA to the Top of the FIFO, and reads draw an MFA from the Bottom of the FIFO.



Figure 17: I<sub>2</sub>O Messaging Unit — Functional Diagram

### 10.2 Inbound Messaging

The Inbound Post\_List FIFO (IP\_FIFO) contains MFAs for message frames that are sent from the host, or other IOPs on the PCI bus, to QBus memory. The Inbound Free\_List FIFO (IF\_FIFO) contains MFAs for message frames that are free to be filled by the sender. The sender, which can be either the host or other IOPs, receives the MFA from the Bottom of the IF\_FIFO and writes a message to the shared QBus memory at the address pointed to by the MFA. The sender then posts the MFA for the message frame in the inbound queue register, which is at offset 0x040 from the I<sub>2</sub>O PCI Base Address Register I<sub>2</sub>O\_BAR at offset 0x010.

When this occurs, the QSpan II writes this MFA to the Top of the Inbound Post\_List FIFO and generates a QBus interrupt, if enabled. The Host (for example, MPC860) then picks up the MFA from the Bottom of the Inbound Post\_List FIFO, processes the message, and then releases the MFA by posting it to the Top of the Inbound Free\_List FIFO. The PCI host reads from the Inbound queue (offset 0x040) to see if there is an MFA available for a new posting. If the Inbound Free\_List FIFO is empty, the QSpan II returns 0xFFFF\_FFFF to the PCI Host or IOP on the PCI bus.

#### Figure 18: I<sub>2</sub>O Implementation



**QBus High Memory Address** 

**QBus Low Memory Address** 

## 10.3 Outbound Messaging

The Outbound Post-List FIFO (OP\_FIFO) contains MFAs for message frames sent to system memory from the QBus Host. The Outbound Free-List FIFO (OF\_FIFO) contains MFAs for message frames that are free to be filled by the QBus Host. The QBus Host gets an MFA from the Bottom of the Outbound Free-List FIFO, writes a message to system memory and then posts the MFA to the Top of the OP\_FIFO. QSpan II generates a PCI interrupt (if enabled) when an MFA is posted. The host accesses the oldest outbound MFA by reading the outbound queue. The outbound queue is offset 0x044 from the I<sub>2</sub>O\_BAR at offset 0x010.

QSpan II then supplies the data from the Bottom of the Outbound Post-List FIFO. If the Outbound Post-List FIFO is empty, the QSpan II returns 0xFFFF\_FFFF to the PCI Host or IOP on the PCI bus. The PCI host allocates available system message frames to the QBus Host by writing an available MFA to the outbound queue at offset 0x044. QSpan II then writes this MFA to the Top of the Outbound Free-List FIFO in QBus memory.

# 10.4 I<sub>2</sub>O Operation

When the QSpan II is enabled for  $I_2O$  operation — I2O Enable (I2O\_EN) in register I2O\_CS — the base address register for PCI Target Image 0 (PCI\_BST0) is moved to the first base address register in the Configuration space (offset 0x010), and is renamed I2O\_BAR. The base address register for accessing the QSpan II registers from PCI (PCI\_BSM) is then moved from offset 0x010 to 0x018 (for more information, see "I<sub>2</sub>O Messaging Unit Initialization" on page 392). The QBus translation address and other QBus options can be set in PBTI0\_CTL and PBTI0\_ADD for message passing from the Host to the QBus memory. The bottom 4 Kbytes of the I2O\_BAR is not translated into QBus memory.

In this 4 Kbyte region, 16 bytes are predefined for  $I_2O$  operation, offsets 0x030 and 0x034 are used for system interrupt generation, and offsets 0x040 and 0x044 are defined as the location of the Inbound and Outbound queues. Each inbound MFA is the offset between the start of the memory region specified by the  $I_2O$  base address Configuration register (I2O\_BAR) and the start of the message. The inbound MFAs must be above the 4 Kbyte region (for example, Inbound MFAs must be greater than FFFh). Each outbound MFA is specified as the offset from Host memory location (0000\_0000h) to the start of the message frame in shared Host memory.

# 10.5 Summary of I<sub>2</sub>O Operations

#### 10.5.1 Initialization

The following initialization operation allows the QSpan II to take part in  $I_2O$  operations:

 The QBus Host reserves a number of memory locations in its local memory to hold inbound I<sub>2</sub>O messages. The locations do not have to be contiguous. It then creates a FIFO (IF\_FIFO) that contains the address to these memory locations (MFAs). It creates another FIFO (IP\_FIFO) that contains the Inbound Post\_List MFAs. The QBus Host then creates two more circular FIFOs: OF\_FIFO and OP\_FIFO.

All four FIFOs must be the same size. They can be anywhere in a 1 Mbyte window (from the base address defined by QIBA in I2O\_CS register), without overlapping. The four FIFOs are required to be in the same 1 Mbyte window so that the upper 12 bits ([31..20]) are the same for the eight pointers maintained by the QSpan II.

The QBus Host then programs the Inbound Free\_List pointers in the QSpan II registers. The I<sub>2</sub>O Inbound Free\_List Bottom Pointer (IIF\_BP) must point to the I<sub>2</sub>O location in the Inbound Free\_List FIFO (for example, if the location of IF\_FIFO is at QIBA, then IIF\_BP = 0). The I<sub>2</sub>O Inbound Free\_List Top Pointer (IIF\_TP) must point to the first free entry (for example, last available MFA + 1).

If the size of the FIFO is 256, and there are 200 MFAs, then IIF\_TP = 201 \* 4 = 804 (0x324). The Inbound Post\_List Top and Bottom (IIP\_TP, IIP\_BP) pointers must also be programmed (for example, if the IP\_FIFO starts at (QIBA + 2048), then IIP\_BP = IIP\_TP = 2048). The four Outbound pointers: I<sub>2</sub>O Outbound Post\_List Top Pointer (IOP\_TP), I<sub>2</sub>O Outbound Post\_List Bottom pointer (IOP\_BP), I<sub>2</sub>O Outbound Free\_List Top Pointer (IOF\_TP), I<sub>2</sub>O Outbound Free\_List Bottom Pointer (IOF\_BP), must be programmed to their respective starting offset—from the QIBA (for example, if OP\_FIFO starts at (QIBA + 4096) and OF\_FIFO starts at (QIBA + 6144), then IOP\_BP = IOP\_TP = 4096, and IOF\_BP = IOF\_TP = 6144).

If the QBus I<sub>2</sub>O base address is  $0xA000_0000$ , then QSpan's I<sub>2</sub>O registers will contain the following for the above settings. I2O\_CS: QIBA = 0xA00, FIFO\_SIZE = 0x0IIF\_BP =  $0xA000_0000$ , IIF\_TP =  $0xA000_0324$  (IF\_FIFO contains 200 MFAs) IIP\_BP =  $0xA000_0800$ , IIP\_TP =  $0xA000_0800$  (IP\_FIFO is empty) IOP\_BP =  $0xA000_1000$ , IOP\_TP =  $0xA000_1000$  (OP\_FIFO is empty) IOF\_BP =  $0xA000_1800$ , IOF\_TP =  $0xA000_1800$  (OF\_FIFO is empty).



If the Top and Bottom pointers are equal, the FIFO can either be full or empty. QSpan II assumes that the FIFO is empty when the pointers are equal at start-up. To indicate that the FIFO (for example, the IF\_FIFO) is full at start-up, the QBus Host needs to first program the Top pointer to the top of the FIFO, and then increment it by four. This places the Top pointer at the bottom of the FIFO.

- 3. The QBus Host enables I<sub>2</sub>O (bit I2O\_EN in register I2O\_CS) and enables access from the PCI bus to the QSpan II (clear bit PCI\_DIS in register MISC\_CTL2).
- 4. The Host, with a mechanism similar to step 1 above, reserves a number of memory locations to hold Outbound I<sub>2</sub>O messages. It then writes the address of these locations (MFAs) to the OF\_FIFO (see "Inbound I<sub>2</sub>O Message" on page 142. This causes the QSpan II to update the IOF\_TP pointer (for example, if the Host writes 100 MFAs into OF\_FIFO, then IOF\_TP = 6144 + 4\*101 = 6548).

QSpan II's registers now contain the following: IOF\_BP = 0xA000\_1800 IOF\_TP = 0xA000\_1994 (OF\_FIFO contains 100 MFAs)

#### 10.5.1.1 Inbound I<sub>2</sub>O Message

- 1. The host gets an MFA by reading from offset 0x040 from the first Base Address Register (I2O\_BAR). This causes the QSpan II to generate a QBus delayed read cycle at address (IIF\_BP = 0xA000\_0000) to get the first MFA. When the read data is available, the QSpan II returns the data to the Host. QSpan II also increases the IIF\_BP pointer by 4 (IIF\_BP = 0xA000\_0004).
- 2. The Host writes the  $I_2O$  message to the shared local memory through the QSpan II using the offset specified by the MFA from I2O\_BAR.
- 3. The Host then places the MFA into the IP\_FIFO (for example, the Host writes to offset 0x040 with MFA as the data). This causes the QSpan II to generate a QBus delayed write cycle at address (IIP\_TP = 0xA000\_0800) with MFA as the data. QSpan II also increases the IIP\_TP pointer by four (IIP\_TP = 0xA000\_0804). QSpan II can be programmed to generate a QBus interrupt when the IP\_FIFO is written with a new MFA. It also sets the Inbound Post\_List New Entry Interrupt Status (IPN\_IS) bit in the INT\_STAT register (see Table 119 on page 266).
- 4. The QBus Host is notified of the Inbound message either through the QBus interrupt, or by polling IP\_FIFO Empty Status (IP\_E) bit in the I2O\_CS register (see Table 109 on page 252). It then reads the QSpan II's IIP\_BP register to get the next Bottom pointer in the Inbound Post\_List FIFO (this is a normal QBus register access). The QBus Host can then get the MFA for the message and process the message. The QBus Host must complete a write to increment the IIP\_BP by four (IIP\_BP = 0xA000\_0804) to point to the next MFA in the IP\_FIFO.



The incrementing is completed by the QBus Host. It writes the new value of the pointer to the IIP\_BP register.

5. The QBus Host releases the used MFA by writing the MFA back to the IF\_FIFO (at the Top pointer). It must also increment the QSpan II's IIF\_TP pointer by four (IIF\_TP = 0xA000\_0328) using a QBus register access.

#### 10.5.1.2 I<sub>2</sub>O Outbound Message

- 1. The QBus Host gets a pointer to the location of an MFA for the outbound message by reading the QSpan II's Outbound Free\_List Bottom Pointer (IOF\_BP). It needs to increase the IOF\_BP by four (IOF\_BP = 0xA000\_1804) to point to the next MFA (these are done through QBus register access).
- 2. The QBus Host writes the message to the host memory location pointed by the MFA.
- 3. The QBus Host places the MFA in the OP\_FIFO (using the Top pointer). It also needs to increment the QSpan II's Outbound Post\_List Top Pointer register (IOP\_TP) by four (IOP\_TP = 0xA000\_1004). QSpan II generates a PCI interrupt (if not masked by the bit OP\_IM in register I2O\_OPIM) when the OP\_FIFO is not empty and sets the OP\_ISR bit in the I2O\_OPIS register (see Table 150 on page 300).

- 4. The Host is notified of the Outbound message either through the PCI interrupt or by polling the status bit. It then initiates a PCI memory read access at offset 0x044 from the first BAR in the QSpan II's Configuration space (I2O\_BAR) to get the MFA. This causes the QSpan II to generate a QBus delayed read cycle at address (IOP\_BP = 0xA000\_1000). When the read data is returned to the QSpan II, the data is passed back to the Host. QSpan II also increases the IOP\_BP by four (IOP\_BP = 0xA000\_1004). The OP\_ISR status bit is cleared if the OP\_FIFO is empty.
- 5. The Host processor then reads the message pointed by the MFA and consumes it.
- 6. The Host then releases the used MFA by writing to offset 0x044 from I2O\_BAR (see Table 74 on page 213).

This causes QSpan II to generate a QBus write cycle at address ( $IOF_TP = 0xA000_1994$ ) with the MFA as the data. Upon completion of the write, the QSpan II increments the IOF\_TP by four ( $IOF_TP = 0xA000_1998$ ).



The four pointers updated automatically by QSpan II are IIF\_BP, IIP\_TP, IOP\_BP and IOF\_TP. When the pointer is at the top of the FIFO, the next increment puts it at the bottom of the FIFO: the increments are accomplished on a modulo boundary of the FIFO\_SIZE. The other four pointers (IIF\_TP, IIP\_BP, IOP\_TP and IOF\_BP) must be incremented by the QBus Host. This is achieved by completing a QBus register write with the new pointer value. The two Top pointers incremented by the QSpan II (IIP\_TP and IOF\_TP) are not incremented if the corresponding FIFO becomes full. Likewise, the two Bottom pointers (IIF\_BP and IOP\_BP) are not incremented if the corresponding FIFO is empty.

## 10.6 I<sub>2</sub>O Interrupts

QSpan II provides status bits in  $I_2O$  Control and Status (I2O\_CS) register for each of the four  $I_2O$  list FIFOs to indicate if they are empty or full (see Table 100 on page 242). A PCI interrupt can be generated when the Outbound Post\_List FIFO contains MFAs (for example, when the Outbound Post\_List FIFO is not empty). The interrupt can be masked by setting the OP\_IM bit in I2O\_OPIM register. The corresponding status bit is in I2O\_OPIS register. A copy of this status bit is also provided in the INT\_STAT register.

To generate a QBus interrupt when a new MFA is posted into the Inbound Post\_List FIFO, set the IPN\_EN bit in INT\_CTL (see Table 120 on page 269). If the interrupt is generated, the IPN\_IS status bit is set. The QBus interrupt can be negated by writing a 1 to the IPN\_IS status bit.

The following four conditions can also cause external interrupts: Inbound Free\_List FIFO empty, Outbound Free\_List FIFO empty, Inbound Post\_List FIFO full and Outbound Free\_List FIFO full. These interrupts are enabled by setting the corresponding bits in the INT\_CTL and INT\_DIR registers.

# Chapter 11: PCI Bus Arbiter

This chapter explains the QSpan II's PCI bus arbiter. The following topics are discussed:

- "Arbitration Scheme" on page 146
- "Bus Parking" on page 148

### 11.1 Overview

QSpan II has an integrated PCI bus arbiter with dedicated support for the QSpan II PCI master, and up to seven external Masters (see Figure 19). The PCI bus arbiter uses a fairness algorithm to prevent deadlocks.

QSpan II's PCI bus arbiter is enabled at power-up if the PCI\_ARB\_EN pin is sampled high at the negation of Reset. The request lines of the external bus Masters can be connected to the REQ# and EXT\_REQ#[6:1] pins. Any unused request pins must be externally pulled up. The grant lines of the external bus Masters can be connected to GNT# and EXT\_GNT#[6:1]. If an external arbiter is used, the QSpan II uses the REQ#/GNT# line to acquire the PCI bus. QSpan II drives the unused EXT\_REQ#[6:1] and EXT\_GNT#[6:1] high when an external arbiter is used.



Figure 19: PCI Bus Arbiter — Functional Diagram

### 11.2 Arbitration Scheme

To maintain arbitration fairness, the PCI bus arbiter assigns bus masters to one of two priority levels: Level 0 or Level 1 (see Figure 20). Bus Masters assigned to Level 0 are of lower priority than Masters assigned to Level 1. Bus Masters assigned to the same level have equal priority in the arbitration scheme. Bus Masters on Level 0 get a single access during each round-robin arbitration on Level 1. Arbitration is performed among Masters asserting request to the QSpan II's PCI bus arbiter. The bus arbiter removes a grant to a master if it has not started an access after its grant has been issued and the bus is in the idle state for 16 clock cycles.



Figure 20: PCI Bus Arbiter — Arbitration Scheme

To assign a priority level, set the Arbitration Level priority (Mx\_PRI) bit in the PARB\_CTL register (see Table 131 on page 287). Background arbitration is implemented, which means arbitration occurs during the previous access so that no PCI cycles are consumed due to arbitration; except when the bus is in the idle state.

In general, the arbiter negates the current grant when the current master asserts FRAME#. It issues a new grant when the current master negates FRAME# if there is a pending new request. If the bus is idle when a new request is received, the arbiter negates the current grant, then issues a new grant on the next clock.

### 11.3 Bus Parking

Bus parking is supported on the last bus master or on a pre-determined bus master. This depends on the setting of the PCI Bus Parking Scheme (PARK) bit and the Select Master for PCI Bus Parking (BM\_PARK) bit in the PARB\_CTL register (see Table 131 on page 287). If PARK is set to 0, the last bus master is parked. If PARK is set to 1, the bus master identified by BM\_PARK is parked.

Bus parking is performed when there are no requests and the bus is idle.

# Chapter 12: CompactPCI Hot Swap Friendly Support

This chapter discusses CompactPCI Hot Swap Friendly capabilities of the QSpan II. The following topics are explained:

- "Hot Swapping with the QSpan II" on page 150
- "CompactPCI Hot Swap Card Insertion" on page 151
- "CompactPCI Hot Swap Card Extraction" on page 153

### 12.1 Overview

QSpan II is a CompactPCI Hot Swap Friendly Device (see Figure 21). *CompactPCI's Hot Swap Specification* defines a process for installing and removing adapter boards without adversely affecting a running system. QSpan II supports programmable access to Hot Swap services. This allows system reconsideration and fault recovery to take place with no system down time and minimum operator interaction.

Hot Swap defines three classes of devices: Hot Swap Capable, Hot Swap Friendly and Hot Swap Ready. Hot Swap Friendly device requirements include the following:

- Hot Swap Control/Status Register and Extended Capabilities Pointer: This supports the use of the Hot Plug System Driver.
- Support of the Hot Swap event pin ENUM#: This signal informs the Host that the configuration of the system has changed; that is, the card has been inserted or is about to be removed.
- Support for sensing the switch connected to the ejector latch, and controlling the LED: Two pins are used for this functionality, HS\_SWITCH (Input) to detect the state of the ejector latch and HS\_LED (Open-Drain Output) to control the LED.



#### Figure 21: CompactPCI Hot Swap — Functional Diagram

### 12.2 Hot Swapping with the QSpan II

The *CompactPCI Hot Swap Specification* defines a switch located in the ejector handle that indicates to QSpan II if the ejector handle is open or closed. The specification also defines a LED that can be controlled by hardware and software, by setting the LED On/Off (LOO) bit in the CPCI\_HS register (see Table 86 on page 225). QSpan II drives the HS\_LED signal low to turn on the LED during the Physical and Hardware Connection process (when HS\_HEALTHY\_ is high), and when the LOO bit is set, to minimize the number of external components. A blue LED with an internal resistor can be directly connected between the 5V rail and the HS\_LED pin.

A low value on HS\_SWITCH input indicates that the ejector latch is open. A high value on HS\_SWITCH indicates that the ejector latch is closed. QSpan II tri-states the HS\_LED signal low when the LED is supposed to be turned-off during normal operation.

QSpan II also monitors the board healthy signal (HEALTHY# in the Hot Swap specification). This connects to QSpan II's input signal, HS\_HEALTHY\_. QSpan II internally OR's the HS\_HEALTHY\_ and PCI Reset (RST#) to generate an internal reset. When HS\_HEALTHY\_ is high, the QSpan II is in reset and all outputs are tri-stated (except for HS\_LED). QSpan II will drive out RESETO\_ low due to a PCI Reset (RST# low) if HS\_HEALTHY\_ is low, indicating that the back-end is powered up. QSpan II samples the power-up option pins (BDIP\_, PCI\_DIS, etc.) on HS\_HEALTHY\_ going low (as well as RST# going high or RESETI\_ going high).

### 12.3 CompactPCI Hot Swap Card Insertion

When a CompactPCI add-in card containing QSpan II is inserted into a powered-on system, power and ground are first supplied to the QSpan II. The remaining subsystem components do not have power. From the long pins, the HEALTHY# signal is generated and applied to QSpan II (HS\_HEALTHY\_). This causes the QSpan II to generate an internal reset, to drive HS\_LED low, and to tri-state all other outputs.

When the board is fully inserted and power is supplied to the rest of the subsystem (or back-end), the HS\_HEALTHY\_ can be asserted low, causing the QSpan II to come out of reset. If the PCI Reset (RST#) is active low at this time, the QSpan II drives out RESETO\_ low until RST# is negated. On the assertion of HS\_HEALTHY\_ or the negation of RST# (if RST# was active when HS\_HEALTHY\_ was asserted), the QSpan II loads from the EEPROM (if enabled). After the EEPROM loading, the QSpan II sets the Insertion (INS) bit in CPCI\_HS register, signals the Host using ENUM# (if enabled), and accepts Configuration cycles from the Host.

QSpan II can also be set — using a power-up option, PCI\_DIS — to hold off asserting ENUM# and retry Configuration cycles while the QBus Host programs the QSpan II's Configuration registers. At the end of this programming, the PCI\_DIS bit in the MISC\_CTL2 register (see Table 130 on page 284) can be cleared to enable the QSpan II to set the INS bit, to assert ENUM#, and to accept Configuration cycles from the Host.

The Host can clear ENUM# by writing to the INS or EIM bit in CPCI\_HS register. The Host can then configure the QSpan II-based add-in card.

| Event                                    | HS_<br>HEALTHY_ | ENUM# | HS_LED | HS_SWITCH | LED | INS | EXT | LOO | EIM |
|------------------------------------------|-----------------|-------|--------|-----------|-----|-----|-----|-----|-----|
| Long pins<br>connect                     | High            | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| Medium pins<br>connect                   | High            | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| Short pins connect                       | High            | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| HS_<br>HEALTHY_<br>asserted <sup>a</sup> | Low             | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| Turn off LED                             | Low             | Z     | Z      | open      | off | 0   | 0   | 0   | 0   |
| Close Ejector<br>latch                   | Low             | Z     | Z      | closed    | off | 0   | 0   | 0   | 0   |
| Drive ENUM#                              | Low             | L     | Z      | closed    | off | 1   | 0   | 0   | 0   |
| Host clears<br>ENUM#                     | Low             | Z     | Z      | closed    | off | 0   | 0   | 0   | 0   |

 Table 45: Insertion Sequence

a. QSpan II will load from external EEPROM, if enabled.

Table Legend of Insertion Sequence:

•  $HS\_LED = L \Rightarrow LED$  on

 $HS\_LED = Z \Rightarrow LED \text{ off}$ 

•  $HS_HEALTHY_ = High \Rightarrow Back-end powered down$ 

 $HS\_HEALTHY\_ = Low \Rightarrow Back-end powered up$ 

• The bits INS, EXT, LOO and EIM are defined in CPCI\_HS register.



#### Figure 22: Hot Swap Card Insertion<sup>1</sup>

### 12.4 CompactPCI Hot Swap Card Extraction

The extraction process is signaled by opening the ejector handle; this causes the HS\_SWITCH to be low. When QSpan II detects the falling edge on HS\_SWITCH, it starts the extraction process. It sets the EXT bit in CPCI\_HS (see Table 86 on page 225) and asserts ENUM#, if it is enabled.

After sensing ENUM# or detecting the EXT bit set in CPCI\_HS (from polling), the Host software writes to the EXT bit to clear the EXT bit and negate ENUM#. It also brings the card to a quiescent state and then writes to the LOO bit to turn on the LED. This indicates to the operator that the board is ready to be extracted.

<sup>1.</sup> This graphic is from the CompactPCI Hot Swap Specification.

As the board is removed from the system, the short pin breaks contact and the HS\_HEALTHY\_ pin is negated, causing the QSpan II to tri-state the outputs (except HS\_LED, to keep the LED on until the long pins disengage).



Instead of taking the board out when the LED is on, the operator can close the ejector latch to indicate an insertion process. In this case, the insertion sequence will begin from event Close Ejector Latch, and the QSpan II will not load from the EEPROM unless HS\_HEALTHY\_ is negated or RST# is asserted prior to closing the ejector latch.

| Event                            | HS_<br>HEALTHY_ | ENUM# | HS_LED | HS_SWITCH | LED | INS | EXT | L00 | EIM |
|----------------------------------|-----------------|-------|--------|-----------|-----|-----|-----|-----|-----|
| Normal<br>Operation              | L               | Z     | Z      | closed    | off | 0   | 0   | 0   | 0   |
| Ejector Open                     | L               | Z     | Z      | open      | off | 0   | 0   | 0   | 0   |
| Drive ENUM#                      | L               | L     | Z      | open      | off | 0   | 1   | 0   | 0   |
| Host detects<br>ENUM#            | L               | L     | Z      | open      | off | 0   | 1   | 0   | 0   |
| Host clears<br>ENUM#             | L               | Z     | Z      | open      | off | 0   | 0   | 0   | 0   |
| Host sets LOO                    | L               | Z     | L      | open      | on  | 0   | 0   | 1   | 0   |
| Short pins<br>break <sup>a</sup> | Н               | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| Medium pins<br>break             | Н               | Z     | L      | open      | on  | 0   | 0   | 0   | 0   |
| Long pins<br>break               | Х               | Х     | х      | Х         | Х   | Х   | Х   | Х   | Х   |

 Table 46: Extraction Sequence

a. The card can be inserted at this point, then the insertion process is started from "Close Ejector Latch" of the insertion sequence.

Table Legend of Extraction Sequence:

•  $HS\_LED = L --> LED On$ ,

 $HS\_LED = Z --> LED Off.$ 

- The bits INS, EXT, LOO and EIM are defined in CPCI\_HS register.
- HS\_HEALTHY\_ = H --> Back-end powered down,

 $HS_HEALTHY_ = L --> Back-end powered up$ 



Figure 23: Hot Swap Card Extraction<sup>1</sup>

<sup>1.</sup> This graphic is from the CompactPCI Hot Swap Specification.

# Chapter 13: PCI Power Management Event Support

This chapter explains PCI Power Management Support for the QSpan II. It focusses on the Power Management Support output signal (PME#).

### 13.1 Overview

QSpan II provides a PCI Power Management interface that is compliant with *PCI Bus Power Management Interface Specification 1.1.* This interface enables the operating system to control the hardware — an add-in card, for example — that implements power saving features in a platform-independent manner. The Power Management interface supports the minimum requirements of powered-up and sleep, or low power, states.

QSpan II does not implement any power saving features in silicon; it merely passes the Power Management information between the Host OS and the I/O subsystem. The Power Management registers can be loaded from the EEPROM or programmed by the QBus Host before initialization by the Host.

### 13.2 Power Management Event (PME#) Support

The QSpan II provides support for the PME# output signal. This signal is asserted to request a change in its current power management state, and/or to indicate that a power management event has occurred.

QSpan II asserts PME# when the PME\_EN bit is set to 1 in the Power Management Control and Status (PCI\_PMCS) register, and if the Power State bits (PWR\_ST in PCI\_PMCS) are written to the value in PME\_support field in PCI\_PMCS register by the QBus Host. The PME Status bit in PCI\_PMCS is set in the above case regardless of the setting of PME\_EN. QSpan II negates PME# if the PME Status bit is cleared or PME\_EN bit is disabled.



PME# has additional electrical requirements beyond standard an open drain signal that allows it to be shared between devices which are powered off, and those that are powered on. This isolation circuitry must be implemented externally on the add-in card.

Transition between the different power states of the add-in card can be initiated by either the Host or the QBus Host writing to the Power State bits in the Power Management Control and Status Register (PCI\_PMCS). QSpan II provides multiple options to allow maximum flexibility:

- D0 to D3hot Transition
  - a. Host initiated:

QSpan II generates a QINT\_ if PSC\_EN bit in INT\_CTL register is set.

b. QBus Host initiated:

QSpan II sets PME\_ST bit in PCI\_PMCS register (if PME\_SP[3]=1, in PCI\_PMC register); it also asserts PME# (if PME\_EN=1, in PCI\_PMCS).

- D3hot to D0 Transition
  - a. Host Initiated:

If the add-in card needs to be reset, then setting the Power State Change (PSC\_QRST) bit in MISC\_CTL2 register causes the QSpan II to generate an internal QSpan II reset. It also causes RESETO\_ signal to be asserted (for 512 to 1024 PCI clocks). QSpan II will load from EEPROM, if enabled.

If the add-in card should not be reset, then the QSpan II can be programmed to generate a QINT\_ (PSC\_EN bit is set in INT\_CTL register).

b. QBus Host initiated (QBus Host powered-up and configured):

QBus Host writes to the PWR\_ST bits in PCI\_PMCS register to change the power state. QSpan II then sets PME\_ST bit in PCI\_PMCS register (if PME\_SP[0]=1, in PCI\_PMC register), and it also asserts PME# (if PME\_EN=1, in PCI\_PMCS).

c. Add-in card initiated (QBus Host in sleep-mode):

QSpan II can be programmed to generate a PME# from the assertion of QINT\_ in the D3hot Power state (if QINT\_PME=1, in MISC\_CTL2 register, PME\_SP[3]=1, in PCI\_PMC and PME\_EN=1, in PCI\_PMCS). PME\_ST bit will also be set.

The Host can then write to the PWR\_ST bits in PCI\_PMCS to change it to D0, and generate an add-in card reset.

For more information about PCI power management states, see the PCI Bus Power Management Interface Specification 1.1.

# Chapter 14: Reset Options

This chapter discusses Reset options for the QSpan II. The following topics are examined:

- "Types of Resets" on page 159
- "Configuration Options at Reset" on page 161

### 14.1 Types of Resets

QSpan II can be reset from the QBus or the PCI bus through hardware. QSpan II uses four pins and one register for reset operation. The reset pins are listed in Table 47.

| Pin Name    | Interface | Direction | Function                                                                                                                                                                                                                                  |
|-------------|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RST#        | PCI       | Input     | Resets all the QSpan II circuits and registers and<br>asserts RESETO_ when HS_HEALTHY_ is low.<br>RESETO_ remains asserted until RST# is released.<br>Also clears the SW_RST bit in the MISC_CTL (see<br>Table 127 on page 280) register. |
| RESETI_     | QBus      | Input     | Resets most of the QSpan II circuits and registers (see Appendix A: "Registers" on page 199)                                                                                                                                              |
| RESETO_     | QBus      | Output    | Resets devices on the QBus                                                                                                                                                                                                                |
| HS_HEALTHY_ | PCI       | Input     | This input indicates the state of the back-end system.                                                                                                                                                                                    |

Table 47: Hardware Reset Mechanisms



The term Reset is used when PCI Reset (RST#) or QBus Reset input RESET1\_ is driven low or HS\_HEALTHY\_ is driven high.

The QBus Software Reset Control (SW\_RST) bit in the MISC\_CTL register (see Table 127 on page 280) controls the QBus Reset output (RESETO\_). One of the uses of this mechanism is to keep the QBus in reset while an operating system and driver are downloaded to on-board memory. When a 1 is written to the SW\_RST bit, the QSpan II asserts RESETO\_ and keeps it asserted until the software reset state is terminated.

There are three ways to cause the QSpan II to terminate the software reset state:

- 1. Clear the SW\_RST bit by writing 0 to it. In this case, RESETO\_ is immediately negated.
- 2. Assert RESETI\_. In this case, the SW\_RST bit is immediately cleared (set to 0) and RESETO\_ is immediately negated.
- 3. Assert RST#. In this case, SW\_RST is immediately cleared (set to 0), however RESETO\_ continues to be asserted until RST# is negated.



We do not recommend RESETO\_ being looped back to RESETI\_. In addition, asserting the SW\_RST bit does not cause an internal reset of the QSpan II.

#### 14.1.1 PCI Transactions during QBus Reset

Assertion of RESETI\_ may interfere with the QSpan II's response to PCI Masters. If a PCI master attempts to access the QSpan II while RESETI\_ is asserted, the QSpan II will not decode the incoming cycle and a Master-Abort will occur on the PCI bus. If the QSpan II has already been selected by a PCI master (QSpan II has asserted DEVSEL#), then the QSpan II will immediately negate DEVSEL#, but TRDY# and STOP# will not be asserted by the QSpan II.

#### 14.1.2 IDMA Reset

IDMA reset issues are discussed in "IDMA Errors, Resets, and Interrupts" on page 95.

#### 14.1.3 Clocking and Resets

The PCLK can operate anywhere from DC to 33 MHz. The maximum QCLK frequency depends on the host processor. For MPC860 applications, the maximum QCLK frequency is 50 MHz. For MC68360 applications, the maximum frequency is 33 MHz. The QCLK input is not required to be operating to successfully complete QSpan II resistor accesses from the PCI bus. QSpan II supports asynchronous assertion and negation of Resets. Refer to the tables in "Signals and DC Characteristics" on page 183 for a description of the state of each QSpan II pin after reset.

When a PCI reset (RST#) is asserted and HS\_HEALTHY\_ is low, the QSpan II's RESETO\_ signal will be asserted and negated as shown in Appendix B: "Timing" on page 305.

The QCLK and PCLK inputs are necessary for software resets. That is, these clocks are required in order for the QSpan II to negate RESETO\_. This is due to the fact that for a software reset, the QSpan II's registers must be accessed to cause RESETO\_ to negate. If the QCLK or PCLK input stops toggling then it is impossible to write to the QSpan II's registers to negate RESETO\_.



QSpan II's QCLK input must be identical to the QBus processor's clock source if transactions are occurring on the QBus. Many applications use an external low skew PLL clock buffer to generate the clock outputs for the board (for example, QCLK input for QSpan II). If the buffer's clock outputs are not locked to the clock input frequency, then transactions cannot occur on the QBus — QSpan II must not detect AS\_ or TS\_ being asserted.

### 14.2 Configuration Options at Reset

The following QSpan II configuration options can be determined at Reset:

- whether the QSpan II is enabled as a PCI bus master
- the master and slave modes of the QBus, which determines the type of cycles that the QSpan II can generate as a master and accept as a slave
- whether the QSpan II loads registers from an EEPROM at reset (see "EEPROM Loading" on page 162 and "PCI Register Access Option" on page 162)
- the test mode (see "Test Mode Pins" on page 163)
- PCI access to QSpan II registers
- PCI bus arbiter functionality

#### 14.2.1 PCI Bus Master Reset Option

If BM\_EN/FIFO\_RDY\_ is sampled as high while reset is asserted, the QSpan II will set the Bus Master (BM) bit in the PCI\_CS register (see Table 70 on page 207). This enables the QSpan II as a PCI bus master. If this pin is not connected, an internal pull-down causes the QSpan II to power-up with the BM bit set to 0.

#### 14.2.2 QBus Master and Slave Modes

QSpan II has four Master and Slave modes that are determined by the BDIP\_ and the SIZ[1] signals at reset. The QBus can be in MC68360 (QUICC), MPC860 (PowerQUICC) or M68040 Master mode. The QBus Slave Module is always capable of accepting MC68360 signals and either MPC860 or M68040 signals. These reset options are listed in Table 48.

| Table 48: Reset Options for QBus Master and Slave Modes <sup>a</sup> |
|----------------------------------------------------------------------|
|----------------------------------------------------------------------|

| Reset sampling |        |             |                    |
|----------------|--------|-------------|--------------------|
| BDIP_          | SIZ[1] | Master Mode | Slave Mode         |
| 0              | 0      | MC68360     | MC68360 and M68040 |
| 0              | 1      | MC68360     | MC68360 and MPC860 |
| 1              | 0      | M68040      | MC68360 and M68040 |
| 1              | 1      | MPC860      | MC68360 and MPC860 |

a. These options are reset whenever the QSpan II is reset.

#### 14.2.3 EEPROM Loading

If either ENID or SDA is sampled high at reset, then the QSpan II will download register information from the EEPROM (see Chapter 9: "The EEPROM Channel" on page 127).

#### 14.2.4 PCI Register Access Option

If PCI\_DIS is sampled high at reset, the QSpan II will retry all PCI accesses until the PCI Access Disabled (PCI\_DIS) bit in MISC\_CTL2 is set to 0 by the QBus processor.

#### 14.2.5 PCI Bus Arbitration Option

If PCI\_ARB\_EN is sampled high at reset, the QSpan II's PCI bus arbiter is enabled and will function as the PCI bus arbiter (for more information, see Chapter 11: "PCI Bus Arbiter" on page 145).

# **Chapter 15: Hardware Implementation Issues**

This chapter briefly describes hardware implementation issue for the QSpan II. The following topics are discussed:

- "Test Mode Pins" on page 163
- "JTAG Support" on page 164
- "Decoupling Capacitors" on page 164

#### 15.1 Test Mode Pins

QSpan II can operate in normal mode or test mode. In test mode, a NAND tree is activated and all outputs are tristated except for the SCL output pin. The output of the NAND tree is on the SCL pin.

QSpan II has two test mode input pins (TMODE[1:0]). For normal operations these inputs must be pulled down. The following table indicates the operation modes of the QSpan II as a function of the TMODE[1:0] input. At reset the TMODE[1:0] inputs are latched by the QSpan II to determine the mode of operation. QSpan II remains in this mode until the TMODE[1:0] inputs have changed and a reset event has occurred.

| TMODE[1:0] | Operation Mode             |
|------------|----------------------------|
| 00         | Normal Mode                |
| 01         | Reserved                   |
| 10         | Reserved                   |
| 11         | NAND Tree/Tristate Outputs |

#### Table 49: Test Mode Operation

### 15.2 JTAG Support

The QSpan II includes dedicated user-accessible test logic that is fully compatible with the IEEE 1149.1 Standard Test Access Port and Boundary Scan Architecture. The following pins are provided: TCK, TDI, TDO, TMS, and TRST#.

There is an internal pull-up resistor on TMS which will keep the QSpan II's JTAG controller in a reset state without requiring TRST# to be low.

The current revision of the Boundary Scan Description Language (BSDL) file for the QSpan II (CA91L862A) is available on the Tundra website at www.tundra.com.

### 15.3 Decoupling Capacitors

When routing the power  $(V_{DD})$  and ground  $(V_{SS})$  tracks to the QSpan II during board layout, care should be taken to ensure that the QSpan II is isolated from the power being supplied to other devices on the board by 0.1uF decoupling capacitors.

It is recommended every fourth  $V_{DD}/V_{SS}$  pair has a decoupling capacitor.

# Chapter 16: Signals

This chapter describes the signals which are supported by the QSpan II. The following topics are discussed:

- "MC68360 Signals: QUICC" on page 167
- "MPC860 Signals: PowerQUICC" on page 171
- "M68040 Signals" on page 175
- "PCI Bus Signals" on page 178
- "Hot Swap Signals" on page 180
- "Miscellaneous Signals" on page 181
- "JTAG Signals" on page 182

### 16.1 Terminology

The following abbreviations are used in this chapter:

- in Defines a signal as a standard input-only signal.
- out Defines a signal as a standard output-only signal.
- t/s Defines a signal as a bidirectional, tristate input/output signal.
- s/t/s Defines a signal as a sustained tristate signal that is driven by one owner at a time.
- o/d Defines a signal as an open drain.

### 16.2 Overview

QSpan II's QBus Interface defines a number of signals that can be mapped to MC68360 (QUICC), MPC860 (PowerQUICC), or M68040 buses (see the following table).

| QBus Interface | MC68360  | MPC860    | M68040                          |
|----------------|----------|-----------|---------------------------------|
| BB_/BGACK_     | BGACK_   | BB_       | BB_                             |
| BERR_/TEA_     | BERR_    | TEA_      | TEA_                            |
| BURST_/TIP_    | N/A      | BURST_    | TIP_                            |
| DACK_/SDACK_   | DACK_    | SDACK_    | N/A                             |
| DSACK1_/TA_    | DSACK1_  | TA_       | TA_                             |
| SIZ[1:0]       | SIZ[1:0] | TSIZ[0:1] | SIZ[1:0]                        |
| TC[3:0]        | FC[3:0]  | AT[0:3]   | TT[1:0]<br>TM[2:0] <sup>a</sup> |
| HALT_/TRETRY_  | HALT_    | TRETRY_   | N/A                             |

#### Table 50: QBus Signal Names Compared to Motorola Signals

a. TC[3:0] can be connected to four out of the five TT[1:0] and TM[2:0] M68040 signals. The unused TC pins, if any, must be connected to pull-up resistors (see Appendix C: "Typical Applications" on page 365).



MPC860 signals do not necessarily operate in the same manner as MC68360 signals of the same name.

# 16.3 MC68360 Signals: QUICC

| A[31:0]                                                                                                                                                                                                                                                                                                                                                                                                                                        | Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| input when QBus sl<br>As a slave, the QSp<br>AS_ must meet the<br>ensure correct oper<br>As a master, the QS<br>AS The address b<br>the subsequent falling<br>When accesses are                                                                                                                                                                                                                                                                | Address Bus: address for the current bus cycle. It is driven by the QSpan II when it is the QBus master and input when QBus slave. It is qualified at the start of a transaction by AS<br>As a slave, the QSpan II samples A[31:0] on the same falling edge of the QCLK as AS Both A[31:0] and AS_ must meet the synchronous set-up and hold time parameters about the falling edge of the QCLK to ensure correct operation.<br>As a master, the QSpan II maintains the correct asynchronous timing relationships between A[31:0] and AS The address bus is driven valid after the rising edge of the QCLK, while the AS_ is driven only after the subsequent falling edge of the same clock period, ensuring the correct address before AS_ timing.<br>When accesses are made to QSpan II registers from the QBus, only the lower 12 bits of the address bus are used to determine the offset. |  |  |  |
| AS_                                                                                                                                                                                                                                                                                                                                                                                                                                            | Rescinding Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| As an output AS_ is<br>other times. The Ad<br>qualifies the followin<br>guarantees a minim<br>driven from the risin<br>tristate.<br>As an input, AS_ is<br>time around the falli<br>intended for it, and a                                                                                                                                                                                                                                     | icates the beginning (and duration) of a transaction on the QBus.<br>driven by the QSpan II when the QSpan II is the QBus master, and is tristated at all<br>dress Strobe is driven low after a falling edge of the QCLK. The Address Strobe<br>ig signals as valid when it is asserted: A[31:0], TC[3:0], SIZ[1:0], and R/W QSpan II<br>um set-up time for the qualified signals before AS_ is asserted (all qualified signals are<br>g edge of QCLK preceding the assertion of AS_). QSpan II rescinds AS_ prior to<br>sampled on the falling edge of the QCLK. AS_ must meet a minimum set-up and hold<br>ng edge of the clock for correct operation. QSpan II recognizes a transaction as<br>acknowledges it accordingly, only if one of CSREG_ or CSPCI_ is sampled low in<br>QSpan II does not require that the input signals qualified by the AS_ be valid when                          |  |  |  |
| BB_/BGACK_                                                                                                                                                                                                                                                                                                                                                                                                                                     | Rescinding Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| handshake for QBus<br>As an output the QS<br>rescinds BB_/BGAC<br>As an input, the QS                                                                                                                                                                                                                                                                                                                                                          | ownership of the QBus. It, along with BR_ and BG_, provides the three-wire<br>s arbitration. BB_/BGACK_ is intended to connect to the BGACK_ bus.<br>Span II asserts BB_/BGACK_ from the falling edge of QCLK (while master). QSpan II<br>CK_ prior to tristate.<br>pan II double-samples BB_/BGACK_ on the falling edge of QCLK: when it is master.<br>e programmed to use a synchronous mode for QBus arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| BGACK_                                                                                                                                                                                                                                                                                                                                                                                                                                         | Rescinding Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| See BB_/BGACK_                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| BDIP_                                                                                                                                                                                                                                                                                                                                                                                                                                          | BDIP_ Input (MC68360 mode) / Bidirectional (MPC860)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| Burst Data In Progress: On the MC68360 interface, this pin is used only to determine the QBus master mode of the QSpan II. This is determined at reset by sensing the level of this pin. If BDIP_ is sampled as low (at power-up or reset) the QBus master module will operate as an MC68360 master. If the BDIP_ signal is sampled as high — at power-up or reset — the QSpan II will operate as an MPC860 master (see Table 48 on page 162). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |

# 16.3 MC68360 Signals: QUICC (Continued)

| BERR_/TEA_                                                                                                                                                                                                                                                                                           | Rescinding tristate birectional pin                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| HALT_/TRETRY_ to<br>As an MC68360 ma<br>which it is a QBus n<br>As an MC68360 sla                                                                                                                                                                                                                    | Bus Error: used to indicate a bus error that occurs during a transaction. It can be used in conjunction with HALT_/TRETRY_ to indicate a busy-retry to the bus master.<br>As an MC68360 master, the QSpan II samples BERR_/TEA_ on the falling edge of QCLK during cycles in which it is a QBus master.<br>As an MC68360 slave, BERR_/TEA_ is driven by the QSpan II from the falling edge of QCLK. QSpan II negates BERR_/TEA_ prior to tristate. |  |  |
| BG_                                                                                                                                                                                                                                                                                                  | Input                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Bus Grant: indicates that the QSpan II may become the next QBus master. BG_, along with BR_ and BB_/BGACK_, provide the three-wire handshake for QBus arbitration.<br>BG_ is doubled-sampled on the falling edge of QCLK. QSpan II can be programmed to use a synchronous mode for QBus arbitration. |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| BM_EN/<br>FIFO_RDY_                                                                                                                                                                                                                                                                                  | Bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                                                                                                                                                                                                                                                                                      | Bus Master Enable/FIFO Ready: If this input is asserted — set as 1 — during a PCI Reset, the Bus Master Enable bit in the PCI_CS register will be set.                                                                                                                                                                                                                                                                                             |  |  |
| BR_                                                                                                                                                                                                                                                                                                  | Output                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| BB_/BGACK_, prov                                                                                                                                                                                                                                                                                     | Bus Request: used by the QSpan II to request ownership of the QBus. BR_, along with BG_ and BB_/BGACK_, provide the three-wire handshake for QBus arbitration. BR_ is asserted and negated from the falling edge of QCLK in MC68360 mode.                                                                                                                                                                                                          |  |  |
| CSPCI_                                                                                                                                                                                                                                                                                               | Input                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| IDMA cycles, if this                                                                                                                                                                                                                                                                                 | dicates that the current transaction on the QBus is an access to the PCI Bus. During is sampled high, a single address transfer is indicated; if sampled low, a dual address . It is sampled on the falling edge of clock.                                                                                                                                                                                                                         |  |  |
| CSREG_                                                                                                                                                                                                                                                                                               | Input                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                                                                                                                                                                                                                                                                                                      | et: indicates that the current transaction on the QBus is an access to the QSpan II's ed on the falling edge of clock.                                                                                                                                                                                                                                                                                                                             |  |  |
| D[31:0]                                                                                                                                                                                                                                                                                              | Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| As an MC68360 sla<br>reads without decor                                                                                                                                                                                                                                                             | Data Bus: provides the data information for the QSpan II's inputs and outputs on the QBus.<br>As an MC68360 slave the QSpan II does not use DS_ to qualify data on writes. It also provides data on<br>reads without decoding DS_, since DS is output only.<br>As an MC68360 master, the QSpan II does use DS to qualify data on writes and to request data on reads.                                                                              |  |  |
| DACK_/SDACK_                                                                                                                                                                                                                                                                                         | Input                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| IDMA Acknowledge: indicates to the QSpan II that the current transaction is an IDMA transaction. The timing of DACK_ should be the same as for AS Using the IDMA handshakes, the QSpan II is capable of supporting MC68360 fast termination cycles.                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

# 16.3 MC68360 Signals: QUICC (Continued)

| DONE_                                                                                                                                           | Input                                                                                                                                                                                                                                                                                                                                                        |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                                 | es that the IDMA controller has completed the current sequence of IDMA operations,<br>II should no longer use DREQ_ to request transactions. Setup for DONE is to falling                                                                                                                                                                                    |  |
| DREQ_                                                                                                                                           | Output                                                                                                                                                                                                                                                                                                                                                       |  |
|                                                                                                                                                 | IDMA Request: request to the MC68360 IDMA to either transfer data to QSpan II IFIFO (PCI Write) or remove data from I-FIFO (PCI Read). It is asserted from the falling edge of QCLK in MC68360 mode.                                                                                                                                                         |  |
| DSACK0_                                                                                                                                         | Rescinding tristate bidirectional                                                                                                                                                                                                                                                                                                                            |  |
| acknowledge the co                                                                                                                              | nowledge 0: in conjunction with DSACK1_/TA_, is driven by the addressed slave to completion of a data transfer on the QBus same timing and characteristics as DSACK1_/TA_ (see the following description).                                                                                                                                                   |  |
| DSACK1_/TA_                                                                                                                                     | Rescinding tristate bidirectional                                                                                                                                                                                                                                                                                                                            |  |
| slave to acknowledg<br>QSpan II terminates<br>32-bit port width at a                                                                            | owledge 1: Used in conjunction with DSACK0 This signal is driven by the addressed ge the completion of a data transfer on the QBus. s all normal bus cycles by asserting both DSACK1_/TA_ and DSACK0_ (indicating a all times). The DSACK1_/TA_ output is driven high (inactive) after the release of AS_ edge of the clock, at which point it is tristated. |  |
| DS_                                                                                                                                             | Rescinding tristate output                                                                                                                                                                                                                                                                                                                                   |  |
| during read transac<br>otherwise.<br>As a slave the QSpa<br>where AS_ is samp<br>DS DS_ is output<br>As a master on the<br>transactions, the DS | QBus, the QSpan II asserts DS_ to qualify data during reads and writes. For write S_ is driven from the falling edge of QCLK one half a clock period after the data is a bus. For read transactions, DS is driven at the same time as AS QSpan II negates                                                                                                    |  |
| HALT_/TRETRY_                                                                                                                                   | ALT_/TRETRY_ Rescinding tristate bidirectional                                                                                                                                                                                                                                                                                                               |  |
|                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                              |  |
| As an MC68360 sla                                                                                                                               | ernal bus activity. It is used for generating retries.<br>we QSpan II uses HALT_/TRETRY_ as stated in Table 11 on page 58.<br>aster QSpan II uses HALT_/TRETRY_ as stated in Table 27 on page 85.                                                                                                                                                            |  |
| As an MC68360 sla                                                                                                                               | ernal bus activity. It is used for generating retries.<br>we QSpan II uses HALT_/TRETRY_ as stated in Table 11 on page 58.                                                                                                                                                                                                                                   |  |

# 16.3 MC68360 Signals: QUICC (Continued)

| QCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Input                                                                                                                                                                                                                                                   |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| clock. The QCLK ca                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Bus Clock: All devices intended to interface with QBus side of the QSpan II must be synchronized to this ock. The QCLK can operate up to 33 MHz (with an MC68360 bus). During IDMA fast termination cycles ne maximum MC68360 QCLK frequency is 30 MHz. |  |  |
| QINT_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Open drain bidirectional                                                                                                                                                                                                                                |  |  |
| QBus Interrupt: as an output, this open drain signal is asserted by the QSpan II when an interrupt event occurs,. As an input, this signal can be mapped to the PCI INT# output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                         |  |  |
| RESETI_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Input                                                                                                                                                                                                                                                   |  |  |
| QBus Reset Input: r<br>configuration and st                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | resets the QSpan II from the QBus side of the QSpan II. RESETI_ does not reset PCI status registers.                                                                                                                                                    |  |  |
| RESETO_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Open drain output                                                                                                                                                                                                                                       |  |  |
| QBus Reset Output software reset bit is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | asserted whenever the QSpan II's PCI RST# input is asserted, or the internal set.                                                                                                                                                                       |  |  |
| R/W_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Tristate bidirectional                                                                                                                                                                                                                                  |  |  |
| low indicates a write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | es the direction of the data transfer on the Data bus. High indicates a read transaction;<br>e. It has the same timing as the Address bus.<br>Span II drives R/W_, and tristates it otherwise. As a slave, the R/W_ pin is an input.                    |  |  |
| SIZ[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Tristate bidirectional                                                                                                                                                                                                                                  |  |  |
| with the lower two a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | number of bytes to be transferred during a bus cycle. The value of the Size bits, along address bits and the port width, define the byte lanes that are active. Table 51 on e encoding for the Size bits.                                               |  |  |
| TC[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Tristate bidirectional                                                                                                                                                                                                                                  |  |  |
| Transaction Code: provides additional information about a bus cycle when the QSpan II is a QBus master.<br>Driven by the QSpan II when it is a QBus master, and tristated otherwise.<br>As a slave, the QSpan II samples TC[3:0] on the first falling edge of the QCLK after AS_ is asserted.<br>TC[3:0] can optionally be used with DACK_/SDACK_ to decode an IDMA operation. For use in IDMA<br>transfers, TC[3:0] should be set to all ones.<br>The timing for the TC[3:0] outputs is the same as the timing for the address bus when the QSpan II is a<br>QBus master.<br>The values output on the TC[3:0] bus during a transaction in which the QSpan II is the bus master is<br>determined by the value programmed in the Transaction Code field of the corresponding QSpan II PCI<br>target image. TC[3:0] is intended to connect to the MC68360's FC[3:0], but may be used for other special<br>decoding purposes. |                                                                                                                                                                                                                                                         |  |  |

# 16.4 MPC860 Signals: PowerQUICC

| A[31:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| input as slave. It is q<br>As a slave, the QSpa<br>(TS_) on the same r<br>As a master, the add<br>When accesses are                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Address bus: address for the current bus cycle. It is driven by the QSpan II when it is the QBus master and input as slave. It is qualified at the start of a transaction by TS<br>As a slave, the QSpan II samples A[31:0] on the rising edge of QCLK, and is qualified by Transaction Start (TS_) on the same rising clock edge.<br>As a master, the address is driven out following a rising edge of the QCLK.<br>When accesses are made to QSpan II registers from the QBus, only the lower 12 bits of the address bus are used to determine the register offset. |  |  |
| AT[0:3]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| See TC[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| BB_/BGACK_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Rescinding tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Bus Busy: indicates ownership of the QBus. BB_ is asserted low by a master to show that it owns the b<br>BB_, along with BR_ and BG_, provides the three-wire handshake for QBus arbitration.<br>As an output the QSpan II asserts BB_/BGACK_ from the rising edge of QCLK (while master). QSpar<br>drives BB_/BGACK_ to the prior to tristate. Note in the MPC860 mode, the QSpan II asserts BB_ one<br>clock after receiving BG_: in compliance with the MPC860 arbiter.<br>As an input, the QSpan II samples BB_/BGACK_ on the rising edge of QCLK.<br>QSpan II can also be programmed to use a asynchronous mode for QBus arbitration.                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| BDIP_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Burst Data In Progress: As MPC860 master, the QSpan II uses BDIP_ in burst writes to indicate the second last data beat of a transaction. This allows the QSpan II to perform burst writes of two, three, four beats. QSpan II does not use BDIP_ in the same manner for burst reads. Burst reads are always cacheline aligned and four beats in length.<br>As MPC860 slave, the QSpan II monitors BDIP_ as a signal indicating the second last data beat in the burst. This allows the QSpan II to support bursts of two, three, or four data beats.<br>The QBus master mode of the QSpan II is determined at power-up and reset by sensing the level of pin. If BDIP_ is sampled as low (at reset) the QBus master module will operate as a MC68360 master reset, if the BDIP_ signal is sampled as high the QSpan II will operate as an MPC860 or M68040 ma (see Table 48 on page 162). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| BERR_/TEA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | BERR_/TEA_ Rescinding tristate bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Transfer Error Acknowledge: indicates that a bus error occurred in the current transaction.<br>Driven by the QSpan II when it is a QBus slave, and tristated otherwise.<br>As an output BERR_/TEA_ is driven by the QSpan II from the rising edge of QCLK. QSpan II negates<br>BERR_/TEA_ prior to tristate.<br>As an input, the QSpan II samples BERR_/TEA_ on the rising edge of QCLK during cycles in which it is<br>QBus master.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| BG_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Bus Grant: indicates that the QSpan II may become the next QBus master. BG_, along with BR_ and BB_/BGACK_, provide the three-wire handshake for QBus arbitration. BG_ is sampled on the rising edge of QCLK.<br>QSpan II can be programmed to use a asynchronous mode for QBus arbitration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |

# 16.4 MPC860 Signals: PowerQUICC (Continued)

| BR_                                                                                                                                                                                                                                                                                                                                          | Output                                                                                 |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|
| Bus Request: used by the QSpan II to request ownership of the QBus. BR_, along with BG_ and BB_/BGACK_, provide the three-wire handshake for QBus arbitration. BR_ is asserted and released from the rising edge of QCLK.                                                                                                                    |                                                                                        |  |
| BM_EN/<br>FIFO_RDY_                                                                                                                                                                                                                                                                                                                          | Bidirectional                                                                          |  |
| Bus Master Enable: If this input is asserted — set as 1 — during a PCI Reset, the Bus Master Enable bit the PCI_CS register will be set.<br>(FIFO_RDY) FIFO Ready functionality is not relevant to MPC860 applications.                                                                                                                      |                                                                                        |  |
| BURST_/TIP                                                                                                                                                                                                                                                                                                                                   | Tristate bidirectional                                                                 |  |
| Burst: indicates that of the same name.                                                                                                                                                                                                                                                                                                      | the current initiated transfer is a burst cycle. This signal matches the MPC860 signal |  |
| CSPCI_                                                                                                                                                                                                                                                                                                                                       | Input                                                                                  |  |
| PCI Chip Select: indicates that the current transaction on the QBus is an access to the PCI Bus. CSPCI_<br>can be sampled on the same clock as TS or up to three clocks following TS_ assertion. During IDMA<br>cycles, if this is sampled high, a single address transfer is indicated; otherwise, a dual address transfer is<br>indicated. |                                                                                        |  |
| CSREG_                                                                                                                                                                                                                                                                                                                                       | Input                                                                                  |  |
| Register Chip Select: indicates that the current transaction on the QBus is an access to the QSpan II's registers. CSREG_ can be sampled on the same clock as TS_ or up to three clocks following TS_ assertion. This signal is sampled synchronously on the rising edge of clock after TS                                                   |                                                                                        |  |
| DP[3:0]                                                                                                                                                                                                                                                                                                                                      | Bidirectional                                                                          |  |
| Data Parity: provides the parity information for the data on D[31:0]. It is valid on the same clock as the data.                                                                                                                                                                                                                             |                                                                                        |  |
| D[31:0]                                                                                                                                                                                                                                                                                                                                      | Tristate bidirectional                                                                 |  |
| Data Bus: provides t                                                                                                                                                                                                                                                                                                                         | he general-purpose data path between the QSpan II, the MPC860, and other devices.      |  |
| DACK_/SDACK_                                                                                                                                                                                                                                                                                                                                 | Input                                                                                  |  |
| IDMA Acknowledge:                                                                                                                                                                                                                                                                                                                            | indicates to the QSpan II that the current transaction is an IDMA transaction.         |  |
| DONE_                                                                                                                                                                                                                                                                                                                                        | Input                                                                                  |  |
| IDMA Done: This sig                                                                                                                                                                                                                                                                                                                          | gnal is not used with MPC860 transfers.                                                |  |
| DREQ_                                                                                                                                                                                                                                                                                                                                        | Output                                                                                 |  |
| IDMA Request: request to the MPC860 IDMA to either transfer data to QSpan II IFIFO (PCI Write) or remove data from I-FIFO (PCI Read). It is asserted from the rising edge of QCLK in MPC860 mode.                                                                                                                                            |                                                                                        |  |

# 16.4 MPC860 Signals: PowerQUICC (Continued)

| DSACK1_/TA_                                                                                                                                                                                                                                                                                                                              | Rescinding tristate bidirectional |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|
| Transaction Acknowledge: driven by the addressed slave to acknowledge the completion of a data transfer<br>on the QBus.<br>As a slave the QSpan II terminates all normal bus cycles by asserting TA QSpan II negates                                                                                                                     |                                   |  |
| DSACK1_/TA_ prior to tristate.                                                                                                                                                                                                                                                                                                           |                                   |  |
| HALT_/TRETRY_                                                                                                                                                                                                                                                                                                                            | Rescinding tristate bidirectional |  |
| Transfer Retry: used for generating retries.<br>As a MPC860 slave, QSpan II uses HALT_/TRETRY_ as stated in Table 12 on page 58.<br>As a MPC860 master, QSpan II uses HALT_/TRETRY_ as stated in Table 28 on page 85.As a slave,<br>HALT_/TRETRY_ has the same timing as DSACK1_/TA QSpan II negates HALT_/TRETRY_ prior to<br>tristate. |                                   |  |
| IMSEL                                                                                                                                                                                                                                                                                                                                    | Input                             |  |
| Image Select: selects which QBus Slave Image to use when CSPCI_ is asserted.<br>The timing requirements for IMSEL are the same as those of the address bus when the QSpan II is a<br>QBus slave.                                                                                                                                         |                                   |  |
| QCLK                                                                                                                                                                                                                                                                                                                                     | Input                             |  |
| QBus Clock: All devices intended to interface with QBus side of the QSpan II must be synchronized to clock.<br>The maximum QCLK frequency with a MPC860 is 50 MHz.                                                                                                                                                                       |                                   |  |
| QINT_                                                                                                                                                                                                                                                                                                                                    | Open drain bidirectional          |  |
| QBus Interrupt: as an output, this open drain signal is asserted by the QSpan II when an interrupt occurs,. As an input, this signal can be mapped to the PCI INT# output.                                                                                                                                                               |                                   |  |
| RESETI_                                                                                                                                                                                                                                                                                                                                  | Input                             |  |
| QBus Reset Input: resets the QSpan II from the QBus side of the QSpan II. Note that RESETI_ does not reset PCI configuration and status registers.                                                                                                                                                                                       |                                   |  |
| RESETO_                                                                                                                                                                                                                                                                                                                                  | Open drain output                 |  |
| QBus Reset Output: asserted whenever the QSpan II's PCI RST# input is asserted, or the internal software reset bit is set.                                                                                                                                                                                                               |                                   |  |
| R/W_                                                                                                                                                                                                                                                                                                                                     | Tristate bidirectional            |  |
| Read Write: indicates the direction of the data transfer on the Data bus. High indicates a read transaction;<br>low indicates a write. It has the same timing as the Address bus.<br>As an active master, the QSpan II drives R/W_, and tristates it otherwise.<br>As an addressed slave, the R/W_ pin is an input.                      |                                   |  |

# 16.4 MPC860 Signals: PowerQUICC (Continued)

| SIZ[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Tristate bidirectional            |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|
| Size: indicates the number of bytes to be transferred during a bus cycle. The value of the Size bits, along with the lower two address bits and the port width, define the byte lanes that are active. Table 51 on page 175 shows the encoding for the Size bits.<br>SIZ[1:0] is intended to connect to MPC860 TSIZ[0:1].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   |  |
| TA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rescinding tristate bidirectional |  |
| See DSACK1_/TA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                   |  |
| TC[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Tristate bidirectional            |  |
| Driven by the QSpan II when it is a QBus master, and tristated otherwise.<br>As a slave, the QSpan II samples TC[3:0] on the first rising edge of the QCLK after TS_ is asserted.<br>TC[3:0] can optionally be used with DACK_/SDACK_ to decode an IDMA operation. For use in IDMA<br>transfers, TC[3:0] should be set to all ones.<br>The timing for the TC[3:0] outputs is the same as the timing for the address bus when the QSpan II is a<br>QBus master.<br>The values output on the TC[3:0] bus during a transaction in which the QSpan II is the bus master is<br>determined by the value programmed in the Transaction Code field of the corresponding QSpan II PCI<br>target image. TC[3:0] is intended to connect to the MPC860's AT[0:3], but can be used for other specia<br>decoding purposes. |                                   |  |
| TEA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Rescinding tristate bidirectional |  |
| See BERR_/TEA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                   |  |
| TRETRY_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Rescinding tristate bidirectional |  |
| See HALT_/TRETR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ۲                                 |  |
| TS_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Rescinding Tristate bidirectional |  |
| Transfer Start: TS_ is a three state bi-directional signal used to indicate the beginning of an MPC860 bus transaction on the QBus.<br>The TS_ output is driven by the QSpan II when the QSpan II is the QBus master, and is tri-stated at all other times.<br>As an output, TS_ is driven low after a rising edge of the QCLK. Transfer Start indicates the following signals will be valid on the next rising edge of the QCLK: A[31:0], TC[3:0], SIZ[1:0], and R/W QSpan II rescinds TS_ prior to tri-state.<br>As an input, TS_ is sampled on the rising edge of the QCLK. QSpan II samples the address bus and other TS_ qualified signals on the same rising edge of QCLK in which it samples TS_ asserted. CSPCI_ and CSREG_ may have up to three wait states after TS_ is sampled.                   |                                   |  |

The following table applies to MC68360 and MPC860 SIZ[1:0] signals.

| SIZ[1] | SIZ[0] | QSpan II<br>Master | QSpan II<br>MC68360 slave | QSpan II<br>MPC860 slave |
|--------|--------|--------------------|---------------------------|--------------------------|
| 0      | 0      | 4 bytes            | 4 bytes                   | 4 bytes                  |
| 0      | 1      | 1 byte             | 1 byte                    | 1 byte                   |
| 1      | 0      | 2 bytes            | 2 bytes                   | 2 bytes                  |
| 1      | 1      | Reserved           | 3 bytes                   | 3 bytes                  |

 Table 51: MC68360/MPC860 Encoding for the SIZ[1:0] Signal

### 16.5 M68040 Signals

| A[31:0]                                                                                                                                                                                                                                                                                                                          | Tristate bidirectional |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Address bus: Address for the current bus cycle. It is driven by the QSpan II when the QSpan II is the M68040 master and input when the QSpan II is the slave. It is qualified at the start of a transaction by TS As a slave, the QSpan II samples A[31:0] on the rising edge of QCLK, and is qualified by Transaction St (TS_). |                        |
| As a master, the address is driven out following a rising edge of the QCLK.                                                                                                                                                                                                                                                      |                        |

When accesses are made to QSpan II registers from the QBus, only the lower 12 bits of the address bus are used to determine the register offset.

| BB_/BGACK_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Rescinding tristate bidirectional |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|
| Bus Busy: This signal is asserted by the current bus master to indicate ownership of the M68040 bus.<br>BB_, along with BR_ and BG_, provide the three-wire handshake for M68040 bus arbitration.<br>As an output the QSpan II asserts BB_/BGACK_ from the rising edge of QCLK (while master). QSpan II<br>negates BB_/BGACK_ prior to tristate.<br>As an input, the QSpan II samples BB_/BGACK_ on the rising edge of QCLK (while master).<br>QSpan II can also be programmed to use an asynchronous mode for M68040 bus arbitration. |                                   |  |
| BDIP_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bidirectional                     |  |
| Burst Data In Progress: This signal is only used in the 68040 mode at reset.<br>QSpan II Master/Slave mode is determined at reset by sensing the level of this pin in conjunction with SIZ[1]. See Table 48 on page 162.                                                                                                                                                                                                                                                                                                               |                                   |  |
| BERR_/TEA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Rescinding tristate bidirectional |  |
| Transfer Error Acknowledge: indicates an error condition exists for a bus transfer.<br>Driven by the QSpan II when it is a M68040 bus slave to signal an errored transaction.<br>As an input, the QSpan II samples BERR_/TEA_ during M68040-style cycles in which it is a M68040 bus<br>master on the rising edge of QCLK.<br>Target retries are indicated by the simultaneous assertion of DSACK1_/TA_ and BERR_/TEA                                                                                                                  |                                   |  |

# 16.5 M68040 Signals (Continued)

| BG_                                                                                                                                                                                                                                                                                                                    | Input                                                                                                                              |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bus Grant: indicates that the QSpan II may become the next M68040 bus master. BG_, along with BR_<br>and BB_/BGACK_, provide the three-wire handshake for M68040 bus arbitration. BG_ is sampled on the<br>rising edge of QCLK.<br>QSpan II can be programmed to use an asynchronous mode for M68040 bus arbitration.  |                                                                                                                                    |  |  |
| BM_EN/<br>FIFO_RDY_                                                                                                                                                                                                                                                                                                    | Bidirectional                                                                                                                      |  |  |
| Bus Master Enable: If this input is asserted (set as 1) during a PCI Reset, the Bus Master Enable bit in PCI_CS register will be set.                                                                                                                                                                                  |                                                                                                                                    |  |  |
| BR_                                                                                                                                                                                                                                                                                                                    | Output                                                                                                                             |  |  |
| Bus Request: asserted by the QSpan II to request ownership of the M68040 bus. BR_, along with BG_<br>and BB_/BGACK_, provide the three-wire handshake for M68040 bus arbitration.<br>BR_ is asserted and released from the rising edge of QCLK.                                                                        |                                                                                                                                    |  |  |
| BURST_/TIP_                                                                                                                                                                                                                                                                                                            | Tristate bidirectional                                                                                                             |  |  |
|                                                                                                                                                                                                                                                                                                                        | Transaction In Progress: asserted for the length of an M68040 transfer. This signal uses the same pin as the MPC860 BURST_ signal. |  |  |
| CSPCI_                                                                                                                                                                                                                                                                                                                 | Input                                                                                                                              |  |  |
| PCI Chip Select: inc                                                                                                                                                                                                                                                                                                   | dicates that the current transaction on the QBus is an access to the PCI Bus.                                                      |  |  |
| CSREG_                                                                                                                                                                                                                                                                                                                 | Input                                                                                                                              |  |  |
| Register Chip Select: indicates that the current transaction on the QBus is an access to the QSpan II's registers.                                                                                                                                                                                                     |                                                                                                                                    |  |  |
| D[31:0]                                                                                                                                                                                                                                                                                                                | Tristate bidirectional                                                                                                             |  |  |
| Data Bus: provides                                                                                                                                                                                                                                                                                                     | the data information for the QSpan II's inputs and outputs on the M68040 bus.                                                      |  |  |
| DSACK1_/TA_                                                                                                                                                                                                                                                                                                            | Rescinding tristate bidirectional                                                                                                  |  |  |
| Transaction Acknowledge: asserted by the addressed slave to acknowledge a bus transfer.<br>As a slave the QSpan II terminates all normal bus cycles by asserting DSACK1_/TA QSpan II negates DSACK1_/TA_ prior to tristate.<br>Target retries are indicated by the simultaneous assertion of DSACK1_/TA_ and BERR_/TEA |                                                                                                                                    |  |  |
| IMSEL                                                                                                                                                                                                                                                                                                                  | Input                                                                                                                              |  |  |
| Image Select: selects which QBus Slave Image to use when CSPCI_ is asserted.<br>The timing requirements for IMSEL are the same as those of the address bus when the QSpan II is a<br>M68040 bus slave.                                                                                                                 |                                                                                                                                    |  |  |

# 16.5 M68040 Signals (Continued)

| QCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Input                                                                                             |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
| QBus Clock: All devices intended to interface with QBus side of the QSpan II must be synchronized to this clock.<br>QCLK can operate up to 40MHz.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                   |  |
| QINT_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Open drain bidirectional                                                                          |  |
| QBus Interrupt: as an output, this open drain signal is asserted by the QSpan II when an interrupt occurs. As an input, this signal can be mapped to the PCI INT# output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                   |  |
| RESETI_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Input                                                                                             |  |
| QBus Reset Input: r<br>configuration and st                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | esets the QSpan II from the QBus side of the QSpan II. RESETI_ does not reset PCI atus registers. |  |
| RESETO_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Open drain output                                                                                 |  |
| QBus Reset Output: asserted whenever the QSpan II's PCI RST# input is asserted, or the internal software reset bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                   |  |
| R/W_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Tristate bidirectional                                                                            |  |
| Read Write: indicates the direction of the data transfer on the Data bus. High indicates a read transaction a low indicates a write. It has the same timing as the Address bus.<br>As a master, the QSpan II drives R/W_, and tristates it otherwise.<br>As a slave, the R/W_ pin is an input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                   |  |
| SIZ[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Tristate bidirectional                                                                            |  |
| Size: indicates the number of bytes to be transferred during a bus cycle. The value of the Size bits, with the lower two address bits and the port width, define the byte lanes that are active. Table 52 o page 178 shows the encoding for the Size bits. SIZ[1:1] indicates a M68040 burst cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                   |  |
| TA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Rescinding tristate bidirectional                                                                 |  |
| See DSACK1_/TA_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                   |  |
| TC[3:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Tristate bidirectional                                                                            |  |
| Transaction Code Bus: provides additional information about a bus cycle when the QSpan II is a M68040 bus master.<br>Driven by the QSpan II when it is a M68040 bus master.<br>As a slave, the QSpan II samples TC[3:0] on the rising edge of QCLK, and is qualified by Transfer Start (TS_).<br>The timing for the TC[3:0] outputs is the same as the timing for the address bus when the QSpan II is a M68040 bus master.<br>The values output on the TC[3:0] bus during a transaction in which the QSpan II is the bus master is determined by the value programmed in the Transaction Code field of the corresponding PCI target image.<br>TC[3:0] may be connected to a subset of the TT[1:0] and TM[2:0] M68040 pins. Unused TC[3:0] pins, if any, should be connected to pull-up resistors. |                                                                                                   |  |

### 16.5 M68040 Signals (Continued)

| TEA_                                                                               | Rescinding tristate bidirectional |  |
|------------------------------------------------------------------------------------|-----------------------------------|--|
| See BERR_/TEA_                                                                     |                                   |  |
| TIP_                                                                               | Tristate bidirectional            |  |
| See BURST_/TIP_                                                                    |                                   |  |
| TS_                                                                                | Tristate bidirectional            |  |
| Transfer Start: asserted for one clock period to indicate the start of a transfer. |                                   |  |

The following table describes the signal encoding for M68040 SIZ[1:0] signals. Byte lane enabling is combined with A[1:0] as described in the *Motorola M68040 User's Manual*.

#### Table 52: M68040 Encoding for the SIZ[1:0] Signal

| SIZ[1] | SIZ[0] | QSpan II as<br>M68040 Master | QSpan II as<br>M68040 Slave |
|--------|--------|------------------------------|-----------------------------|
| 0      | 0      | 4 bytes                      | 4 bytes                     |
| 0      | 1      | 1 byte                       | 1 byte                      |
| 1      | 0      | 2 bytes                      | 2 bytes                     |
| 1      | 1      | Reserved                     | Line (burst)                |

### 16.6 PCI Bus Signals

| AD [31:0]                                                                                                                                                                                          | Bidirectional (t/s)                                                                  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| PCI Address/Data Bus: address and data are multiplexed over these pins providing a 32-bit address/dat<br>bus. A bus transaction consists of an address phases followed by one or more data phases. |                                                                                      |  |
| C/BE# [3:0]                                                                                                                                                                                        | Bidirectional (t/s)                                                                  |  |
| PCI Bus Command<br>enables during data                                                                                                                                                             | and Byte Enable Lines: command information during address phase and byte line phase. |  |
| DEVSEL#                                                                                                                                                                                            | Bidirectional (s/t/s)                                                                |  |
| PCI Device Select: driven by the QSpan II when it is accessed as PCI slave. Sampled by the QSpan II when it is PCI master.                                                                         |                                                                                      |  |
| EXT_GNT#[6:1]                                                                                                                                                                                      | Output                                                                               |  |
| External Grant: used by the QSpan II to indicate to an external device that it has been granted access to the PCI bus (this is an output).                                                         |                                                                                      |  |

# 16.6 PCI Bus Signals (Continued)

| EXT_REQ#[6:1]                                                                                                                                                                                                                                                                                                                                                           | Bidirectional                                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| External Request: used by an external device to indicate to the QSpan II PCI bus arbiter that it wants ownership of the PCI bus. The QSpan II drives the unused EXT_REQ#[6:1] pins high when an external arbiter is used.                                                                                                                                               |                                                                                                                                    |  |
| FRAME#                                                                                                                                                                                                                                                                                                                                                                  | Bidirectional (s/t/s)                                                                                                              |  |
| Cycle Frame for PCI Bus: driven by the QSpan II when it is PCI master, and is monitored by the C when it is PCI target. This signal indicates the beginning and duration of an access.                                                                                                                                                                                  |                                                                                                                                    |  |
| GNT#                                                                                                                                                                                                                                                                                                                                                                    | Bidirectional                                                                                                                      |  |
| PCI Grant: As an input, when the QSpan II uses an external arbiter, it indicates to the QSpan II that it has been granted ownership of the PCI bus. GNT# can be parked at QSpan II to improve its PCI master performance.<br>As an output, when the QSpan II is the PCI bus arbiter, it indicates to an external device that it has been granted access to the PCI bus. |                                                                                                                                    |  |
| IDSEL                                                                                                                                                                                                                                                                                                                                                                   | Input (in)                                                                                                                         |  |
| PCI Initialization Dev                                                                                                                                                                                                                                                                                                                                                  | vice Select: used as a chip select during configuration read and write transactions                                                |  |
| INT#                                                                                                                                                                                                                                                                                                                                                                    | Bidirectional (o/d)                                                                                                                |  |
| PCI Interrupt: As an output, it indicates that the QSpan II is generating an internal interrupt. As an input this signal will cause QINT# to be asserted on the QBus bus (if enabled). The signal can be used as an input for an application where the MPC860 is the system host.                                                                                       |                                                                                                                                    |  |
| IRDY#                                                                                                                                                                                                                                                                                                                                                                   | Bidirectional (s/t/s)                                                                                                              |  |
| Initiator Ready: used by the QSpan II to indicate that it is ready to complete the current data phase of the transaction. As PCI target, the QSpan II monitors this signal during reads to determine when the PCI master is ready to accept data.                                                                                                                       |                                                                                                                                    |  |
| PAR                                                                                                                                                                                                                                                                                                                                                                     | Bidirectional (t/s)                                                                                                                |  |
|                                                                                                                                                                                                                                                                                                                                                                         | Parity: parity is even across AD [31:0] and C/BE# [3:0] (the number of 1s summed across these lines and PAR equal an even number). |  |
| PCLK                                                                                                                                                                                                                                                                                                                                                                    | Input (in)                                                                                                                         |  |
| PCI Clock input for F<br>33MHz.                                                                                                                                                                                                                                                                                                                                         | PCI interface used to generate fixed timing parameters. PCLK can operate up to                                                     |  |
| PERR#                                                                                                                                                                                                                                                                                                                                                                   | Bidirectional (s/t/s)                                                                                                              |  |
| Parity Error: reports parity errors during all PCI transactions except a special cycle. QSpan II asserts PERR# within two clocks of receiving a parity error on incoming data, and holds PERR# for at least one clock for each errored data phase.                                                                                                                      |                                                                                                                                    |  |

# 16.6 PCI Bus Signals (Continued)

| REQ#                                                                                                                                                                                                                                                                                                                                                   | Bidirectional (t/s)   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| Bus Request: used by the QSpan II to indicate that it requires the use of the PCI bus; this is an output when the QSpan II uses an external arbiter. REQ# is also used by an external device to indicate to the QSpan II PCI bus arbiter that this device wants use of the PCI bus; this signal is an input when the QSpan II PCI bus arbiter is used. |                       |
| RST#                                                                                                                                                                                                                                                                                                                                                   | Input                 |
| PCI Reset: Asynchronous Reset that is used to bring PCI-specific registers, state machines, and signals to a consistent state.                                                                                                                                                                                                                         |                       |
| SERR#                                                                                                                                                                                                                                                                                                                                                  | Bidirectional         |
| System Error: reports address parity errors during all transactions. QSpan II asserts SERR# within two clocks of receiving a parity error on incoming address, and holds SERR# for at least one clock for each errored data phase.                                                                                                                     |                       |
| STOP#                                                                                                                                                                                                                                                                                                                                                  | Bidirectional         |
| Stop: used by the QSpan II as PCI target when it wishes to signal the PCI master to stop the current transaction. As PCI master, the QSpan II terminates the transaction if it receives STOP# from the PCI target.                                                                                                                                     |                       |
| TRDY#                                                                                                                                                                                                                                                                                                                                                  | Bidirectional (s/t/s) |
| Target Ready: used by the QSpan II as PCI target to indicate that it is ready to complete the current data phase. During a read with QSpan II as PCI master, the target asserts TRDY# to indicate to the QSpan II that valid data is present on the data bus.                                                                                          |                       |

# 16.7 Hot Swap Signals

| ENUM#                                                                                                                                                                                                                                                           | Open Drain Output |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Hot Swap Event Interrupt: notifies the PCI host that either a board has been inserted or is about to be extracted.                                                                                                                                              |                   |
| HS_HEALTHY_                                                                                                                                                                                                                                                     | Input             |
| Hot Swap Healthy: QSpan II internally OR's this input with PCI reset (RST#) to determine when back-end power is stable.                                                                                                                                         |                   |
| HS_LED                                                                                                                                                                                                                                                          | Output            |
| Hot Swap LED Control: This signal is driven by QSpan II to control the status of the LED. The signal is driven low to turn on the LED during the hardware and software connection stages. The signal is tri-stated during normal operation to turn off the LED. |                   |
| HS_SWITCH                                                                                                                                                                                                                                                       | Input             |
| Hot Swap Switch: QSpan II uses this input to monitor the state of the Hot Swap board ejector latch. A low value on this signal indicates that the ejector latch is open.                                                                                        |                   |

# 16.8 Miscellaneous Signals

| ENID                                                                                                                                                            | Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
|                                                                                                                                                                 | ading Reset Option. If ENID is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM.                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| PCI_ARB_EN                                                                                                                                                      | Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| PCI Arbiter Enable: If PCI_ARB_EN is sampled high at the negation of Reset, the QSpan II's PCI bus arbiter is enabled and will function as the PCI bus arbiter. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
| PCI_DIS                                                                                                                                                         | Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| assertion and retry                                                                                                                                             | bisable: This is a power-up option which makes the QSpan II hold off on ENUM#<br>PCI configuration cycles to allow the Host processor to perform local configuration.<br>CI configuration cycles after the PCI_DIS bit is cleared in the MISC_CTL2 register.                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| PME#                                                                                                                                                            | Open Drain Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
|                                                                                                                                                                 | Event Interrupt: This signal is asserted to request a change in its current power and/or to indicate that a power management event has occurred.                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| SCL                                                                                                                                                             | Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
| Serial Clock: EEPR                                                                                                                                              | OM Serial clock. The frequency of the SCL is the PCLK frequency divided by 2 <sup>10</sup> .                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| 0.5.4                                                                                                                                                           | Bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| SDA                                                                                                                                                             | Bidirectional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC                                                                                                                                              | <b>Bidirectional</b><br>DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will<br>formation from the EEPROM.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC                                                                                                                                              | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC<br>download register in<br>TEST1                                                                                                             | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will<br>oformation from the EEPROM.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC<br>download register in<br>TEST1                                                                                                             | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM.                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRO<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2                                                                            | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM. Input ring test input which should be left open. This pin has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRO<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2                                                                            | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM. Input ring test input which should be left open. This pin has an internal pull-up resistor. Input                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2<br>This is a manufactur<br>TEST3                                           | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM. Input ring test input which should be left open. This pin has an internal pull-up resistor. Input ring test input which should be left open. This pin has an internal pull-down resistor.                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRC<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2<br>This is a manufactur<br>TEST3                                           | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM.  Input ring test input which should be left open. This pin has an internal pull-up resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRO<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2<br>This is a manufactur<br>TEST3<br>This is a manufactur<br>TMODE[1:0]     | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM.  Input ring test input which should be left open. This pin has an internal pull-up resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input                                                                                                |  |  |  |  |  |  |  |  |  |
| Serial Data: EEPRO<br>download register in<br>TEST1<br>This is a manufactur<br>TEST2<br>This is a manufactur<br>TEST3<br>This is a manufactur<br>TMODE[1:0]     | DM Serial data line. If SDA is sampled high after a PCI reset, then the QSpan II will iformation from the EEPROM.  Input ring test input which should be left open. This pin has an internal pull-up resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input ring test input which should be left open. This pin has an internal pull-down resistor.  Input |  |  |  |  |  |  |  |  |  |

# 16.9 JTAG Signals

| TMS                                           | Input                                                                                         |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| Test Mode Select: L                           | Test Mode Select: Used to control the state of the Test Access Port controller                |  |  |  |  |  |  |  |  |  |  |
| TDI                                           | Input                                                                                         |  |  |  |  |  |  |  |  |  |  |
| Test Input: Used (in a serial bit stream.     | conjunction with TCK) to shift data and instructions into the Test Access Port (TAP) in       |  |  |  |  |  |  |  |  |  |  |
| TDO                                           | Output                                                                                        |  |  |  |  |  |  |  |  |  |  |
| Test Output: Used (<br>in a serial bit stream | in conjunction with TCK) to shift data and instructions into the Test Access Port (TAP)<br>n. |  |  |  |  |  |  |  |  |  |  |
| TRST_                                         | Input                                                                                         |  |  |  |  |  |  |  |  |  |  |
| Test Reset: Used to                           | force the Test Access Port (TAP) into a initialized state.                                    |  |  |  |  |  |  |  |  |  |  |
| тск                                           | TCK Input                                                                                     |  |  |  |  |  |  |  |  |  |  |
| Test Clock: Used to                           | clock state information and data into and out of the device during boundary scan.             |  |  |  |  |  |  |  |  |  |  |

# **Chapter 17: Signals and DC Characteristics**

This chapter discusses QSpan II signals and DC characteristics. The following topics are explained:

- "Packaging and Voltage Level Support" on page 184
- "Signals and DC Characteristics" on page 184
- "Pinout" on page 196

## 17.1 Terminology

The following abbreviations are used in this chapter:

| Two-state output                                            |
|-------------------------------------------------------------|
| Tristate output                                             |
| Bidirectional                                               |
| Input                                                       |
| Output                                                      |
| Open Drain                                                  |
| Internal pull-down                                          |
| Internal pull-up                                            |
| Input with TTL threshold                                    |
| Input with TTL threshold (the pull-up resistor is internal) |
| TTL Schmitt trigger input                                   |
|                                                             |

## 17.2 Packaging and Voltage Level Support

QSpan II is available in two packages:

- 17 mm x 17 mm, 1.0 mm ball pitch, 256 PBGA
- 27 mm x 27 mm, 1.27 mm ball pitch, 256 PBGA

Both packages require a 3.3V power supply and provide 3.3V or 5V I/O signaling characteristics on the PCI bus. Both devices are also 5V tolerant. For more information on QSpan II packaging, see Appendix G: "Mechanical Information" on page 405.

# 17.3 Signals and DC Characteristics

| Symbols <sup>a</sup> | Parameters                                   | Test conditions                                                                                    | Min                 | Мах                |
|----------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------|---------------------|--------------------|
| V <sub>IH</sub>      | Voltage Input high                           | TTL, TTL Sch                                                                                       | 2.0V                | -                  |
| V <sub>IH</sub>      | Voltage Input high                           | CMOS                                                                                               | 0.7 V <sub>DD</sub> | -                  |
| V <sub>IL</sub>      | Voltage Input low                            | TTL, TTL Sch                                                                                       | -                   | 0.8V               |
| V <sub>IL</sub>      | Voltage Input low                            | CMOS                                                                                               | -                   | 0.3V <sub>DD</sub> |
| V <sub>HY</sub>      | Hysteresis for Schmitt                       | TTL Sch                                                                                            | 0.3V                | -                  |
| V <sub>OL</sub>      | Voltage Output low                           | I <sub>OL</sub> = 8.0 mA<br>V <sub>DD</sub> = 3.0 V                                                | -                   | 0.4V               |
| V <sub>OH</sub>      | Voltage Output high                          | I <sub>OH</sub> = -8.0 ma<br>V <sub>DD</sub> = 3.0 V                                               | 2.4V                | -                  |
| I <sub>IL</sub>      | Input Leakage Current<br>low                 | With no pull-up or pull-down<br>resistance (V <sub>IN</sub> = V <sub>SS</sub> or V <sub>DD</sub> ) | -10.0μA             | 10.0μΑ             |
| I <sub>IL_PU</sub>   | Input Leakage Current<br>Low with Pull-up    | -                                                                                                  | -100.0μA            | -4μΑ               |
| I <sub>IH_PD</sub>   | Input Leakage Current<br>High with Pull-down | -                                                                                                  | 4μΑ                 | 100µA              |
| I <sub>OZ</sub>      | Tristate Output<br>Leakage                   | $V_{OUT} = V_{DD} \text{ or } V_{SS}$                                                              | -10.0μA             | 10.0μA             |
| I <sub>DD</sub>      | Quiescent Supply<br>Current                  | $V_{IN} = V_{SS} \text{ or } V_{DD}$                                                               | -                   | 80μΑ <sup>b</sup>  |
| C <sub>IN</sub>      | Input Capacitance                            | -                                                                                                  | -                   | 10pF               |

Table 53: Non-PCI DC Electrical Characteristics (V<sub>DD</sub> ±5%)

a. For more information on PCI signal characteristics, see the PCI Local Bus Specification (Revision 2.2).

b. Depends on customer design.

| Symbols              | Parameters                                   | Min                                                        | Мах                                                            | Units                |      |
|----------------------|----------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------|----------------------|------|
| V <sub>IL</sub>      | Input low voltage                            | -                                                          | -0.5                                                           | 0.3*V <sub>DD</sub>  | V    |
| V <sub>IH</sub>      | Input high voltage                           | -                                                          | 0.5*V <sub>DD</sub>                                            | V <sub>DD</sub> +0.5 | V    |
| I <sub>IH</sub>      | Input high current                           | 0 <v<sub>IN<v<sub>DD</v<sub></v<sub>                       | -10                                                            | +10                  | μA   |
| I <sub>IL</sub>      | Input low current                            | 0 <v<sub>IN<v<sub>DD</v<sub></v<sub>                       | -10                                                            | +10                  | μΑ   |
| V <sub>OL</sub>      | Output low voltage                           | I <sub>OL</sub> =1500 μA                                   | -                                                              | 0.1*V <sub>DD</sub>  | V    |
| V <sub>OH</sub>      | Output high voltage                          | Ι <sub>ΟΗ</sub> =-500 μΑ                                   | 0.9*V <sub>DD</sub>                                            | -                    | V    |
| I <sub>OZ</sub>      | Output leakage current<br>tristate condition | $V_{OH}=V_{SS}$ or $V_{DD}$                                | -10                                                            | 10                   | μA   |
| I <sub>OH</sub> (AC) | Switching current high                       | $0 < V_{OUT} \le 0.3 V_{DD}$                               | -12*V <sub>DD</sub>                                            | -                    | mA   |
|                      |                                              | 0.3V <sub>DD</sub> <v<sub>OUT&lt;0.9V<sub>DD</sub></v<sub> | -17.1<br>(V <sub>DD</sub> -V <sub>OUT</sub> )                  | -                    | mA   |
|                      |                                              | 0.7V <sub>DD</sub> <v<sub>OUT<v<sub>DD -</v<sub></v<sub>   |                                                                | Eqn A <sup>a</sup>   | mA   |
|                      | (Test Point)                                 | V <sub>OUT</sub> =0.7V <sub>DD</sub>                       | -                                                              | $-32V_{DD}$          | mA   |
| I <sub>OL</sub> (AC) | Switching current low                        | V <sub>DD</sub> >V <sub>OUT</sub> >0.6V <sub>DD</sub>      | 16V <sub>DD</sub>                                              | -                    | mA   |
|                      |                                              | 0.6V <sub>DD</sub> >V <sub>OUT</sub> >0.1V <sub>DD</sub>   | 26.7V <sub>OUT</sub>                                           | -                    | mA   |
|                      |                                              | 0.18V <sub>DD</sub> >V <sub>OUT</sub> >0                   | -                                                              | Eqn B <sup>b</sup>   | mA   |
|                      | (Test Point)                                 | V <sub>OUT</sub> =0.18V <sub>DD</sub>                      | -                                                              | 38V <sub>DD</sub>    | mA   |
| I <sub>CL</sub>      | Low clamp current                            | -3 <v<sub>IN≤-1</v<sub>                                    | -25+(V <sub>IN</sub> -V <sub>D</sub><br><sub>D</sub> -1)/0.015 | -                    | mA   |
| I <sub>CH</sub>      | High clamp current                           | V <sub>DD</sub> +4>V <sub>IN</sub> >V <sub>DD</sub> +1     | 25+(Vin-V <sub>DD</sub><br>-1)/0.015                           | -                    | mA   |
| slewr                | Output rise slew rate                        | $0.2V_{DD}$ - $0.6V_{DD}$ load                             | 1                                                              | 4                    | V/ns |
| slewf                | Output fall slew rate                        | $0.6V_{DD}$ - $0.2V_{DD}$ load                             | 1                                                              | 4                    | V/ns |

Table 54: 3.3V PCI I/O Signaling AC/DC Characteristics (V<sub>DD</sub> ±5%)

a. Equation A:  $I_{OH}$ =(98.0/V<sub>DD</sub>)\*(V<sub>OUT</sub>V<sub>DD</sub>)\*(V<sub>OUT</sub>+0.4V<sub>DD</sub>) for V<sub>DD</sub> >V<sub>OUT</sub>>0.7V<sub>DD</sub>

b. Equation B:  $I_{OL}$ =(256/V<sub>DD</sub>) \* V<sub>OUT</sub> \* (V<sub>DD</sub> -V<sub>OUT</sub>) for 0v < V<sub>OUT</sub><0.18V<sub>DD</sub>

| Symbols              | Parameters                                | Test Conditions                         | Min                                     | Max                | Units |
|----------------------|-------------------------------------------|-----------------------------------------|-----------------------------------------|--------------------|-------|
| V <sub>IL</sub>      | Input low voltage                         | -                                       | -0.5                                    | 0.8                | V     |
| V <sub>IH</sub>      | Input high voltage                        | -                                       | 2.0                                     | 5.3 <sup>a</sup>   | V     |
| I <sub>IH</sub>      | Input high current                        | V <sub>IN</sub> =2.7                    | -                                       | +70                | μΑ    |
| ۱ <sub>IL</sub>      | Input low current                         | V <sub>IN</sub> =0.5                    | -                                       | -70                | μΑ    |
| V <sub>OL</sub>      | Output low voltage                        | I <sub>OL</sub> =3 mA, 6 mA             | -                                       | 0.55               | V     |
| V <sub>OH</sub>      | Output high voltage                       | I <sub>OH</sub> =-2 mA                  | 2.4                                     | -                  | V     |
| I <sub>OZ</sub>      | Output leakage current tristate condition | $\rm V_{OH}=V_{SS}$ or $\rm V_{DD}$     | -70                                     | 70                 | μA    |
| I <sub>OH</sub> (AC) | Switching current high                    | 0 <v<sub>OUT≤1.4</v<sub>                | -44                                     | -                  | mA    |
|                      |                                           | 1.4 <v<sub>OUT&lt;2.4</v<sub>           | -44 + (V <sub>OUT</sub><br>-1.4)/0.024  | -                  | mA    |
|                      |                                           | 3.1 <v<sub>OUT<v<sub>DD</v<sub></v<sub> | -                                       | Eqn C <sup>b</sup> | mA    |
|                      | (Test Point)                              | V <sub>OUT</sub> =3.1                   | -                                       | -142               | mA    |
| I <sub>OL</sub> (AC) | Switching current low                     | V <sub>OUT</sub> ≥2.2                   | 95                                      | -                  | mA    |
|                      |                                           | 2.2>V <sub>OUT</sub> >0.55              | V <sub>OUT</sub> /0.023                 | -                  | mA    |
|                      |                                           | 0.71>V <sub>OUT</sub> >0                | -                                       | Eqn D <sup>c</sup> | mA    |
|                      | (Test Point)                              | V <sub>OUT</sub> =0.71                  | -                                       | 206                | mA    |
| I <sub>CL</sub>      | Low clamp current                         | -5 <v<sub>IN≤-1</v<sub>                 | -25 +<br>(V <sub>IN</sub> +1)/0.01<br>5 | -                  | mA    |
| slewr                | Output rise slew rate                     | 0.4 to 2.4 load                         | 1                                       | 5                  | V/ns  |
| slewf                | Output fall slew rate                     | 2.4 to 0.4 load                         | 1                                       | 5                  | V/ns  |

Table 55: 5V PCI I/O Signaling AC/DC Electrical Characteristics

a. All signals are 5V tolerant.

b. Equation C: I\_{OH} = 11.9 \* (V\_{OUT} - 5.25) \* (V\_{OUT} + 2.45) for V\_{DD} > V\_{OUT} > 3.1V

c. Equation D: I\_{OL} = 78.5 \* V\_{OUT} \* (4.4 - V\_{OUT}) for 0V < V\_{OUT} < 0.71V

| Pin Name            | 17 mm<br>PBGA<br>Ball # | 27 mm<br>PBGA<br>Ball # | Туре | Input<br>Type | Output<br>Type | Reset<br>State | IOL<br>(mA) | IOH<br>(mA) | Interface | Signal Description                                                |
|---------------------|-------------------------|-------------------------|------|---------------|----------------|----------------|-------------|-------------|-----------|-------------------------------------------------------------------|
| A[31:0]             | See<br>Table 58         | See<br>Table 58         | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Address Lines                                                     |
| AD[31:0]            | See<br>Table 57         | See<br>Table 57         | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | Address/data Lines                                                |
| AS_                 | L16                     | N20                     | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Address Strobe                                                    |
| BB_/BGACK_          | L2                      | R1                      | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Bus Busy/bus Grant<br>Acknowledge                                 |
| BDIP_               | K14                     | M17                     | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Burst Data In<br>Progress<br>(And Tundra QSpan<br>II Master Mode) |
| BERR_/TEA_          | L15                     | N19                     | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Bus Error/ Transfer<br>Error Acknowledge                          |
| BG_                 | K16                     | M18                     | Ι    | TTL           | -              | -              | -           | -           | QBus      | Bus Grant                                                         |
| BGACK_              |                         |                         |      |               | Se             | e BB_/BO       | GACK_       |             |           |                                                                   |
| BM_EN/<br>FIFO_RDY_ | J14                     | M20                     | В    | TTL<br>(PD)   | 2S             | Hi-Z           | 8           | -8          | QBus      | Bus Master Enable                                                 |
| BR_                 | L1                      | R2                      | 0    | TTL           | 2S             | Hi-Z           | 8           | -8          | QBus      | Bus Request                                                       |
| BURST_/TIP_         | L4                      | N3                      | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Burst/transaction In<br>Progress                                  |
| C/BE[0]             | R11                     | W15                     |      |               |                |                | -           | -           |           | Command And Byte                                                  |
| C/BE[1]             | R9                      | W12                     | В    | PCI           | 3S             | Hi-Z           |             |             | PCI       | Enables                                                           |
| C/BE[2]             | N7                      | Y9                      |      |               |                |                |             |             |           |                                                                   |
| C/BE[3]             | T2                      | W4                      |      |               |                |                |             |             |           |                                                                   |
| CSPCI_              | P16                     | R20                     | Ι    | TTL           | -              | -              | -           | -           | QBus      | PCI Chip Select                                                   |
| CSREG_              | M13                     | T19                     | Ι    | TTL           | -              | -              | -           | -           | QBus      | QSpan Register<br>Chip Select                                     |
| D[31:0]             | See<br>Table 59         | See<br>Table 59         | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Data Lines                                                        |
| DP[0]               | A5                      | C6                      |      |               |                |                |             |             |           |                                                                   |
| DP[1]               | C5                      | B5                      | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Data Parity Line                                                  |
| DP[2]               | B5                      | A4                      |      |               |                |                |             |             |           |                                                                   |
| DP[3]               | D4                      | C5                      |      |               |                |                |             |             |           |                                                                   |
| DACK_/<br>SDACK_    | J13                     | K19                     | Ι    | TTL<br>Sch.   | -              | -              | -           | -           | QBus      | IDMA Acknowledge                                                  |
| DEVSEL#             | R8                      | Y11                     | В    | PCI           | 3S             | Hi-Z           | 8           | -8          | PCI       | Device Select                                                     |

Table 56: Pin List for QSpan II Signals

| Pin Name          | 17 mm<br>PBGA<br>Ball # | 27 mm<br>PBGA<br>Ball # | Туре | Input<br>Type | Output<br>Type | Reset<br>State | IOL<br>(mA) | IOH<br>(mA) | Interface | Signal Description                                         |
|-------------------|-------------------------|-------------------------|------|---------------|----------------|----------------|-------------|-------------|-----------|------------------------------------------------------------|
| DONE_             | J15                     | K17                     | Ι    | TTL           | -              | -              | -           | -           | QBus      | IDMA Done                                                  |
| DREQ_             | G13                     | J17                     | 0    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | IDMA Request                                               |
| DS_               | C10                     | A13                     | 0    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus      | Data Strobe                                                |
| DSACK0_           | G3                      | J4                      | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Data And Size<br>Acknowledge 0                             |
| DSACK1_/<br>TA_   | F1                      | H1                      | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Data And Size<br>Acknowledge 1/<br>Transfer<br>Acknowledge |
| ENID              | H15                     | J18                     | Ι    | TTL<br>PD     | -              | -              | -           | -           | -         | EEPROM Loading<br>Reset Options                            |
| ENUM#             | G4                      | K1                      | 0    | -             | OD             | Hi-Z           | 8           | -8          | -         | CompactPCI Hot<br>Swap event output                        |
| EXT_GNT#<br>[6:1] | See<br>Table 60         | See<br>Table 60         | 0    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | External Grant                                             |
| EXT_REQ#<br>[6:1] | See<br>Table 60         | See<br>Table 60         | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | External Request                                           |
| FRAME#            | P7                      | W10                     | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | Cycle Frame                                                |
| GNT#              | М3                      | U2                      | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | Grant (External<br>Grant 7)                                |
| HALT_/<br>TRETRY_ | M1                      | T1                      | В    | TTL<br>Sch.   | 3S             | Hi-Z           | 8           | -8          | QBus      | Halt/Transfer Retry                                        |
| HS_<br>HEALTHY_   | K4                      | N2                      | Ι    | TTL<br>(PD)   | -              | -              | -           | -           | -         | Hot Swap Healthy<br>Signal                                 |
| HS_LED            | H2                      | L2                      | 0    | -             | OD             | Low            | 8           | -8          | -         | LED control output<br>for Hot Swap                         |
| HS_SWITCH         | J2                      | L4                      | Ι    | TTL<br>(PD)   | -              | -              | -           | -           | -         | Switch input for<br>Hot Swap                               |
| IDSEL             | N12                     | Y16                     | I    | PCI           | -              | -              | -           | -           | PCI       | Initialization Device<br>Select                            |
| IMSEL             | H4                      | L1                      | Ι    | TTL           | -              | -              | -           | -           | QBus      | Slave Image Select                                         |
| INT#              | M14                     | T18                     | В    | PCI           | OD             | Hi-Z           | 8           | -8          | PCI       | Interrupt                                                  |
| IRDY#             | R7                      | V10                     | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | Initiator Ready                                            |
| PAR               | N10                     | Y12                     | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI       | Parity                                                     |

Table 56: Pin List for QSpan II Signals (Continued)

| Pin Name   | 17 mm<br>PBGA<br>Ball # | 27 mm<br>PBGA<br>Ball # | Туре | Input<br>Type | Output<br>Type | Reset<br>State | IOL<br>(mA) | IOH<br>(mA) | Interface  | Signal Description                                                  |
|------------|-------------------------|-------------------------|------|---------------|----------------|----------------|-------------|-------------|------------|---------------------------------------------------------------------|
| PCI_ARB_EN | C4                      | B4                      | I    | TTL<br>(PD)   | -              | -              | -           | -           | PCI        | Power up option to<br>enable PCI Bus<br>Arbiter                     |
| PCI_DIS    | КЗ                      | M4                      | Ι    | TTL<br>(PD)   | -              | -              | -           | -           | PCI        | Power up option to<br>disable PCI config<br>accesses to<br>QSpan II |
| PCLK       | P8                      | W11                     | I    | PCI           | -              | -              | -           | -           | PCI        | PCI Clock                                                           |
| PERR#      | N9                      | U11                     | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI        | Parity Error                                                        |
| PME#       | J1                      | M2                      | 0    | -             | OD             | Hi-Z           | 8           | -8          | -          | Power management event                                              |
| QCLK       | D8                      | A10                     | I    | TTL           | -              | -              | -           | -           | QBus       | QBus clock                                                          |
| QINT_      | H16                     | J19                     | В    | TTL           | OD             | Hi-Z           | 8           | -8          | QBus       | Interrupt                                                           |
| REQ#       | M4                      | Т3                      | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI        | Request (External<br>Request 7)                                     |
| RESETI_    | J4                      | М3                      | Ι    | TTL<br>Sch.   | -              | -              | -           | -           | QBus       | Reset Input                                                         |
| RESETO_    | K1                      | N1                      | 0    | TTL           | OD             | Hi-Z           | 8           | -8          | QBus       | Reset Output                                                        |
| RETRY_     |                         |                         |      |               | See            | HALT_/T        | RETRY_      |             |            |                                                                     |
| RST#       | M2                      | P4                      | I    | PCI           | -              | -              | -           | -           | PCI        | Reset                                                               |
| R/W_       | D1                      | G3                      | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus       | Read/Write                                                          |
| SCL        | H3                      | K3                      | 0    | TTL           | 3S             | Hi-Z           | 8           | -8          | EEPRO<br>M | Serial Clock                                                        |
| SDA        | G1                      | J1                      | В    | TTL           | OD             | Hi-Z           | 8           | -8          | EEPRO<br>M | Serial Data                                                         |
| SDACK_     |                         |                         |      |               | See            | DSACK_/        | SDACK_      |             |            |                                                                     |
| SERR#      | M15                     | U20                     | В    | TTL           | OD             | Hi-Z           | 8           | -8          | PCI        | System Error                                                        |
| SIZ[0]     | G2                      | J2                      | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus       | 0                                                                   |
| SIZ[1]     | F4                      | J3                      |      |               |                |                |             |             |            | Size                                                                |
| STOP#      | T7                      | V11                     | В    | PCI           | 3S             | Hi-Z           | -           | -           | PCI        | Stop                                                                |
| TA_        |                         |                         |      |               | Se             | e DSACK        | 1_/TA_      |             |            |                                                                     |
| TC[0]      | N16                     | P18                     |      |               |                |                |             |             |            |                                                                     |
| TC[1]      | L14                     | P19                     | В    | TTL           | 3S             | Hi-Z           | 8           | -8          | QBus       | Transaction Code                                                    |
| TC[2]      | M16                     | P20                     |      |               |                |                |             |             |            |                                                                     |
| TC[3]      | L13                     | N18                     |      |               |                |                |             |             |            |                                                                     |

| Pin Name | 17 mm<br>PBGA<br>Ball # | 27 mm<br>PBGA<br>Ball # | Туре | Input<br>Type    | Output<br>Type | Reset<br>State | IOL<br>(mA) | IOH<br>(mA) | Interface | Signal Description        |
|----------|-------------------------|-------------------------|------|------------------|----------------|----------------|-------------|-------------|-----------|---------------------------|
| тск      | H13                     | J20                     | Ι    | TTL              | -              | Hi-Z           | -           | -           | JTAG      | JTAG Test Clock<br>Input  |
| TDI      | K15                     | L18                     | I    | TTL<br>(PU)      | -              | Hi-Z           | -           | -           | JTAG      | JTAG Test Data<br>Input   |
| TDO      | K13                     | M19                     | 0    | TTL              | 3S             | Hi-Z           | 8           | -8          | JTAG      | JTAG Test Data<br>Output  |
| TEA_     |                         |                         |      |                  | Se             | e BERR_        | /TEA_       |             |           |                           |
| TEST1    | B12                     | B15                     | I    | CMO<br>S<br>(PU) | -              | -              | -           | -           | -         | Manufacturing Test<br>Pin |
| TEST2    | A14                     | D14                     | Ι    | TTL<br>(PD)      | -              | -              | -           | -           | -         | Manufacturing Test<br>Pin |
| TEST3    | C12                     | C15                     | I    | TTL<br>(PD)      | -              | -              | -           | -           | -         | Manufacturing Test<br>Pin |
| TIP_     |                         |                         |      |                  | Se             | e BURST        | _/TIP_      |             |           |                           |
| TMODE[0] | J3                      | M1                      | 1    | TTL              | -              | _              | -           | -           | -         |                           |
| TMODE[1] | H1                      | L3                      |      | (PD)             | _              |                |             | -           | -         | Test Mode Pins            |
| TMS      | J16                     | K20                     | Ι    | TTL<br>(PU)      | -              | -              | -           | -           | JTAG      | JTAG Mode Select          |
| TRDY#    | N8                      | Y10                     | В    | PCI              | 3S             | Hi-Z           | -           | -           | PCI       | Target Ready              |
| TRST_    | H14                     | K18                     | Ι    | TTL<br>(PU)      | -              | -              | -           | -           | JTAG      | JTAG Test Reset           |
| TS_      | K2                      | P2                      | В    | TTL<br>Sch.      | 3S             | Hi-Z           | 8           | -8          | QBus      | Transfer Start            |

Table 56: Pin List for QSpan II Signals (Continued)

| Signal | 17 mm<br>PBGA | 27 mm<br>PBGA | Signal | 17 mm<br>PBGA | 27 mm<br>PBGA |
|--------|---------------|---------------|--------|---------------|---------------|
| AD0    | N15           | V20           | AD16   | P6            | W9            |
| AD1    | N14           | U18           | AD17   | T6            | U9            |
| AD2    | T16           | W20           | AD18   | T5            | Y8            |
| AD3    | P15           | V19           | AD19   | R6            | W8            |
| AD4    | T14           | Y20           | AD20   | N6            | V8            |
| AD5    | T13           | V18           | AD21   | P5            | Y7            |
| AD6    | P14           | W18           | AD22   | N5            | V7            |
| AD7    | P12           | U14           | AD23   | T1            | U5            |
| AD8    | T10           | V14           | AD24   | R2            | W3            |
| AD9    | P11           | Y15           | AD25   | R3            | Y2            |
| AD10   | N11           | W14           | AD26   | P3            | Y1            |
| AD11   | P10           | Y14           | AD27   | N3            | W2            |
| AD12   | R10           | V13           | AD28   | N4            | W1            |
| AD13   | Т9            | W13           | AD29   | P2            | U3            |
| AD14   | Т8            | Y13           | AD30   | P1            | V2            |
| AD15   | P9            | V12           | AD31   | N2            | T4            |

Table 57: PCI Bus Address/Data Pins

| Signal | 17 mm<br>PBGA | 27 mm<br>PBGA | Signal | 17 mm<br>PBGA | 27 mm<br>PBGA |
|--------|---------------|---------------|--------|---------------|---------------|
| A0     | G14           | G20           | A16    | A9            | D10           |
| A1     | G16           | G19           | A17    | D7            | A9            |
| A2     | G15           | F20           | A18    | B8            | C9            |
| A3     | F14           | F19           | A19    | C7            | D9            |
| A4     | F16           | E20           | A20    | A8            | B8            |
| A5     | E16           | G17           | A21    | A7            | C8            |
| A6     | C13           | C17           | A22    | B7            | A7            |
| A7     | B16           | B17           | A23    | D6            | B7            |
| A8     | C14           | A18           | A24    | C6            | A6            |
| A9     | A15           | B16           | A25    | A6            | C7            |
| A10    | D12           | C16           | A26    | C1            | E3            |
| A11    | C11           | C14           | A27    | E3            | E1            |
| A12    | D11           | B14           | A28    | E4            | F2            |
| A13    | A13           | A14           | A29    | E1            | G2            |
| A14    | A12           | C13           | A30    | F3            | H3            |
| A15    | B11           | B13           | A31    | F2            | H2            |

| Signal | 17 mm<br>PBGA | 27 mm<br>PBGA | Signal | 17 mm<br>PBGA | 27 mm<br>PBGA |
|--------|---------------|---------------|--------|---------------|---------------|
| D0     | F15           | F18           | D16    | C9            | C11           |
| D1     | E15           | E19           | D17    | A10           | A11           |
| D2     | E14           | E18           | D18    | B9            | B10           |
| D3     | D16           | E17           | D19    | C8            | C10           |
| D4     | D15           | C20           | D20    | B6            | B6            |
| D5     | F13           | D18           | D21    | D5            | D7            |
| D6     | E13           | B20           | D22    | A4            | A3            |
| D7     | D14           | B19           | D23    | A3            | C4            |
| D8     | C16           | C18           | D24    | B4            | D5            |
| D9     | C15           | A20           | D25    | A2            | B3            |
| D10    | B14           | B18           | D26    | B3            | A2            |
| D11    | B15           | A19           | D27    | C3            | C2            |
| D12    | D10           | D12           | D28    | B1            | B1            |
| D13    | A11           | C12           | D29    | D3            | D3            |
| D14    | D9            | B12           | D30    | D2            | C1            |
| D15    | B10           | B11           | D31    | C2            | E4            |

Table 59: QBus Data Pins

## Table 60: External Request and Grant Pins

| Signal      | 17 mm<br>PBGA | 27 mm<br>PBGA | Signal      | 17 mm<br>PBGA | 27 mm<br>PBGA |
|-------------|---------------|---------------|-------------|---------------|---------------|
| EXT_REQ[1]# | T11           | Y17           | EXT_GNT[1]# | R1            | V5            |
| EXT_REQ[2]# | R12           | V16           | EXT_GNT[2]# | R4            | W5            |
| EXT_REQ[3]# | N13           | W17           | EXT_GNT[3]# | Т3            | Y5            |
| EXT_REQ[4]# | P13           | Y18           | EXT_GNT[4]# | P4            | V6            |
| EXT_REQ[5]# | T12           | U16           | EXT_GNT[5]# | R5            | U7            |
| EXT_REQ[6]# | R13           | V17           | EXT_GNT[6]# | T4            | W6            |

| 17 mm PBGA       |     |                  |     | 27 mm PBGA |                 |
|------------------|-----|------------------|-----|------------|-----------------|
| A16 <sup>a</sup> | F12 | M5               | D2  | D15        | T2              |
| B2 <sup>a</sup>  | G5  | M6               | V3  | F4         | D20             |
| E5               | G12 | M7               | U12 | F17        | B2              |
| E6               | H5  | M8               | Y19 | K4         | R3 <sup>a</sup> |
| E7               | H12 | M9               | U19 | L17        | -               |
| E8               | J5  | M10              | G18 | R4         | -               |
| E9               | J12 | M11              | C19 | R17        | -               |
| E10              | K5  | M12              | D16 | U6         | -               |
| E11              | K12 | N1 <sup>a</sup>  | A5  | U10        | -               |
| E12              | L5  | R15 <sup>a</sup> | D6  | U15        | -               |
| F5               | L12 | -                | D11 | E2         | -               |

### Table 61: Pin Assignments for Power (V<sub>DD</sub>)

a. These power pins are called VH. These pins must be connected to the highest voltage level that the QSpan II I/Os will observe on either the QBus or the PCI bus (see Table 62).

Table 62: Voltage Required to be Applied to VH

| PCI Bus Voltage (V) | QBus Voltage (V) | VH Voltage (V)   |
|---------------------|------------------|------------------|
| 3.3                 | 3.3              | 3.3              |
| 5                   | 5                | 5                |
| 3.3                 | 5                | 5                |
| 5                   | 3.3              | 5                |
| VIO <sup>a</sup>    | 3.3              | VIO <sup>a</sup> |
| VIO <sup>a</sup>    | 5                | 5                |

a. VIO denotes the signal connection to the PCI bus connector for Universal Signaling.

| 17 mm PBGA |     |     |     | 27 mm PBGA |     |
|------------|-----|-----|-----|------------|-----|
| F6         | H6  | K6  | F1  | A12        | U8  |
| F7         | H7  | K7  | U1  | A8         | U13 |
| F8         | H8  | K8  | V1  | A1         | U17 |
| F9         | H9  | K9  | V9  | D4         | -   |
| F10        | H10 | K10 | H19 | D8         | -   |
| F11        | H11 | K11 | D19 | D13        | -   |
| G6         | J6  | L6  | D1  | D17        | -   |
| G7         | J7  | L7  | P3  | H4         | -   |
| G8         | J8  | L8  | W7  | H17        | -   |
| G9         | J9  | L9  | W19 | N4         | -   |
| G10        | J10 | L10 | T17 | N17        | -   |
| G11        | J11 | L11 | L20 | U4         | -   |

### Table 63: Pin Assignments for Ground (V<sub>SS</sub>)

### Table 64: No-connect Pin Assignments<sup>a</sup>

| 17 mm PBGA |     | 27 mm PBGA |     |  |  |
|------------|-----|------------|-----|--|--|
| A1         | A15 | H18        | T20 |  |  |
| B13        | A16 | H20        | V4  |  |  |
| D13        | A17 | K2         | V15 |  |  |
| E2         | В9  | L19        | W16 |  |  |
| L3         | C3  | P1         | Y3  |  |  |
| R14        | F3  | P17        | Y4  |  |  |
| R16        | G1  | R18        | Y6  |  |  |
| T15        | G4  | R19        | -   |  |  |

a. Route all N/C signals out to vias on your board to allow for future migration to new QSpan II variants.

# 17.4 Pinout

### Table 65: Pinout of 17x17 mm Package

| A1. NC         D5. D[21]         G9. VSS         K13. TDO         P1. AD[30]           A2. D[25]         D6. A[23]         G10. VSS         K14. BDIP         P2. AD[26]           A3. D[22]         D8. OCLK         G12. VDD         K16. BG         P4. EXT_GNT[4]#           A5. DP[0]         D9. D[14]         G13. DREQ_         L1. BRGACK         P6. AD[21]           A6. A[25]         D10. D[12]         G14. A[0]         L2. BBBGACK         P6. AD[21]           A6. A[26]         D10. D[12]         G14. A[0]         L2. BBBGACK         P6. AD[21]           A6. A[20]         D12. A[10]         G16. A[1]         L4. BURST_/TIP         P8. AD[15]           A1. D[17]         D14. D[7]         H2. HS_LED         L6. VSS         P11. AD[9]           A12. A[14]         D16. D[3]         H4. MSEL         L8. VSS         P12. AD[7]           A13. A[13]         E1. A[29]         H5. VDD         L9. VSS         P14. AD[6]           A14. TESTZ         E2. NC         H6. VSS         L10. VSS         P14. AD[6]           A15. A[9]         E3. A[27]         H7. VSS         L11. VSS         P14. AD[6]           A14. TESTZ         E2. NC         H6. VSS         L13. TC3         R1. EXT_RC0[4]#                                                                                                | A4 N/C     |           |               |                   |                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|---------------|-------------------|------------------|
| A3. D[23]         D7. A[17]         G11. VSS         K15. TDI         P3. AD[26]           A4. D[22]         D8. OCLK         G12. VDD         K16. BG_         P4. EXT_CONT[4]#           A5. DP[0]         D9. D[14]         G13. DREQ_         L1. BR_         P5. AD[21]           A6. A[25]         D10. D[12]         G14. A[0]         L2. BB_JBGACK_         P6. AD[16]           A7. A[21]         D11. A[12]         G14. A[0]         L2. BB_JBGACK_         P6. AD[16]           A8. A[16]         D12. A[10]         G16. A[1]         L4. BURST_/TIP_         P8. AD[16]           A9. AT[6]         D13. NC         H1. TMODE[1]         L5. VDS         P10. AD[11]           A11. D[13]         D15. D[4]         H3. SCL         L7. VSS         P11. AD[7]           A12. A[14]         D16. D[3]         H4. MISEL         L8. VSS         P12. AD[7]           A13. A[13]         E1. A[29]         H5. VDD         L9. VSS         P14. AD[6]           A14. TESTZ         E2. NC         H6. VSS         L10. VSS         L11. VSS         P14. SAD[26]           A14. TESTZ         E2. NC         H9. VSS         L13. TC3         R1. EXT_GNT[3]#           B1. D2[2]         E5. VDD         H10. VSS         L14. TC1         R2. AD[24] <td></td> <td></td> <td></td> <td></td> <td></td>                  |            |           |               |                   |                  |
| A4. D[22]       D8. OCLK       G12, VDD       K16. BG_       P4. EXT_GNT[4]#         A5. D[0]       D9. D[14]       G13. DREQ_       L1. BR_       P5. AD[21]         A6. A[22]       D10. D[12]       G14. A[0]       L2. BB_BGACK_       P6. AD[16]         A7. A[21]       D11. A[12]       G15. A[2]       L3. NC       P7. FRAME#         A8. A[20]       D12. A[10]       G16. A[1]       L4. BURST_TIP       P8. PCLK         A8. A[20]       D12. A[10]       G16. A[1]       L4. BURST_TIP       P8. PCLK         A8. A[20]       D12. A[10]       G16. A[1]       L4. BURST_TIP       P8. PCLK         A9. A1[6]       D13. NC       H1. TMODE[1]       L5. VDD       P9. AD[16]         A10. D[17]       D14. D[7]       H2. HS_LED       L6. VSS       P11. AD[9]         A12. A[14]       D16. D[3]       H4. MSEL       L8. VSS       P13. EXT_REQ[4]#         A13. A[13]       E1. A[29]       H5. VDD       L9. VSS       P14. AD[6]         A14. TEST2       E2. NC       H6. VSS       L10. VSS       P14. AD[6]         A14. HEST2       E2. ND       H9. VSS       L13. TC3       R1. EXT_GNT[1]#         B2. VH       E6. VDD       H10. VSS       L14. TC1       R2. AD[22]                                                                                                                                       |            |           |               |                   |                  |
| AS. DP[0]         D9. 0[14]         G13. DREQ_         L1. BR_         P5. AD[21]           A6. A[25]         D10. D[12]         G14. A[0]         L2. BB_/BGACK_         P6. AD[16]           A7. A[21]         D11. A[12]         G14. A[0]         L2. BB_/BGACK_         P6. AD[16]           A8. A[16]         D12. A[10]         G16. A[1]         L4. BURST_TIP_         P9. AD[16]           A8. A[16]         D13. NC         H1. TMODE[1]         L5. VDD         P9. AD[16]           A10. D[17]         D14. D[7]         H2. HS_LED         L6. VSS         P1. AD[9]           A12. A[14]         D16. D[3]         H4. IMSEL         L8. VSS         P14. AD[6]           A14. TESTZ         E2. NC         H6. VSS         L10. VSS         P14. AD[6]           A15. A[4]         E3. A[27]         H7. VSS         L11. VSS         P16. CSPCL           B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R1. EXT_GNT[1]#           B2. D[21]         E5. VDD         H1. VSS         L15. AD[2]         E5. AD[2]           B3. D[22]         E7. VDD         H11. VSS         L15. BERR_TRA_         R3. AD[26]           B3. D[22]         E7. VDD         H13. TCK         M1. HALT_TRETRA_         R3. DD[26]                                                                                  |            |           |               |                   |                  |
| A6. A[25]         D10. D[12]         G14. A[0]         L2. BB_/BGACK_         P6. AD[16]           A7. A[21]         D11. A[12]         G15. A[2]         L3. N/C         P7. FRAME#           A8. A[20]         D12. A[10]         G16. A[1]         L4. BURST_/TIP_         P8. PCLK           A9. A[16]         D13. N/C         H1. TMODE[1]         L5. VDD         P9. AD[15]           A10. D[17]         D14. A[D7]         H2. KS_LED         L6. VSS         P11. AD[9]           A12. A[14]         D16. D[3]         H4. IMSEL         L8. VSS         P13. EXT_REO[4]#           A13. A[13]         E1. A[29]         H5. VDD         L9. VSS         P13. EXT_REO[4]#           A14. TEST2         E2. N/C         H6. VSS         L10. VSS         P14. AD[6]           A14. FEST2         E2. N/C         H6. VSS         L11. VSS         P16. CSPC]           B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R8. AD[24]           B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H13. TCK         M1. HALT_/TRETRY_         R6. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TST_         M2. AD[4]         R8. VDD         R9. DEST <td></td> <td></td> <td></td> <td></td> <td></td>                  |            |           |               |                   |                  |
| A7. A[21]       D11. A[12]       G15. A[2]       L3. N/C       P7. FRAME#         A8. A[20]       D12. A[10]       G16. A[1]       L4. BURST_TIP_       P8. PCLK         A9. A[16]       D13. N/C       H1. TMODE[1]       L5. VDD       P9. AD[15]         A10. D[17]       D14. D[7]       H2. HS_LED       L6. VSS       P11. AD[9]         A11. D[13]       D15. D[4]       H3. SCL       L7. VSS       P11. AD[9]         A12. A[14]       D16. D[3]       H4. IMSEL       L8. VSS       P12. AD[7]         A13. A[13]       E1. A[29]       H5. VDD       L9. VSS       P14. AD[6]         A14. TEST2       E2. N/C       H6. VSS       L10. VSS       P14. AD[6]         A15. A[9]       E3. A[27]       H7. VSS       L11. VSS       P16. CSPC]         B1. D[26]       E5. VDD       H9. VSS       L13. TC3       R1. EXT_GMT[1]#         B2. VH       E6. VDD       H10. VSS       L14. TC1       R2. AD[24]         B3. D[26]       E7. VDD       H14. TRST_       M2. RST_R       R6. AD[19]         B4. D[24]       E8. VDD       H14. TRST_       M2. RST_R       R6. AD[14]         B5. D[2]       E10. VDD       H14. TRST_       M2. RST_R       R6. AD[19]         B7. A[                                                                                                                                             |            |           |               | _                 |                  |
| A8. A[20]         D12. A[10]         G16. A[1]         L4. BURST_TIP.         P8. PCLK           A9. A[16]         D13. NIC         H1. TMODE[1]         L5. VDD         P9. AD[15]           A10. D[17]         D14. D[7]         H2. HS, LED         L6. VSS         P10. AD[11]           A11. D[13]         D15. D[4]         H3. SCL         L7. VSS         P11. AD[9]           A13. A[13]         E1. A[29]         H5. VDD         L9. VSS         P13. EXT_REG4]#           A14. TEST2         E2. N/C         H6. VSS         L10. VSS         P14. AD[6]           A15. A[9]         E3. A[27]         H7. VSS         L11. VSS         P15. AD[3]           A15. A[9]         E3. VD1         H9. VSS         L13. TC3         R1. EXT_GNT[1]#           B3. D[26]         E7. VDD         H10. VSS         L16. SBERR_TEA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |           |               |                   |                  |
| A8, A[16]         D13, N/C         H1, TMODE[1]         L5, VDD         P9, AD[15]           A10, D[17]         D14, D[7]         H2, HS, LED         L6, VSS         P11, AD[1]           A11, D[13]         D15, D[4]         H3, SCL         L7, VSS         P11, AD[9]           A12, A[14]         D16, D[3]         H4, IMSEL         L8, VSS         P12, AD[7]           A13, A[13]         E1, A[29]         H5, VDD         L9, VSS         P13, EXT_REQ[4]#           A14, TEST2         E2, N/C         H6, VSS         L11, VSS         P14, AD[6]           A16, VH         E4, A[28]         H8, VSS         L12, VDD         P16, CSPCL           B1, D[28]         E5, VDD         H0, VSS         L14, TC1         R2, AD[24]           B3, D[26]         E7, VDD         H11, VSS         L16, AS_R         R4, EXT_GNT[2]#           B5, DP[2]         E9, VDD         H13, TCK         M1, HALT_TRETRY_R         R6, AD[19]           B6, A[16]         E10, VDD         H15, ENID         M3, GNT#         R7, IRDY#           B6, A[16]         E14, D[2]         J2, HS_SWITCH         M6, VDD         R10, CBE[0]           B10, D[16]         E14, D[2]         J4, RESETL_M8, VDD         R12, EXT_REQ[6]#           B14, D[10] <t< td=""><td></td><td></td><td></td><td></td><td></td></t<>                 |            |           |               |                   |                  |
| A10. D[17]       D14. D[7]       H2. H2, LED       L6. VSS       P10. AD[11]         A11. D[13]       D15. D[4]       H3. SCL       L7. VSS       P11. AD[9]         A12. A[14]       D16. D[3]       H4. IMSEL       L8. VSS       P12. AD[7]         A13. A[13]       E1. A[29]       H5. VDD       L9. VSS       P13. EXT_REQ[4]#         A14. TEST2       E2. N/C       H6. VSS       L10. VSS       P14. AD[6]         A15. A[9]       E3. A[27]       H7. VSS       L11. VSS       P16. CSPC_]         B1. D[28]       E5. VDD       H9. VSS       L13. TC3       R1. EXT_GNT[1]#         B2. VH       E6. VDD       H10. VSS       L16. AS_       R4. EXT_GNT[2]#         B4. D[24]       E8. VDD       H13. TCK       M1. HALT_/TRETRY_       R6. EXT_GNT[2]#         B5. DP[2]       E9. VDD       H13. TCK       M1. HALT_/TRETRY_       R6. EXT_GNT[2]#         B5. DP[2]       E9. VDD       H16. QINT                                                                                                                                                                                                                                                                                                                                                                                                                      |            |           |               |                   |                  |
| A11. D[13]         D15. D[4]         H3. SCL         L7. VSS         P11. AD[9]           A12. A[14]         D16. D[3]         H4. IMSEL         L8. VSS         P12. AD[7]           A13. A[13]         E1. A[29]         H5. VDD         L9. VSS         P13. EXT_REC[4]#           A14. TEST2         E2. N/C         H6. VSS         L10. VSS         P14. AD[6]           A15. A[9]         E3. A[27]         H7. VSS         L11. VSS         P16. CSPC1_           B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R1. EXT_GONT[1]#           B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H13. TCK         M1. HALT_TRET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |               |                   |                  |
| A12. A[14]       D16. D[3]       H4. IMSEL       L8. VSS       P12. AD[7]         A13. A[13]       E1. A[29]       H5. VDD       L9. VSS       P14. AD[6]         A14. TEST2       E2. N/C       H6. VSS       L10. VSS       P14. AD[6]         A14. TEST2       E2. N/C       H6. VSS       L10. VSS       P14. AD[6]         A15. A[9]       E3. A[27]       H7. VSS       L11. VSS       P16. CSPC]         B1. D[28]       E5. VDD       H9. VSS       L13. TC3       R1. EXT_GNT[1]#         B2. VH       E6. VDD       H10. VSS       L14. TC1       R2. AD[24]         B3. D[26]       E7. VDD       H11. VSS       L15. BERR_TEA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |           | —             |                   |                  |
| A13. $\hat{A}[13]$ E1. $A[29]$ H5. VDDL9. VSSP13. $EXT_REQ[4]\#$ A14. TEST2E2. N/CH6. VSSL10. VSSP14. AD[6]A15. A[9]E3. A[27]H7. VSSL11. VSSP15. AD[6]A16. VHE4. A[28]H8. VSSL12. VDDP16. CSPCLB1. D[28]E5. VDDH10. VSSL13. TC3R1. EXT_GNT[1]#B2. VHE6. VDDH10. VSSL14. TC1R2. AD[24]B3. D[26]E7. VDDH11. VSSL16. BERR_TEAR3. AD[25]B4. D[24]E8. VDDH13. TCKM1. HALT_TRETRYR5. EXT_GNT[5]#B5. DP[2]E9. VDDH13. TCKM1. HALT_TRETRYR6. EXT_GNT[5]#B6. D[20]E10. VDDH16. CINT_M4. REQ#R8. DEVSEL#B7. A[22]E11. VDDH16. CINT_M4. REQ#R8. DEVSEL#B9. D[18]E13. D[6]J1. PME#M5. VDDR9. CBE[1]B10. D[15]E14. D[2]J2. HS_SWITCHM6. VDDR10. AD[12]B13. N/CF1. DSACK1_TA_J5. VDDM9. VDDR13. EXT_REQ[2]#B13. N/CF1. DSACK1_TA_J5. VSDM10. VDDR14. N/CB14. D[10]F2. A[31]J6. VSSM10. VDDR14. N/CB14. A[11]F3. A[30]J7. VSSM10. VDDR14. N/CB15. D[11]F3. A[30]J7. VSSM10. VDDR14. N/CB15. D[11]F3. ASSM10. VDDR14. N/CCBE[3]G3. D[27]F7. VSSJ10. VSSM15. SERR#T3. EXT_GNT[6]#G4. A[7]F4. SVSS <td></td> <td></td> <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                      |            |           |               |                   |                  |
| A14. TEST2         E2. N/C         H6. VSS         L10. VSS         P14. AD[6]           A15. A[9]         E3. A[27]         H7. VSS         L11. VSS         P15. AD[3]           A16. VH         E4. A[28]         H8. VSS         L12. VDD         P16. CSPCL_           B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R1. EXT_GNT[1]#           B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H11. VSS         L16. AS         R4. EXT_GNT[2]#           B4. D[24]         E8. VDD         H12. VDD         L16. AS         R4. EXT_GNT[2]#           B5. D[21]         E9. VDD         H14. TRST         M2. RST#         R6. AD[19]           B6. D[20]         E10. VDD         H16. CINT         M4. REQ#         R8. DEVSEL#           B9. D[16]         E13. D[6]         J1. PME#         M5. VDD         R9. CSE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B1. A[16]         E15. D[1]         J3. TMODE[0]         M7. VDD         R12. EXT_REQ[2]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R12. EXT_REQ[2]#           B14. D[10]                                                                               |            |           |               |                   | • •              |
| A15. A[9]         E3. A[27]         H7. VSS         L11. VSS         P15. AD[3]           A16. VH         E4. A[28]         H8. VSS         L12. VDD         P16. CSPCL           B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R1. EXT_GNT[1]#           B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H11. VSS         L16. SERR_TEA_         R3. AD[25]           B4. D[24]         E8. VDD         H12. VDD         L16. AS_         R4. EXT_GNT[2]#           B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_TRETRY_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H15. ENID         M3. GNT#         R6. AD[19]           B7. A[22]         E11. VDD         H15. ENID         M3. GNT#         R6. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B13. NC         F1. DSACK1_TA_         J5. VDD         M8. VDD         R13. EXT_REQ[8]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. NC           B14. AD[17] </td <td></td> <td></td> <td></td> <td></td> <td></td>                  |            |           |               |                   |                  |
| A16. VH       E4. A[28]       H8. VSS       L12. VDD       P16. CSPCL_         B1. D[28]       E5. VDD       H9. VSS       L13. TC3       R1. EXT_GNT[1]#         B2. VH       E6. VDD       H10. VSS       L14. TC1       R2. AD[24]         B3. D[26]       E7. VDD       H11. VSS       L15. BERR_/TEA_       R3. AD[25]         B4. D[24]       E8. VDD       H12. VDD       L16. AS_       R4. EXT_GNT[2]#         B5. DP[2]       E9. VDD       H13. TCK       M1. HALT_/TRETRY_       R5. EXT_GNT[6]#         B6. D[20]       E10. VDD       H14. TRST_       M2. RST#       R6. AD[19]         B7. A[22]       E11. VDD       H15. ENID       M3. GNT#       R7. IRDV#         B8. D[18]       E13. D[6]       J1. PME#       M5. VDD       R9. CEE[1]         B10. D[15]       E14. D[2]       J2. HS_SWITCH       M6. VDD       R10. AD[12]         B11. A[15]       E15. D[1]       J3. TMODE[0]       M7. VDD       R11. CET_REQ[2]#         B13. NC       F1. DSACK1_TA_       J5. VDD       M9. VDD       R12. EXT_REQ[6]#         B14. D[10]       F2. A[31]       J6. VSS       M10. VDD       R14. NC         C1. A[26]       F5. VDD       J9. VSS       M13. CSREG_       T1. AD[23] <td></td> <td></td> <td></td> <td></td> <td></td>                                                                               |            |           |               |                   |                  |
| B1. D[28]         E5. VDD         H9. VSS         L13. TC3         R1. EXT_GNT[1]#           B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H11. VSS         L15. BERR_TEA_         R3. AD[25]           B4. D[24]         E8. VDD         H12. VDD         L16. AS_         R4. EXT_GNT[2]#           B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_TRETRY_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H16. QINT_         M4. REQ#         R8. DEVSEL#           B8. D[18]         E13. D[6]         J1. PME#         M6. VDD         R9. CBE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R12. EXT_REQ[6]#           B13. N/C         F1. DSACK1_TTA_         J5. VDD         M9. VDD         R14. NC           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. NC           B14. A[10]         F2. A[31]         J8. VSS         M13. CSRE6_         T1. AD[23]           C                                                                       |            |           |               |                   |                  |
| B2. VH         E6. VDD         H10. VSS         L14. TC1         R2. AD[24]           B3. D[26]         E7. VDD         H11. VSS         L15. BER_TEA_         R3. AD[25]           B4. D[24]         E8. VDD         H12. VDD         L16. AS_         R4. EXT_GNT[2]#           B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_TRETR_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H16. CINT_         M4. REC#         R8. DEVSEL#           B8. A[18]         E12. VDD         H16. CINT_         M4. REC#         R8. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R10. AD[12]           B11. A[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R1. CB[1]           B13. D[16]         E14. D[2]         J2. HS_SWITCH         M8. VDD         R12. EXT_REC[2]#           B13. N/C         F1. DSACK1_TA         J5. VDD         M9. VDD         R13. EXT_REC[6]#           B14. D[10]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B15. D[11]         F3. A[30]         J7. VSS         M13. CSREG                                                                                                  |            |           |               |                   |                  |
| B3. D[26]         E7. VDD         H11. VSS         L15. BERR_TEA_         R3. AD[25]           B4. D[24]         E8. VDD         H12. VDD         L16. AS_         R4. EXT_GNT[2]#           B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_TRETRY_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H16. GINT_         M4. REQ#         R8. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R0. CBE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R1. CBE[0]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETL_         M8. VDD         R12. EXT_REQ[2]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#                                                                              |            |           |               |                   |                  |
| B4. D[24]         E8. VDD         H12. VDD         L16. AS_         R4. EXT_GNT[2]#           B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_TRETRY_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H15. ENID         M3. GNT#         R7. IRDY#           B8. A[18]         E12. VDD         H16. QINT_         M4. REQ#         R8. DEVSEL#           B9. D[16]         E13. D[6]         J1. PME#         M5. VDD         R10. AD[12]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETI_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TA_         J5. VDD         M9. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. SEREG_         T1. AD[23]           C2.                                                                       | B2. VH     |           |               |                   |                  |
| B5. DP[2]         E9. VDD         H13. TCK         M1. HALT_/TRETRY_         R5. EXT_GNT[5]#           B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H15. ENID         M3. GNT#         R7. IRDY#           B8. A[18]         E12. VDD         H16. QINT_         M4. REQ#         R8. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R10. AD[12]           B1. A[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B1. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETL_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TA_         J5. VDD         M9. VDD         R14. NC           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M15. SERR#         T3. EXT_GNT[6]#           C4. PCL_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#                                                                      | B3. D[26]  |           |               |                   | R3. AD[25]       |
| B6. D[20]         E10. VDD         H14. TRST_         M2. RST#         R6. AD[19]           B7. A[22]         E11. VDD         H15. ENID         M3. GNT#         R7. IRDY#           B8. A[18]         E12. VDD         H16. QINT_         M4. REQ#         R8. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R9. CBE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETI_         M8. VDD         R13. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TAL         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J13. DACK_SDACK_N         N1. VH         T5. AD[18]           C4. P                                                                       | B4. D[24]  |           |               | L16. AS_          | R4. EXT_GNT[2]#  |
| B7. A[22]       E11. VDD       H15. ENID       M3. GNT#       R7. IRDY#         B8. A[18]       E12. VDD       H16. QINT_       M4. RE0#       R8. DEVSEL#         B9. D[18]       E13. D[6]       J1. PME#       M5. VDD       R9. CBE[1]         B10. D[15]       E14. D[2]       J2. HS_SWITCH       M6. VDD       R10. AD[12]         B11. A[15]       E15. D[1]       J3. TMODE[0]       M7. VDD       R11. CBE[0]         B12. TEST1       E16. A[5]       J4. RESETL_       M8. VDD       R12. EXT_REQ[2]#         B13. N/C       F1. DSACK1_/TA_       J5. VDD       M9. VDD       R13. EXT_REQ[6]#         B14. D[10]       F2. A[31]       J6. VSS       M10. VDD       R14. N/C         B15. D[11]       F3. A[30]       J7. VSS       M11. VDD       R16. N/C         C1. A[26]       F5. VDD       J9. VSS       M13. CSREG_       T1. AD[23]         C2. D[31]       F6. VSS       J10. VSS       M14. NT#       T2. CBE[3]         C3. D[27]       F7. VSS       J11. VSS       M15. SERR#       T3. EXT_GNT[6]#         C4. PCI_ARB_EN       F8. VSS       J12. VDD       M16. TC[2]       T4. EXT_GNT[6]#         C5. DP[1]       F9. VSS       J13. DACK_SDACK_SDACK_SAD[23]       T6. AD[17]                                                                                                                         | B5. DP[2]  |           |               | M1. HALT_/TRETRY_ | R5. EXT_GNT[5]#  |
| B8. A[18]         E12. VDD         H16. QINT_         M4. REQ#         R8. DEVSEL#           B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R9. CBE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETI_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. NSS         M16. SERR#         T3. EXT_GNT[3]#           C4. PCL_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[3]# <t< td=""><td></td><td></td><td></td><td>M2. RST#</td><td>R6. AD[19]</td></t<> |            |           |               | M2. RST#          | R6. AD[19]       |
| B9. D[18]         E13. D[6]         J1. PME#         M5. VDD         R9. CBE[1]           B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETL_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_/TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[6]#           C4. PCLARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C4. APCLARB_EN         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#                                                                    | B7. A[22]  |           | H15. ENID     |                   | R7. IRDY#        |
| B10. D[15]         E14. D[2]         J2. HS_SWITCH         M6. VDD         R10. AD[12]           B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETI_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R14. N/C           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M15. SERR#         T3. EXT_GONT[6]#           C3. D[27]         F7. VSS         J11. VSS         M16. TC[2]         T4. EXT_GONT[6]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GONT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_N         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J15. DONE_N         N3. AD[27]         T7. STOP#                                                              | B8. A[18]  |           | _             | M4. REQ#          | R8. DEVSEL#      |
| B11. A[15]         E15. D[1]         J3. TMODE[0]         M7. VDD         R11. CBE[0]           B12. TEST1         E16. A[5]         J4. RESETL         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M16. TC[2]         T4. EXT_GNT[6]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T10. AD[8]                                                                         |            |           |               |                   |                  |
| B12. TEST1         E16. A[5]         J4. RESETI_         M8. VDD         R12. EXT_REQ[2]#           B13. N/C         F1. DSACK1_/TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J14. BM_EN/FIFO_RDV_N2. AD[31]         T6. AD[17]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDV_N2. AD[23]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]                                                          |            | E14. D[2] | J2. HS_SWITCH | M6. VDD           | R10. AD[12]      |
| B13. N/C         F1. DSACK1_/TA_         J5. VDD         M9. VDD         R13. EXT_REQ[6]#           B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M16. TC[2]         T4. EXT_GNT[6]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T10. AD[8]           C11. A[11]                                                              |            | E15. D[1] | • •           |                   |                  |
| B14. D[10]         F2. A[31]         J6. VSS         M10. VDD         R14. N/C           B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[17]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]                                                                       |            |           | J4. RESETI_   |                   |                  |
| B15. D[11]         F3. A[30]         J7. VSS         M11. VDD         R15. VH           B16. A[7]         F4. SIZ[1]         J8. VSS         M12. VDD         R16. N/C           C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12.                                                               |            |           |               |                   |                  |
| B16. A[7]       F4. SIZ[1]       J8. VSS       M12. VDD       R16. N/C         C1. A[26]       F5. VDD       J9. VSS       M13. CSREG_       T1. AD[23]         C2. D[31]       F6. VSS       J10. VSS       M14. INT#       T2. CBE[3]         C3. D[27]       F7. VSS       J11. VSS       M15. SERR#       T3. EXT_GNT[3]#         C4. PCI_ARB_EN       F8. VSS       J12. VDD       M16. TC[2]       T4. EXT_GNT[6]#         C5. DP[1]       F9. VSS       J13. DACK_/SDACK_       N1. VH       T5. AD[18]         C6. A[24]       F10. VSS       J14. BM_EN/FIFO_RDY_N2. AD[31]       T6. AD[17]         C7. A[19]       F11. VSS       J15. DONE_       N3. AD[27]       T7. STOP#         C8. D[19]       F12. VDD       J16. TMS       N4. AD[28]       T8. AD[14]         C9. D[16]       F13. D[5]       K1. RESETO_       N5. AD[20]       T10. AD[8]         C10. DS_       F14. A[3]       K2. TS_       N6. AD[20]       T11. EXT_REQ[1]#         C12. TEST3       F16. A[4]       K4. HS_HEALTHY_       N8. TRDY#       T12. EXT_REQ[5]#         C14. A[8]       G2. SIZ[0]       K6. VSS       N10. PAR       T14. AD[4]         C15. D[9]       G3. DSACK0_       K7. VSS       N11. AD[10]       T15. N/C <td></td> <td></td> <td></td> <td></td> <td></td>                                                           |            |           |               |                   |                  |
| C1. A[26]         F5. VDD         J9. VSS         M13. CSREG_         T1. AD[23]           C2. D[31]         F6. VSS         J10. VSS         M14. INT#         T2. CBE[3]           C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#           C4. PCL_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[3]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]                                                               |            |           |               |                   |                  |
| C2. D[31]       F6. VSS       J10. VSS       M14. INT#       T2. CBE[3]         C3. D[27]       F7. VSS       J11. VSS       M15. SERR#       T3. EXT_GNT[3]#         C4. PCI_ARB_EN       F8. VSS       J12. VDD       M16. TC[2]       T4. EXT_GNT[6]#         C5. DP[1]       F9. VSS       J13. DACK_/SDACK_       N1. VH       T5. AD[18]         C6. A[24]       F10. VSS       J14. BM_EN/FIFO_RDY_N2. AD[31]       T6. AD[17]         C7. A[19]       F11. VSS       J15. DONE_       N3. AD[27]       T7. STOP#         C8. D[19]       F12. VDD       J16. TMS       N4. AD[28]       T8. AD[14]         C9. D[16]       F13. D[5]       K1. RESETO_       N5. AD[22]       T9. AD[13]         C10. DS_       F14. A[3]       K2. TS_       N6. AD[20]       T10. AD[8]         C11. A[11]       F15. D[0]       K3. PCI_DIS       N7. CBE[2]       T11. EXT_REQ[1]#         C12. TEST3       F16. A[4]       K4. HS_HEALTHY_       N8. TRDY#       T12. EXT_REQ[5]#         C13. A[6]       G1. SDA       K5. VDD       N9. PERR#       T13. AD[5]         C14. A[8]       G2. SIZ[0]       K6. VSS       N10. PAR       T14. AD[4]         C15. D[9]       G3. DSACK0_       K7. VSS       N11. AD[10]       T15.                                                                                                           |            |           |               |                   |                  |
| C3. D[27]         F7. VSS         J11. VSS         M15. SERR#         T3. EXT_GNT[3]#           C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C      <                                                  |            |           |               | M13. CSREG_       |                  |
| C4. PCI_ARB_EN         F8. VSS         J12. VDD         M16. TC[2]         T4. EXT_GNT[6]#           C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]                                                             |            |           |               | M14. INT#         |                  |
| C5. DP[1]         F9. VSS         J13. DACK_/SDACK_         N1. VH         T5. AD[18]           C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N13. EXT_REQ[3]#         L           D1. R/W_         G5. VDD         K9. VSS         N14. AD[1]         L           D3. D[29] <td></td> <td></td> <td></td> <td></td> <td></td>               |            |           |               |                   |                  |
| C6. A[24]         F10. VSS         J14. BM_EN/FIFO_RDY_N2. AD[31]         T6. AD[17]           C7. A[19]         F11. VSS         J15. DONE_N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                   |            |           |               |                   |                  |
| C7. A[19]         F11. VSS         J15. DONE_         N3. AD[27]         T7. STOP#           C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#         L           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]         J           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]         L                                                                                                       |            |           |               |                   |                  |
| C8. D[19]         F12. VDD         J16. TMS         N4. AD[28]         T8. AD[14]           C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACKO_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N13. EXT_REQ[3]#         L2. D[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#         L2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]         L2.                                                                                                                                                                                |            |           |               |                   |                  |
| C9. D[16]         F13. D[5]         K1. RESETO_         N5. AD[22]         T9. AD[13]           C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                              |            |           |               |                   |                  |
| C10. DS_         F14. A[3]         K2. TS_         N6. AD[20]         T10. AD[8]           C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                              |            |           |               |                   |                  |
| C11. A[11]         F15. D[0]         K3. PCI_DIS         N7. CBE[2]         T11. EXT_REQ[1]#           C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |               |                   |                  |
| C12. TEST3         F16. A[4]         K4. HS_HEALTHY_         N8. TRDY#         T12. EXT_REQ[5]#           C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |               |                   |                  |
| C13. A[6]         G1. SDA         K5. VDD         N9. PERR#         T13. AD[5]           C14. A[8]         G2. SIZ[0]         K6. VSS         N10. PAR         T14. AD[4]           C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           | K3. PCI_DIS   | N7. CBE[2]        | T11. EXT_REQ[1]# |
| C14. A[8]       G2. SIZ[0]       K6. VSS       N10. PAR       T14. AD[4]         C15. D[9]       G3. DSACK0_       K7. VSS       N11. AD[10]       T15. N/C         C16. D[8]       G4. ENUM#       K8. VSS       N12. IDSEL       T16. AD[2]         D1. R/W_       G5. VDD       K9. VSS       N13. EXT_REQ[3]#         D2. D[30]       G6. VSS       K10. VSS       N14. AD[1]         D3. D[29]       G7. VSS       K11. VSS       N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | C12. TEST3 | F16. A[4] |               | N8. TRDY#         | T12. EXT_REQ[5]# |
| C15. D[9]         G3. DSACK0_         K7. VSS         N11. AD[10]         T15. N/C           C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |           |               |                   | T13. AD[5]       |
| C16. D[8]         G4. ENUM#         K8. VSS         N12. IDSEL         T16. AD[2]           D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            |           |               |                   |                  |
| D1. R/W_         G5. VDD         K9. VSS         N13. EXT_REQ[3]#           D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |           |               |                   |                  |
| D2. D[30]         G6. VSS         K10. VSS         N14. AD[1]           D3. D[29]         G7. VSS         K11. VSS         N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |           |               |                   | T16. AD[2]       |
| D3. D[29] G7. VSS K11. VSS N15. AD[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |           |               |                   |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |               |                   |                  |
| D4. DP[3] G8. VSS K12. VDD N16. TC[0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |           |               |                   |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | D4. DP[3]  | G8. VSS   | K12. VDD      | N16. TC[0]        |                  |

### Table 66: Pinout of 27x27 mm Package

| A1. VSS                | C13. A[14] | H1. DSACK1_/TA_                | P17. N/C         | V13. AD[12]      |
|------------------------|------------|--------------------------------|------------------|------------------|
| A2. D[26]              | C14. A[11] | H2. A[31]                      | P18. TC[0]       | V14. AD[8]       |
| A3. D[22]              | C15. TEST3 | H3. A[30]                      | P19. TC[1]       | V15. N/C         |
| A4. DP[2]              | C16. A[10] | H4. VSS                        | P20. TC[2]       | V16. EXT_REQ[2]# |
| A5. VDD                | C17. A[6]  | H17. VSS                       | R1. BB_/BGACK_   | V17. EXT_REQ[6]# |
| A6. A[24]              | C18. D[8]  | H18. N/C                       | R2. BR_          | V18. AD[5]       |
| A7. A[22]              | C19. VDD   | H19. VSS                       | R3. VH           | V19. AD[3]       |
| A8. VSS                | C20. D[4]  | H20. N/C                       | R4. VDD          | V20. AD[0]       |
| A9. A[17]              | D1. VSS    | J1. SDA                        | R17. VDD         | W1. AD[28]       |
| A10. QCLK              | D2. VDD    | J2. SIZ[0]                     | R18. N/C         | W2. AD[27]       |
| A11. D[17]             | D3. D[29]  | J3. SIZ[1]                     | R19. N/C         | W3. AD[24]       |
| A12. VSS               | D4. VSS    | J4. DSACK0_                    | R20. CSPCI       | W4. CBE[3]       |
| A13. DS                | D5. D[24]  | J17. DREQ_                     | T1. HALT /TRETRY | W5. EXT_GNT[2]#  |
| A14. A[13]             | D6. VDD    | J18. ENID                      | T2. VDD          | W6. EXT_GNT[6]#  |
| A15. N/C               | D7. D[21]  | J19. QINT_                     | T3. REQ#         | W7. VSS          |
| A16. N/C               | D8. VSS    | J20. TCK                       | T4. AD[31]       | W8. AD[19]       |
| A10. N/C               | D9. A[19]  | K1. ENUM#                      | T17. VSS         | W9. AD[16]       |
|                        |            |                                |                  |                  |
| A18. A[8]              | D10. A[16] | K2. N/C                        | T18. INT#        | W10. FRAME#      |
| A19. D[11]             | D11. VDD   | K3. SCL                        | T19. CSREG_      | W11. PCLK        |
| A20. D[9]              | D12. D[12] | K4. VDD                        | T20. N/C         | W12. CBE[1]      |
| B1. D[28]              | D13. VSS   | K17. DONE_                     | U1. VSS          | W13. AD[13]      |
| B2. VDD                | D14. TEST2 | K18. TRST_                     | U2. GNT#         | W14. AD[10]      |
| B3. D[25]              | D15. VDD   | K19. DACK_/SDACK_              | U3. AD[29]       | W15. CBE[0]      |
| B4. PCI_ARB_EN         | D16. VDD   | K20. TMS                       | U4. VSS          | W16. N/C         |
| B5. DP[1]              | D17. VSS   | L1. IMSEL                      | U5. AD[23]       | W17. EXT_REQ[3]# |
| B6. D[20]              | D18. D[5]  | L2. HS_LED                     | U6. VDD          | W18. AD[6]       |
| B7. A[23]              | D19. VSS   | L3. TMODE[1]                   | U7. EXT_GNT[5]#  | W19. VSS         |
| B8. A[20]              | D20. VDD   | L4. HS_SWITCH                  | U8. VSS          | W20. AD[2]       |
| B9. N/C                | E1. A[27]  | L17. VDD                       | U9. AD[17]       | Y1. AD[26]       |
| B10. D[18]             | E2. VDD    | L18. TDI                       | U10. VDD         | Y2. AD[25]       |
| B11. D[15]             | E3. A[26]  | L19. N/C                       | U11. PERR#       | Y3. N/C          |
| B12. D[14]             | E4. D[31]  | L20. VSS                       | U12. VDD         | Y4. N/C          |
| B13. A[15]             | E17. D[3]  | M1. TMODE[0]                   | U13. VSS         | Y5. EXT_GNT[3]#  |
| B14. A[12]             | E18. D[2]  | M2. PME#                       | U14. AD[7]       | Y6. N/C          |
| B15. TEST1             | E19. D[1]  | M3. RESETI_                    | U15. VDD         | Y7. AD[21]       |
| B16. A[9]              | E20. A[4]  | M4. PCI_DIS                    | U16. EXT_REQ[5]# | Y8. AD[18]       |
| B17. A[7]              | F1. VSS    | M17. BDIP_                     | U17. VSS         | Y9. CBE[2]       |
| B18. D[10]             | F2. A[28]  | M18. BG_                       | U18. AD[1]       | Y10. TRDY#       |
| B19. D[7]              | F3. N/C    | M19. TDO                       | U19. VDD         | Y11. DEVSEL#     |
| B10. D[6]              | F4. VDD    | M10. HDO<br>M20.BM_EN/FIFO_RDY |                  | Y12. PAR         |
|                        |            |                                |                  | Y13. AD[14]      |
| C1. D[30]<br>C2. D[27] | F17. VDD   | N1. RESETO_<br>N2.HS_HEALTHY_  | V1. VSS          |                  |
|                        | F18. D[0]  |                                | V2. AD[30]       | Y14. AD[11]      |
| C3. N/C                | F19. A[3]  | N3. BURST_/TIP_                | V3. VDD          | Y15. AD[9]       |
| C4. D[23]              | F20. A[2]  | N4. VSS                        | V4. N/C          | Y16. IDSEL       |
| C5. DP[3]              | G1. N/C    | N17. VSS                       | V5. EXT_GNT[1]#  | Y17. EXT_REQ[1]# |
| C6. DP[0]              | G2. A[29]  | N18. TC[3]                     | V6. EXT_GNT[4]#  | Y18. EXT_REQ[4]# |
| C7. A[25]              | G3. R/W_   | N19. BERR_/TEA_                | V7. AD[22]       | Y19. VDD         |
| C8. A[21]              | G4. N/C    | N20. AS_                       | V8. AD[20]       | Y20. AD[4]       |
| C9. A[18]              | G17. A[5]  | P1. N/C                        | V9. VSS          |                  |
| C10. D[19]             | G18. VDD   | P2. TS_                        | V10. IRDY#       |                  |
| C11. D[16]             | G19. A[1]  | P3. VSS                        | V11. STOP#       |                  |
| C12. D[13]             | G20. A[0]  | P4. RST#                       | V12. AD[15]      |                  |
|                        |            |                                |                  |                  |

# **Appendix A: Registers**

This Appendix describes the QSpan II's registers. The following topics are discussed:

- "Register Map" on page 201
- "Registers" on page 206

## A.1 Overview

The 4 Kbytes of QSpan II Control and Status Registers (QCSRs) promotes host system configuration and allows the user to control QSpan II operational characteristics. The QCSRs are divided into two functional groups: the PCI Configuration Registers and the QSpan II Device Specific Registers. All of the QCSR space is accessible from both the PCI bus and the QBus.



The QSpan II (CA91C862A) is backwards software compatible with the QSpan (CA91C860B, CA91L860B). However, some register differences will be experienced (for example, device ID changes from one version to the other). Please contact Tundra for a complete list of these minor software differences.

# A.2 Terminology

| G_RST   | General reset. Active when either RST# or RESETI_ is driven low or HS_HEALTHY_ is driven high. |
|---------|------------------------------------------------------------------------------------------------|
| N/A     | Not applicable                                                                                 |
| PCI_RST | PCI Reset driven low (RST#) or HS_HEALTHY_ driven high.                                        |
| 0x      | Hexadecimal prefix (binary numbers have no prefix)                                             |
| R       | Read Only. Writes have no effect.                                                              |
| R/W     | Read/Write from PCI or QBus.                                                                   |
| R/W/E   | Read/Write from PCI or QBus. Loadable from EEPROM after PCI_RST.                               |
| R/WQ    | Read/Write from QBus only.                                                                     |
| R/WP    | Read/Write from PCI only.                                                                      |
| R/WQ/E  | Read/Write from QBus only. Loadable from EEPROM after PCI_RST.                                 |



The bit combinations listed as "Reserved" must not be set to 1. All bits listed as "Reserved" must read back a value of 0.

# A.3 Register Map

## Table 67: Register Map

| Address Offset<br>(Hexidecimal) | Register             | Description                                                                                                                                                | See                     |
|---------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| 0x000                           | PCI_ID               | PCI Configuration Space ID Register                                                                                                                        | Table 69 on page 206    |
| 0x004                           | PCI_CS               | PCI Configuration Space Control and Status Register                                                                                                        | Table 70 on page 207    |
| 0x008                           | PCI_CLASS            | PCI Configuration Class Register                                                                                                                           | Table 71 on page 210    |
| 0x00C                           | PCI_MISC0            | PCI Configuration Miscellaneous 0 Register                                                                                                                 | Table 72 on page 211    |
| 0x010                           | PCI_BSM/<br>I20_BAR  | PCI Configuration Base Address for Memory Register / $I_20$ Base Address Register (when $I_20$ operation is enabled)                                       | Table 73 on<br>page 212 |
| 0x014                           |                      | PCI Unimplemented                                                                                                                                          | -                       |
| 0x018                           | PCI_BST0/<br>PCI_BSM | PCI Configuration Base Address for Target 0<br>Register/PCI Configuration Base Address for Memory<br>Register (when I <sub>2</sub> 0 operation is enabled) | Table 75 on page 214    |
| 0x01C                           | PCI_BST1             | PCI Configuration Base Address for Target 1 Register                                                                                                       | Table 77 on page 216    |
| 0x020                           |                      | PCI Unimplemented                                                                                                                                          | -                       |
| 0x024                           |                      | PCI Unimplemented                                                                                                                                          | -                       |
| 0x02C                           | PCI_SID              | PCI Configuration Subsystem ID Register                                                                                                                    | Table 79 on page 218    |
| 0x030                           | PCI_BSROM            | PCI Configuration Expansion ROM Base Address<br>Register                                                                                                   | Table 80 on page 219    |
| 0x034                           | PCI_CP               | PCI Capabilities Pointer Register                                                                                                                          | Table 82 on page 221    |
| 0x038                           |                      | PCI Reserved                                                                                                                                               | -                       |
| 0x03C                           | PCI_MISC1            | PCI Configuration Miscellaneous 1 Register                                                                                                                 | Table 83 on page 222    |
| 0x040-0x0DB                     |                      | PCI Unimplemented                                                                                                                                          | -                       |
| 0x0DC                           | PCI_PMC              | PCI Power Management Capabilities Register                                                                                                                 | Table 84 on page 223    |
| 0x0E0                           | PCI_PMCS             | PCI Power Management Control and Status Register                                                                                                           | Table 85 on page 224    |
| 0x0E4                           | CPCI_HS              | CompactPCI Hot Swap Register                                                                                                                               | Table 86 on page 225    |

| Table 67: Register Map | (Continued) |
|------------------------|-------------|
|------------------------|-------------|

| Address Offset<br>(Hexidecimal) | Register  | Description                                                | See                      |
|---------------------------------|-----------|------------------------------------------------------------|--------------------------|
| 0x0E8                           | PCI_VPD   | PCI Vital Product Data (VPD) Register                      | Table 88 on page 227     |
| 0x0EC                           | VPD_DATA  | PCI VPD Data Register                                      | Table 88 on page 227     |
| 0x0F0-0x0FF                     |           | PCI Unimplemented                                          | -                        |
| 0x100                           | PBTI0_CTL | PCI Bus Target Image 0 Control Register                    | Table 89 on page 228     |
| 0x104                           | PBTI0_ADD | PCI Bus Target Image 0 Address Register                    | Table 90 on<br>page 230  |
| 0x108–10F                       |           | Reserved                                                   | -                        |
| 0x110                           | PBTI1_CTL | PCI Bus Target Image 1 Control Register                    | Table 92 on<br>page 232  |
| 0x114                           | PBTI1_ADD | PCI Bus Target Image 1 Address Register                    | Table 93 on<br>page 234  |
| 0x118-0x13B                     |           | Reserved                                                   | -                        |
| 0x13C                           | PBROM_CTL | PCI Bus Expansion ROM Control Register                     | Table 95 on<br>page 236  |
| 0x140                           | PB_ERRCS  | PCI Bus Error Control and Status Register                  | Table 97 on page 238     |
| 0x144                           | PB_AERR   | PCI Bus Address Error Log Register                         | Table 98 on page 240     |
| 0x148                           | PB_DERR   | PCI Bus Data Error Log Register                            | Table 99 on page 241     |
| 0x14C-1FF                       |           | Reserved                                                   | -                        |
| 0x200                           | 120_CS    | I <sub>2</sub> 0 Control and Status Register               | Table 100<br>on page 242 |
| 0x204                           | IIF_TP    | I <sub>2</sub> 0 Inbound Free_List Top Pointer Register    | Table 101<br>on page 244 |
| 0x208                           | IIF_BP    | I <sub>2</sub> 0 Inbound Free_List Bottom Pointer Register | Table 102<br>on page 245 |
| 0x20C                           | IIP_TP    | I <sub>2</sub> 0 Inbound Post_List Top Pointer Register    | Table 103<br>on page 246 |
| 0x210                           | IIP_BP    | I <sub>2</sub> 0 Inbound Post_List Bottom Pointer Register | Table 104<br>on page 247 |
| 0x214                           | IOF_TP    | I <sub>2</sub> 0 Outbound Free_List Top Pointer Register   | Table 105<br>on page 248 |

| Table 67: | Register | Мар | (Continued) |
|-----------|----------|-----|-------------|
|-----------|----------|-----|-------------|

| Address Offset<br>(Hexidecimal) |               |                                                             | See                      |
|---------------------------------|---------------|-------------------------------------------------------------|--------------------------|
| 0x218                           | IOF_BP        | I <sub>2</sub> 0 Outbound Free_List Bottom Pointer Register | Table 106<br>on page 249 |
| 0x21C                           | IOP_TP        | I <sub>2</sub> 0 Outbound Post_List Top Pointer Register    | Table 107<br>on page 250 |
| 0x220                           | IOP_BP        | I <sub>2</sub> 0 Outbound Post_List Bottom Pointer Register | Table 108<br>on page 251 |
| 0x224–3FF                       |               | Reserved                                                    | -                        |
| 0x400                           | IDMA/DMA_CS   | IDMA/DMA Control and Status Register                        | Table 109<br>on page 252 |
| 0x404                           | IDMA/DMA_PADD | IDMA/DMA PCI Address Register                               | Table 110<br>on page 255 |
| 0x408                           | IDMA/DMA_CNT  | IDMA/DMA Transfer Count Register                            | Table 111<br>on page 256 |
| 0x40C                           | DMA_QADD      | DMA QBus Address Register                                   | Table 112<br>on page 257 |
| 0x410                           | DMA_CS        | DMA Control and Status Register                             | Table 113<br>on page 258 |
| 0x414                           | DMA_CPP       | DMA Command Packet Pointer Register                         | Table 114<br>on page 261 |
| 0x418–0x4FF                     |               | Reserved                                                    | -                        |
| 0x500                           | CON_ADD       | Configuration Address Register                              | Table 115<br>on page 262 |
| 0x504                           | CON_DATA      | Configuration Data Register                                 | Table 117<br>on page 264 |
| 0x508                           | IACK_GEN      | IACK Cycle Generator Register                               | Table 118<br>on page 265 |
| 0x50C-0x5FF                     |               | Reserved                                                    | -                        |
| 0x600                           | INT_STAT      | Interrupt Status Register                                   | Table 119<br>on page 266 |
| 0x604                           | INT_CTL       | Interrupt Control Register                                  | Table 120<br>on page 269 |
| 0x608                           | INT_DIR       | Interrupt Direction Control Register                        | Table 121<br>on page 272 |
| 0x60C-0x6FF                     |               | Reserved                                                    | -                        |
| 0x700                           | MBOX0         | Mailbox 0 Register                                          | Table 123<br>on page 276 |

| Address Offset<br>(Hexidecimal) | Register  | Description                                     | See                      |  |
|---------------------------------|-----------|-------------------------------------------------|--------------------------|--|
| 0x704                           | MBOX1     | Mailbox 1 Register                              | Table 124<br>on page 277 |  |
| 0x708                           | MBOX2     | Mailbox 2 Register                              | Table 125<br>on page 278 |  |
| 0x70C                           | MBOX3     | Mailbox 3 Register                              | Table 126<br>on page 279 |  |
| 0x710–0x7FF                     |           | Reserved                                        | -                        |  |
| 0x800                           | MISC_CTL  | Miscellaneous Control and Status Register       | Table 127<br>on page 280 |  |
| 0x804                           | EEPROM_CS | EEPROM Control and Status Register              | Table 129<br>on page 283 |  |
| 0x808                           | MISC_CTL2 | Miscellaneous Control 2 Register                | Table 130<br>on page 284 |  |
| 0x810                           | PARB_CTL  | PCI Bus Arbiter Control Register                | Table 131<br>on page 287 |  |
| 0x814-0xEFF                     |           | -                                               |                          |  |
| 0xF00                           | QBSI0_CTL | QBus Slave Image 0 Control Register             | Table 133<br>on page 289 |  |
| 0xF04                           | QBSI0_AT  | QBus Slave Image 0 Address Translation Register | Table 138<br>on page 291 |  |
| 0xF08-0xF0F                     |           | Reserved                                        | -                        |  |
| 0xF10                           | QBSI1_CTL | QBus Slave Image 1 Control Register             | Table 140<br>on page 293 |  |
| 0xF14                           | QBSI1_AT  | QBus Slave Image 1 Address Translation Register | Table 145<br>on page 295 |  |
| 0xF18-0xF7F                     |           | Reserved                                        | -                        |  |
| 0xF80                           | QB_ERRCS  | QBus Error Log Control and Status Register      | Table 147<br>on page 297 |  |
| 0xF84                           | QB_AERR   | QBus Address Error Log Register                 | Table 148<br>on page 298 |  |
| 0xF88                           | QB_DERR   | QBus Data Error Log Register                    | Table 149<br>on page 299 |  |
| 0xF8C-0xFFF                     | Reserved  |                                                 |                          |  |

| Address Offset | Register | Page                                                          |                          |  |  |
|----------------|----------|---------------------------------------------------------------|--------------------------|--|--|
| 0x000-0x02F    |          | Reserved                                                      |                          |  |  |
| 0x030          | I2O_OPIS | I <sub>2</sub> 0 Outbound Post_List Interrupt Status Register | Table 150<br>on page 300 |  |  |
| 0x034          | I2O_OPIM | I <sub>2</sub> 0 Outbound Post_List Interrupt Mask Register   | Table 151<br>on page 301 |  |  |
| 0x038-0x03C    |          | Reserved                                                      |                          |  |  |
| 0x040          | I2O_INQ  | I <sub>2</sub> 0 Inbound Queue Register                       | Table 152<br>on page 302 |  |  |
| 0x044          | I2O_OUTQ | I <sub>2</sub> 0 Outbound Queue Register                      | Table 153<br>on page 303 |  |  |
| 0x048-0xFFF    |          | Reserved                                                      | -                        |  |  |

### Table 68: I<sub>2</sub>O Memory Map — Lower 4K

# A.4 Registers

## Table 69: PCI Configuration Space ID Register

| Register Name: PCI_ID |  | Register Offset: 000 |
|-----------------------|--|----------------------|
| Bits                  |  | Function             |
| 31–24                 |  | DID                  |
| 23–16                 |  | DID                  |
| 15–08                 |  | VID                  |
| 07–00                 |  | VID                  |

### **PCI\_ID Description**

| Name      | Туре   | Reset<br>By | Reset<br>State | Function                                                     |
|-----------|--------|-------------|----------------|--------------------------------------------------------------|
| DID[15:0] | R/WQ/E | G_RST       | 0x0862         | Device ID<br>Tundra allocated Device Identifier.             |
| VID[15:0] | R/WQ/E | G_RST       | 0x10E3         | Vendor ID<br>PCI SIG allocated vendor Identifier for Tundra. |

| Register Name: PCI_CS |                        |                                         |       |        |      |         | Register | Offset: 004 |
|-----------------------|------------------------|-----------------------------------------|-------|--------|------|---------|----------|-------------|
| Bits                  |                        | Function                                |       |        |      |         |          |             |
| 31–24                 | D_PE                   | S_SERR                                  | R_MA  | R_TA   | S_TA | DEV     | SEL      | MD_PED      |
| 23–16                 | TFBBC                  | TFBBC Reserved DEV66 CAP_L PCI Reserved |       |        |      |         |          |             |
| 15–08                 | PCI Reserved MFFBC SEF |                                         |       |        |      | SERR_EN |          |             |
| 07–00                 | WAIT                   | PERESP                                  | VGAPS | MWI_EN | SC   | BM      | MS       | IOS         |

### Table 70: PCI Configuration Space Control and Status Register

### PCI\_CS Description

| Name        | Туре                     | Reset By | Reset<br>State | Function                                                                                                                                                                                                                               |
|-------------|--------------------------|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D_PE        | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Detected Parity Error<br>0 = No parity error<br>1 = Parity error<br>This bit is set by the QSpan II whenever: the PCI<br>Master Module detects a data parity error, or the PCI<br>Target Module detects address or data parity errors. |
| S_SERR      | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Signaled SERR#<br>0 = SERR# not asserted<br>1 = SERR# asserted<br>The QSpan II as PCI target sets this bit when it<br>asserts SERR# to signal an address parity error.<br>SERR_EN must be set before SERR# can be<br>asserted.         |
| R_MA        | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Received Master-Abort<br>0 = QSpan II did not generate Master-Abort<br>1 = QSpan II generated Master-Abort<br>The QSpan II sets this bit when a transaction it<br>initiated had to be terminated with a Master-Abort.                  |
| R_TA        | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Received Target-Abort<br>0 = Master did not detect Target-Abort<br>1 = Master detected Target-Abort<br>The QSpan II sets this bit when a transaction it<br>initiated was terminated with a Target-Abort.                               |
| S_TA        | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Signaled Target-Abort<br>0 = Target did not terminate transaction with<br>Target-Abort<br>1 = Target terminated transaction with Target-Abort                                                                                          |
| DEVSEL[1:0] | R                        | N/A      | 01             | Device Select<br>Device Select Timing<br>The QSpan II is a medium-speed device.                                                                                                                                                        |

### PCI\_CS Description (Continued)

| Name    | Туре                     | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|--------------------------|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MD_PED  | R/Write<br>1 to<br>Clear | PCI_RST  | 0              | Master Data Parity Error Detected<br>0 = Master Module did not detect/generate data<br>parity error<br>1 = Master Module detected/generated data parity<br>error<br>The QSpan II sets this bit if the PERESP bit is set<br>and either (a) it is the master of transaction in which it<br>asserts PERR#, or (b) the addressed target asserts<br>PERR#.                                                                      |
| TFBBC   | R                        | N/A      | 1              | Target Fast Back-to-Back Capable<br>QSpan II can accept fast back-to-back transactions<br>from different agents.                                                                                                                                                                                                                                                                                                           |
| DEV66   | R                        | N/A      | 0              | Device 66 MHz Capable<br>The QSpan II is not capable of running at 66 MHz: it<br>is a 33 MHz capable device.                                                                                                                                                                                                                                                                                                               |
| CAP_L   | R                        | N/A      | 1              | Capabilities List<br>The QSpan II implements the new Capabilities List.<br>The capabilities pointer at offset 34h is a pointer to a<br>linked list of new capabilities.                                                                                                                                                                                                                                                    |
| MFBBC   | R                        | N/A      | 0              | Master Fast Back-to-Back Enable<br>QSpan II does not generate fast back-to-back<br>transfers.                                                                                                                                                                                                                                                                                                                              |
| SERR_EN | R/W                      | PCI_RST  | 0              | SERR# Enable<br>0 = Disable SERR# driver<br>1 = Enable SERR# driver<br>Setting this and PERESP allows the QSpan II to<br>report address parity errors with SERR# as PCI<br>target.                                                                                                                                                                                                                                         |
| WAIT    | R                        | N/A      | 0              | Wait Cycle Control<br>0 = No address/data stepping                                                                                                                                                                                                                                                                                                                                                                         |
| PERESP  | R/W                      | PCI_RST  | 0              | Parity Error Response<br>0 = Disable<br>1 = Enable<br>Controls the QSpan II response to data and address<br>parity errors. When enabled, PERR# is asserted and<br>the MD_PED bit is set in response to data parity<br>errors. When this bit and SERR_EN are set, the<br>QSpan II reports address parity errors on SERR#.<br>QSpan II parity generation (for example., its assertion<br>of PAR#) is unaffected by this bit. |

PCI\_CS Description (Continued)

| Name   | Туре | Reset By | Reset<br>State                                                                                                                                                                                                                                    | Function                                                                                                                        |
|--------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| VGAPS  | R    | N/A      | 0                                                                                                                                                                                                                                                 | VGA Palette Snoop<br>0 = Disable<br>1 = Enable                                                                                  |
| MWI_EN | R    | PCI_RST  | 0       Memory Write and Invalidate Enable         0 = Disable       1 = Enable         1 = Enable       The QSpan II generates Memory Write and Invalidate command as PCI master during         IDMA/DMA transfers (CMD bit set in IDMA/DMA_CS). |                                                                                                                                 |
| SC     | R    | N/A      | 0                                                                                                                                                                                                                                                 | Special Cycles<br>0 = Disable<br>1 = Enable<br>The QSpan II never responds to special cycles as<br>PCI target.                  |
| BM     | R/W  | PCI_RST  | Powerup<br>Option                                                                                                                                                                                                                                 | Bus Master<br>0 = Disable<br>1 = Enable<br>Enables the QSpan II to become PCI bus master.<br>This can be set as a reset option. |
| MS     | R/W  | PCI_RST  | 0                                                                                                                                                                                                                                                 | Memory Space<br>0 = Disable<br>1 = Enable<br>Enables the QSpan II target to accept Memory space<br>accesses.                    |
| IOS    | R/W  | PCI_RST  | 0                                                                                                                                                                                                                                                 | IO Space<br>0 = Disable<br>1 = Enable<br>Enables the QSpan II target to accept I/O space<br>accesses.                           |

The following status bits can generate an external interrupt: D\_PE, S\_SERR, R\_MA, R\_TA, S\_TA, and MD\_PED (for more information, see "Interrupt Generation due to PCI Configuration Register Status Bits" on page 124).

### Table 71: PCI Configuration Class Register

| Register N | Name: PCI_CLASS | Register Offset: 008 |
|------------|-----------------|----------------------|
| Bits       |                 | Function             |
| 31–24      |                 | BASE                 |
| 23–16      |                 | SUB                  |
| 15–08      |                 | PROG                 |
| 07–00      |                 | RID                  |

#### **PCI\_CLASS** Description

| Name      | Туре   | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                       |
|-----------|--------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BASE[7:0] | R/WQ/E | PCI_RST     | 0x06           | Base Class Code.<br>06 - Bridge Device<br>$0Eh = I_20 Controller$                                                                                                                                                                                                              |
| SUB[7:0]  | R/WQ/E | PCI_RST     | 0x80           | Sub Class Code.<br>80 - Other Bridge Device (if BASE = 06),<br>00 - I20 device (if BASE = 0E)                                                                                                                                                                                  |
| PROG[7:0] | R/WQ/E | PCI_RST     | 0x00           | Programming Interface.<br>00 = Other Bridge Device (if BASE = 06),<br>00 = I20 Inbound and Outbound FIFOs at 40h and 44h (if<br>BASE = 0E),<br>01 = I20 Inbound and Outbound FIFOs at 40h and 44h,<br>and Interrupt Status and Mask registers at 30h and 34h<br>(if BASE = 0E) |
| RID[7:0]  | R      | PCI_RST     | See<br>Right   | Revision ID<br>0x00 = QSpan II Prototype<br>0x01 = QSpan II Production Part                                                                                                                                                                                                    |

| Register Name: PCI_MISC0 | Register Offset: 00C |
|--------------------------|----------------------|
|--------------------------|----------------------|

| Bits  |        | Function |                          |  |  |  |   |  |  |
|-------|--------|----------|--------------------------|--|--|--|---|--|--|
| 31–24 | BISTC  | SBIST    | SBIST PCI Reserved CCODE |  |  |  |   |  |  |
| 23–16 | MFUNCT |          | LAYOUT                   |  |  |  |   |  |  |
| 15–08 |        |          | LTIMER 0                 |  |  |  |   |  |  |
| 07–00 | 0      | 0        | 0 0 CLINE                |  |  |  | 0 |  |  |

**PCI\_MISC0** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                |
|-------------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BISTC       | R    | N/A         | 0              | BIST Capable<br>0 = Device not BIST capable                                                                                                                             |
| SBIST       | R    | N/A         | 0              | Start BIST<br>0 = Device not BIST capable                                                                                                                               |
| CCODE[3:0]  | R    | N/A         | 0              | Completion Code<br>0 = Device not BIST capable                                                                                                                          |
| MFUNCT      | R    | N/A         | 0              | Multifunction Device<br>0 = QSpan II is not a multi-function Device                                                                                                     |
| LAYOUT[6:0] | R    | N/A         | 0              | Configuration Space Layout                                                                                                                                              |
| LTIMER[7:1] | R/W  | PCI_RST     | 0              | Latency Timer<br>Number of PCI bus clocks before transaction is<br>terminated.                                                                                          |
| CLINE[1:0]  | R/W  | PCI_RST     | 0              | CacheLine Size<br>00b = treated as 01<br>01b = 4 x 32-bit word<br>10b = 8 x 32-bit word<br>All other combinations written to this entry will return<br>a value of zero. |

The latency timer supports an increment of two PCI bus clocks. The minimum value is eight PCI bus clocks. The default value corresponds to eight PCI clock cycles.

CLINE[1:0] determines how the PCI Target module accepts burst write data (see "Acceptance of Burst Writes by the PCI Target Module" on page 78). It also determines how the IDMA/DMA Channel sinks data on and sources data from the PCI bus. If CLINE[1:0] is set to 00, the QSpan II treats it as if it were set to 01.

#### Table 73: PCI Configuration Base Address for Memory Register

| Register N | Name: PCI_ | BSM      |   |  |   |   | Register | Offset: 010 |
|------------|------------|----------|---|--|---|---|----------|-------------|
| Bits       |            | Function |   |  |   |   |          |             |
| 31–24      |            | BA       |   |  |   |   |          |             |
| 23–16      |            | BA       |   |  |   |   |          |             |
| 15–08      |            | В        | A |  | 0 | 0 | 0        | 0           |
| 07–00      | 0          | 0 0 0    |   |  | 0 | 0 | 0        | SPACE       |

#### **PCI\_BSM** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                  |
|-----------|------|-------------|----------------|-------------------------------------------|
| BA[31:12] | R/W  | PCI_<br>RST | 0              | Base Address                              |
| SPACE     | R    | N/A         | 0              | PCI Bus Address Space<br>0 = Memory Space |

This register is at this location when the  $I_20$  messaging unit in the QSpan II is not used: the I20\_EN bit is set to 0 in the I2O\_CS register. If the  $I_20$  messaging unit is enabled, this register is moved to offset 018, and PCI\_BST0 register from offset 018 is moved to this offset and renamed I2O\_BAR.

This register specifies the 4 Kbyte aligned base address of the QSpan II register space on PCI in Memory Space. The QSpan II register space is 4 Kbytes, therefore the PCI address lines [11:0] are used to select the QSpan II register.

A write must occur to this register before the QSpan II register space can be accessed from the PCI bus. This write can be performed with a PCI configuration transaction or a QBus register access.

### Table 74: I<sub>2</sub>0 Base Address Register

| Register Name: I2O_BAR | Register Offset: 010 |
|------------------------|----------------------|
|------------------------|----------------------|

| Bits  | Function |             |   |   |   |   |   |       |
|-------|----------|-------------|---|---|---|---|---|-------|
| 31–24 |          | BA          |   |   |   |   |   |       |
| 23–16 |          | BA          |   |   |   |   |   |       |
| 15–08 | 0        | 0 0 0 0 0 0 |   |   |   |   | 0 |       |
| 07–00 | 0        | 0           | 0 | 0 | 0 | 0 | 0 | SPACE |

#### I2O\_BAR Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                  |
|-----------|------|-------------|----------------|-------------------------------------------|
| BA[31:12] | R/W  | NONE        | 0              | Base Address                              |
| SPACE     | R    | N/A         | 0              | PCI Bus Address Space<br>0 = Memory Space |

This register is at this location when the  $I_2O$  messaging unit in the QSpan II is enabled: the I2O\_EN bit is set to 1 in I2O\_CS register. When the I2O\_EN bit is set, the first Base address register must provide a window to the QBus memory space. Essentially, the PCI\_BST0 register is moved from register offset 018 to 010 (see Table 75 for more information about the programming options).

The lower 4K of this space is reserved. The region above this space provides a window to the QBus memory.

### Table 75: PCI Configuration Base Address for Target 0 Register

| Register N | Name: PCI_ | BST0 |   |   |      |   | Register | Offset: 018 |
|------------|------------|------|---|---|------|---|----------|-------------|
| Bits       | Function   |      |   |   |      |   |          |             |
| 31–24      |            | BA   |   |   |      |   |          |             |
| 23–16      | BA         |      |   |   |      |   |          |             |
| 15–08      | 0          | 0    | 0 | 0 | 0    | 0 | 0        | 0           |
| 07–00      | 0          | 0    | 0 | 0 | PREF | 0 | 0        | PAS         |

#### **PCI\_BST0** Description

| Name      | Туре         | Reset By | Reset<br>State | Function                                                                              |
|-----------|--------------|----------|----------------|---------------------------------------------------------------------------------------|
| BA[31:16] | See<br>Below | PCI_RST  | 0              | Base Address of PCI bus Target Image 0                                                |
| PREF      | R/WQ/E       | PCI_RST  | See<br>Below   | Prefetchable<br>0 = Not Prefetchable<br>1 = Prefetchable (reads have no side effects) |
| PAS       | R            | PCI_RST  | See<br>Below   | PCI Bus Address Space<br>0 = Memory Space<br>1 = I/O Space                            |

This register is enabled if the state of the SDA pin or ENID pin is latched as high during PCI reset and bit 5 of byte 7 of the EEPROM is 1 (for information, see "Mapping of EEPROM Bits to QSpan II Registers" on page 130). This register is also enabled if the power-up option PCI\_DIS is latched high during Reset. If this register is not enabled — for example, there is no EEPROM or bit 5 of byte 7 of the EEPROM is 0 — the entire register is read only, and reads return all 0s.

If enabled, this register specifies the Base Address and PCI Bus Address Space settings for PCI Bus Target Image 0. The Base Address is used during transaction decoding; it specifies the contiguous PCI bus address line values compared by the QSpan II during PCI bus address phases. The number of address lines compared for this image is based on the value of the Block Size field in the PBTI0\_CTL register (see Table 89 on page 228 and "Transaction Decoding" on page 65 for more information).

If this register is enabled, the number of writable bits in BA[31:16] is determined by the Block Size field of the PBTI0\_CTL register. After power-up the serial EEPROM contents are loaded and a PCI host can write all 1s to the BA field of this register. The number of 1s that are read back can be used to compute the block size of the image (Block Size = 64Kbytes \*  $2^{N}$ ). For example, if the Block Size is 64 Kbytes (BS=0000) then the BA field will be 0xFFFF. If the Block Size is 2 Gbytes (BS = 1111) then the BA field will be 0x8000.

The PREF bit can be loaded from the EEPROM, or programmed from QBus. This bit does not enable prefetching on the QBus. The PREN bit in PBTI0\_CTL register must be set to enable prefetching on QBus.

| BS   | Block Size | Address Lines Compared |  |  |
|------|------------|------------------------|--|--|
| 0000 | 64 Kbytes  | AD31–AD16              |  |  |
| 0001 | 128 Kbytes | AD31–AD17              |  |  |
| 0010 | 256 Kbytes | AD31–AD18              |  |  |
| 0011 | 512 Kbytes | AD31–AD19              |  |  |
| 0100 | 1 Mbyte    | AD31–AD20              |  |  |
| 0101 | 2 Mbytes   | AD31–AD21              |  |  |
| 0110 | 4 Mbytes   | AD31–AD22              |  |  |
| 0111 | 8 Mbytes   | AD31–AD23              |  |  |
| 1000 | 16 Mbytes  | AD31–AD24              |  |  |
| 1001 | 32 Mbytes  | AD31–AD25              |  |  |
| 1010 | 64 Mbytes  | AD31–AD26              |  |  |
| 1011 | 128 Mbytes | AD31–AD27              |  |  |
| 1100 | 256 Mbytes | AD31–AD28              |  |  |
| 1101 | 512 Mbytes | AD31–AD29              |  |  |
| 1110 | 1 Gbyte    | AD31–AD30              |  |  |
| 1111 | 2 Gbytes   | AD31                   |  |  |

Table 76: PCI Address Lines Compared as a Function of Block Size

### Table 77: PCI Configuration Base Address for Target 1 Register

| Register Name: PCI_BST1 |               |    |   |   |      |   | Register ( | Offset: 01C |
|-------------------------|---------------|----|---|---|------|---|------------|-------------|
| Bits                    | Bits Function |    |   |   |      |   |            |             |
| 31–24                   |               | BA |   |   |      |   |            |             |
| 23–16                   | BA            |    |   |   |      |   |            |             |
| 15–08                   | 0             | 0  | 0 | 0 | 0    | 0 | 0          | 0           |
| 07–00                   | 0             | 0  | 0 | 0 | PREF | 0 | 0          | PAS         |

#### PCI\_BST1 Description

| Name      | Туре         | Reset By | Reset<br>State | Function                                                                              |
|-----------|--------------|----------|----------------|---------------------------------------------------------------------------------------|
| BA[31:16] | See<br>Below | PCI_RST  | 0              | Base Address of PCI Target Image 1                                                    |
| PREF      | R/WQ/E       | PCI_RST  | See<br>Below   | Prefetchable<br>0 = Not Prefetchable<br>1 = Prefetchable (reads have no side effects) |
| PAS       | R            | PCI_RST  | See<br>Below   | PCI Bus Address Space of PCI Target Image 1<br>0 = Memory Space<br>1 = I/O Space      |

This register is enabled if the state of the SDA or ENID pin is latched as high during PCI reset and bit 7 of byte 8 of the EEPROM is 1. This register is also enabled if the power-up option PCI\_DIS is latched high during Reset. If this register is not enabled (for example, there is no EEPROM or bit 7 of byte 8 of the EEPROM is 0), the entire register is read only, and reads return all zeros.

If enabled this register specifies the Base Address and PAS fields for PCI Bus Target Image 1. The Base Address is used during transaction decoding; it specifies the contiguous PCI bus address line values compared by the QSpan II during PCI bus address phases. The number of address lines compared for this image is based on the value of the Block Size field in the PBTI1\_CTL register. (see "Transaction Decoding" on page 65).

If this register is enabled, the number of writable bits in BA[31:16] is determined by the Block Size field of the PBTI1\_CTL register (see Table 92 on page 232). After power-up the serial EEPROM contents are loaded and a PCI host can write all 1s to the BA field of this register. The number of 1s that are read back can be used to compute the block size of the image (Block Size = 64Kbytes \*  $2^N$ ). For example, if the Block Size is 64 Kbytes (BS=0000) then the BA field will be 0xFFFF. If the Block Size is 2 Gbytes (BS = 1111), then the BA field will be 0x8000.

The PREF bit can be loaded from the EEPROM, or written from the QBus. The PREN bit in PBTI1\_CTL register must be set to enable QSpan II to perform prefetched reads on the QBus.

| BS   | Block Size | Address Lines Compared |
|------|------------|------------------------|
| 0000 | 64 Kbytes  | AD31–AD16              |
| 0001 | 128 Kbytes | AD31–AD17              |
| 0010 | 256 Kbytes | AD31–AD18              |
| 0011 | 512 Kbytes | AD31–AD19              |
| 0100 | 1 Mbyte    | AD31–AD20              |
| 0101 | 2 Mbytes   | AD31–AD21              |
| 0110 | 4 Mbytes   | AD31–AD22              |
| 0111 | 8 Mbytes   | AD31–AD23              |
| 1000 | 16 Mbytes  | AD31–AD24              |
| 1001 | 32 Mbytes  | AD31–AD25              |
| 1010 | 64 Mbytes  | AD31–AD26              |
| 1011 | 128 Mbytes | AD31–AD27              |
| 1100 | 256 Mbytes | AD31–AD28              |
| 1101 | 512 Mbytes | AD31–AD29              |
| 1110 | 1 Gbyte    | AD31–AD30              |
| 1111 | 2 Gbytes   | AD31                   |

Table 78: PCI Address Lines Compared as a Function of Block Size

### Table 79: PCI Configuration Subsystem ID Register

| Register Name: PCI_SID |  |          | Register Offset: 02C |
|------------------------|--|----------|----------------------|
| Bits                   |  | Function |                      |
| 31–24                  |  | SID      |                      |
| 23–16                  |  | SID      |                      |
| 15–08                  |  | SVID     |                      |
| 07–00                  |  | SVID     |                      |

#### PCI\_SID Description

| Name       | Туре   | Reset By | Reset<br>State | Function                                                                                                                                              |
|------------|--------|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| SID[15:0]  | R/WQ/E | PCI_RST  | See<br>Below   | Subsystem ID<br>Values for Subsystem ID are vendor specific.                                                                                          |
| SVID[15:0] | R/WQ/E | PCI_RST  | See<br>Below   | Subsystem Vendor ID<br>Subsystem Vendor IDs are obtained from the PCI<br>SIG and are used to identify the vendor of the add-in<br>board or subsystem. |

The Subsystem ID and the Subsystem Vendor ID is loaded from an external serial EEPROM at the end of the PCI bus reset (RST#); if the state of the SDA pin or ENID pin is latched as high during the reset. If the state of the SDA pin or ENID pin is latched as low, the reset state of the register will be all zeros.

Writes to the PCI\_SID register from the QBus will propagate to its contents, except while the QSpan II is updating its contents from the EEPROM. Writes to the PCI\_SID register from the PCI bus do not affect its contents.

| Table 80: PCI Configuration Expansion | <b>ROM Base Address Register</b> |
|---------------------------------------|----------------------------------|
|---------------------------------------|----------------------------------|

| Register Name: PCI_BSROM | Register Offset: 030 |
|--------------------------|----------------------|
|--------------------------|----------------------|

| Bits  |   | Function      |   |   |   |   |   |    |
|-------|---|---------------|---|---|---|---|---|----|
| 31–24 |   | ВА            |   |   |   |   |   |    |
| 23–16 |   | BA            |   |   |   |   |   |    |
| 15–08 | 0 | 0 0 0 0 0 0 0 |   |   |   |   |   |    |
| 07–00 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | EN |

**PCI\_BSROM** Description

| Name      | Туре         | Reset By | Reset<br>State | Function                                           |
|-----------|--------------|----------|----------------|----------------------------------------------------|
| BA[31:16] | See<br>Below | PCI_RST  | See<br>Below   | Expansion ROM Base Address                         |
| EN        | See<br>Below | PCI_RST  | 0              | Enable Address Decode<br>0 = Disable<br>1 = Enable |

The number of writable bits in BA[31:16] determines the size of the external QBus Expansion ROM (for more information, see the *PCI Local Bus Specification* 2.2).

The number of bits itself is determined by the Block Size field of the PCI Expansion ROM Control register (see "PBROM\_CTL" on page 236). After power-up a PCI host can write all 1s to the BA field of this register. The number of 1s that are read-back will indicate the size of the Expansion ROM of the QSpan II.

This register is enabled if bit 7 of byte 5 of the EEPROM is latched as 1 (see Table 44 on page 131). If the state of this bit is 0 or if the state of the SDA pin or ENID pin is latched as low during PCI reset, then all bits in the entire register will be set to 0 and will be read only.

The PCI Expansion ROM Base Address register can be written from either bus, if write enabled, except while the QSpan II is loading data from an external serial EEPROM. Writes to bits in the PCI Expansion ROM Base Address register that are not write enabled will have no effect.

| BS  | Block Size | Read/Write Bits |
|-----|------------|-----------------|
| 000 | 64 Kbytes  | BA31–BA16       |
| 001 | 128 Kbytes | BA31–BA17       |
| 010 | 256 Kbytes | BA31–BA18       |
| 011 | 512 Kbytes | BA31–BA19       |
| 100 | 1 Mbyte    | BA31–BA20       |
| 101 | 2 Mbytes   | BA31–BA21       |
| 110 | 4 Mbytes   | BA31–BA22       |
| 111 | 8 Mbytes   | BA31–BA23       |

Table 81: Writable BA bits as a function of Block Size

## Table 82: PCI Capabilities Pointer Register

| Register Name: PCI_CP |   | Register Offset: 034 |
|-----------------------|---|----------------------|
| Bits                  |   | Function             |
| 31–24                 | Р | CI Reserved          |
| 23–16                 | Р | CI Reserved          |
| 15–08                 | Р | CI Reserved          |
| 07–00                 |   | CAP_PT               |

### **PCI\_CP** Description

| Name        | Туре | Reset By | Reset<br>State | Function                                                                                                             |
|-------------|------|----------|----------------|----------------------------------------------------------------------------------------------------------------------|
| CAP_PT[7:0] | R    | PCI_RST  | 0xDC           | Capabilities Pointer<br>Points to the first entry of the linked list of new<br>capabilities implemented by QSpan II. |

### Table 83: PCI Configuration Miscellaneous 1 Register

| Register Name: PCI_MISC1 |  | Register Offset: 03C |
|--------------------------|--|----------------------|
| Bits                     |  | Function             |
| 31–24                    |  | MAX_LAT              |
| 23–16                    |  | MIN_GNT              |
| 15–08                    |  | INT_PIN              |
| 07–00                    |  | INT_LINE             |

#### **PCI\_MISC1** Description

| Name          | Туре   | Reset By | Reset<br>State | Function               |
|---------------|--------|----------|----------------|------------------------|
| MAX_LAT[7:0]  | R/WQ/E | PCI_RST  | 0              | Maximum Latency        |
| MIN_GNT[7:0]  | R/WQ/E | PCI_RST  | 0              | Minimum Grant          |
| INT_PIN[7:1]  | R      | PCI_RST  | 0              | Interrupt Pin (7 to 1) |
| INT_PIN[0]    | R/WQ/E | PCI_RST  | See<br>below   | Interrupt Pin 0        |
| INT_LINE[7:0] | R/W    | PCI_RST  | 0x00           | Interrupt Line         |

The INT\_PIN[0] can be loaded from the serial EEPROM or written from the QBus, before configuration by an external Host. A value of 1 indicates that the QSpan II uses a single PCI interrupt (INT#). A value of 0 indicates that the QSpan II does not use any PCI interrupts.

When QSpan II is setup to not use any PCI interrupts, it is up to an external agent to set the INT\_LINE to the appropriate value.

## Table 84: PCI Power Management Capabilities Register

| Register Name: PCI_PMC |          |        |      |         |        | Register C | offset: 0DC |  |
|------------------------|----------|--------|------|---------|--------|------------|-------------|--|
| Bits                   | Function |        |      |         |        |            |             |  |
| 31–24                  |          | PME_SP |      |         | D2_SP  | D1_SP      | Reserved    |  |
| 23–16                  | Reserved | DSI    | APS  | PME_CLK | PM_VER |            |             |  |
| 15–08                  | NXT_IP   |        |      |         |        |            |             |  |
| 07–00                  |          |        | CAP_ | ID      |        |            |             |  |

### **PCI\_PMC** Description

| Name        | Туре   | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                   |
|-------------|--------|----------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PME_SP[4:0] | R/WQ/E | PCI_RST  | 0              | PME_Support<br>Indicates the power states in which QSpan II asserts<br>PME#.<br>0X001b = PME# can be asserted from D0<br>0100Xb = PME# can be asserted from D3 <sub>hot</sub><br>Bits 4, 2 and 1 are set to 0, since QSpan II never<br>asserts PME# when in D3 <sub>cold</sub> , D2 or D1. |
| D2_SP       | R      | PCI_RST  | 0              | D2 Support<br>Set to 0 to indicate that D2 power state is not<br>supported.                                                                                                                                                                                                                |
| D1_SP       | R      | PCI_RST  | 0              | D1 Support<br>Set to 0 to indicate that D1 power state is not<br>supported.                                                                                                                                                                                                                |
| DSI         | R/WQ/E | PCI_RST  | 0              | Device-Specific Initialization.                                                                                                                                                                                                                                                            |
| APS         | R      | PCI_RST  | 0              | Auxiliary Power Source<br>Set to 0, since PME# is not supported from D3 <sub>cold.</sub>                                                                                                                                                                                                   |
| PME_CLK     | R      | PCI_RST  | 0              | PME Clock<br>Set to 1 to indicate that a clock is required to assert<br>PME# when any of the PME_SP bits are set to 1. Set<br>to 0 when all the PME_SP bits are 0.                                                                                                                         |
| PM_VER[2:0] | R/WQ/E | PCI_RST  | 001            | Power Management Version<br>A value of 001 indicates that this device complies with<br>Revision 1.0 of the <i>PCI Power Management Interface</i><br><i>Specification 1.1.</i>                                                                                                              |
| NXT_IP[7:0] | R      | PCI_RST  | 0xE4           | Next Item Pointer<br>Set to 0xE4 to indicate that the next item in the<br>QSpan II capabilities list (Compact PCI Hot Swap) is<br>located at offset E4h.                                                                                                                                   |
| CAP_ID[7:0] | R      | PCI_RST  | 0x01           | Capability ID<br>Set to 0x01 to identify the linked list item as PCI<br>Power Management Register.                                                                                                                                                                                         |

## Table 85: PCI Power Management Control and Status Register

| Register Name: PCI_PMCS |        |          |          | Register C | Offset: 0E0 |  |  |
|-------------------------|--------|----------|----------|------------|-------------|--|--|
| Bits                    |        |          | Function |            |             |  |  |
| 31–24                   |        | Reserved |          |            |             |  |  |
| 23–16                   |        |          | P2P_BSE  |            |             |  |  |
| 15–08                   | PME_ST |          | Reserved |            | PME_EN      |  |  |
| 07–00                   |        | Reserved |          | PWF        | R_ST        |  |  |

### PCI\_PMCS Description

| Name         | Туре                  | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                              |
|--------------|-----------------------|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P2P_BSE[7:0] | R                     | PCI_RST  | 0x00           | PCI to PCI Bridge Support Extensions                                                                                                                                                                                                                                                                                                                  |
| PME_ST       | R/Write<br>1 to clear | PCI_RST  | 0              | PME_Status<br>This bit is set when QSpan II would normally assert<br>PME#, regardless of PME_EN bit.                                                                                                                                                                                                                                                  |
| PME_EN       | R/W                   | PCI_RST  | 0              | PME Enable<br>0 = Disable<br>1 = Enable<br>Enables the QSpan II to assert PME#.                                                                                                                                                                                                                                                                       |
| PWR_ST[1:0]  | R/W                   | PCI_RST  | 0              | Power State<br>This field is used to both determine the current power<br>state and set the QSpan II into a new power state. If<br>an unimplemented power state is written to this<br>register, the QSpan II completes the write, but ignores<br>the write data. D0 and D3 <sub>hot</sub> are the only states<br>implemented.<br>00b: D0<br>11b: D3hot |

### Table 86: CompactPCI Hot Swap Register

| Register Name: CPCI_HS |     |          |          |          |     |          | Register ( | Offset: 0E4 |  |
|------------------------|-----|----------|----------|----------|-----|----------|------------|-------------|--|
| Bits                   |     | Function |          |          |     |          |            |             |  |
| 31–24                  |     | Reserved |          |          |     |          |            |             |  |
| 23–16                  | INS | EXT      | Reserved | Reserved | LOO | Reserved | EIM        | Reserved    |  |
| 15–08                  |     | NXT_IP   |          |          |     |          |            |             |  |
| 07–00                  |     |          |          | CAP_I    | D   |          |            |             |  |

### **CPCI\_HS** Description

| Name        | Туре                  | Reset By | Reset<br>State | Function                                                                                                                                                                                  |
|-------------|-----------------------|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INS         | R/Write<br>1 to clear | PCI_RST  | 0              | ENUM# Status Insertion<br>0 = Not asserted<br>1 = ENUM# asserted<br>The QSpan II sets this bit when EEPROM load is<br>completed and PCI Disable bit (PCI_DIS in<br>MISC_CTL2) is cleared. |
| EXT         | R/Write<br>1 to clear | PCI_RST  | 0              | ENUM# Status Extraction<br>0 = Not asserted<br>1 = ENUM# asserted<br>The QSpan II sets this bit when HS_SWITCH is<br>sampled high and RST# is negated.                                    |
| LOO         | R/W                   | PCI_RST  | 0              | LED On/Off<br>0 = LED off<br>1 = LED on                                                                                                                                                   |
| EIM         | R/W                   | PCI_RST  | 0              | ENUM# Interrupt Mask<br>0 = Enable Interrupt<br>1 = Mask Interrupt                                                                                                                        |
| NXT_IP[7:0] | R/W                   | PCI_RST  | See<br>Below   | Next Item Pointer                                                                                                                                                                         |
| CAP_ID[7:0] | R/W                   | PCI_RST  | 0x06           | Capability ID<br>Set to 0x06 to identify the linked list item as Compact<br>PCI Hot Swap Register.                                                                                        |

If the QSpan II is enabled for Vital Product Data (VPD) access, the next pointer will point to the VPD register (NXT\_IP = 0xE8). Otherwise NXT\_IP will be set to 0x00, which indicates that it is the last item in the Capabilities Linked List.

## Table 87: PCI Vital Product Data Register

| Register Name: PCI_VPD |          |  | Register Offset: 0E8 |  |  |  |  |
|------------------------|----------|--|----------------------|--|--|--|--|
| Bits                   | Function |  |                      |  |  |  |  |
| 31–24                  | VPD_F    |  | Reserved             |  |  |  |  |
| 23–16                  |          |  | VPD_ADDR             |  |  |  |  |
| 15–08                  |          |  | NXT_IP               |  |  |  |  |
| 07–00                  |          |  | CAP_ID               |  |  |  |  |

### PCI\_VPD Description

| Name              | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|------|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VPD_F             | R/W  | PCI_RST  | 0              | VPD Flag<br>Initiates a VPD serial EEPROM access and indicates<br>completion.<br>When written with a 1, QSpan II writes the 4 bytes in<br>VPD_DATA to the EEPROM. QSpan II sets VPD_F<br>to 0, when the write is complete.<br>When written with a 0, QSpan II reads the 4 bytes<br>from the EEPROM and store them in VPD_DATA.<br>QSpan II sets VPD_F to 1, when the read is<br>complete. |
| VPD_ADDR<br>[7:0] | R/W  | PCI_RST  | 0x00           | VPD Address<br>4 byte aligned byte address of the VPD to be<br>accessed.                                                                                                                                                                                                                                                                                                                  |
| NXT_IP[7:0]       | R    | PCI_RST  | 0x00           | Next Item Pointer<br>This is the last item in the linked list, so the pointer is<br>set to 0.                                                                                                                                                                                                                                                                                             |
| CAP_ID[7:0]       | R    | PCI_RST  | 0x03           | Capability ID<br>Set to 0x03 to indicate that this linked list register<br>supports the Vital Product Data access.                                                                                                                                                                                                                                                                        |

## Table 88: PCI VPD Data Register

| Register Name: VPD_DATA |  | Register Offset: 0E |  |  |  |  |
|-------------------------|--|---------------------|--|--|--|--|
| Bits                    |  | Function            |  |  |  |  |
| 31–24                   |  | VPD_DATA            |  |  |  |  |
| 23–16                   |  | VPD_DATA            |  |  |  |  |
| 15–08                   |  | VPD_DATA            |  |  |  |  |
| 07–00                   |  | VPD_DATA            |  |  |  |  |

### PCI\_VPD Description

| Name               | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|------|----------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VPD_DATA<br>[31:0] | R/W  | PCI_RST  | 0              | VPD Data<br>This contains the VPD read or write data. On a<br>read, this register will be valid, after the read was<br>initiated and the QSpan II sets the VPD_F bit to 1.<br>On a write, the data should be written to this field<br>before the write is initiated by writing to the<br>PCI_VPD register.<br>VPD_DATA[7:0] will contain the byte specified by the<br>VPD_ADDR. |

## Table 89: PCI Bus Target Image 0 Control Register

| Register N | lame: PBTI0_CTL | Register Offset: 100 |  |  |
|------------|-----------------|----------------------|--|--|
| Bits       |                 | Function             |  |  |

| 31–24 | EN   |          | Reserved                   | BS    |  |          |
|-------|------|----------|----------------------------|-------|--|----------|
| 23–16 | PREN | BRSTWREN | N Reserved INVEND Reserved |       |  | Reserved |
| 15–08 |      | T        | C                          | DSIZE |  | Reserved |
| 07–00 | PWEN | PAS      | Reserved                   |       |  |          |

#### PBTI0\_CTL Description

| Name              | Туре         | Reset By | Reset<br>State | Function                                                                                                     |
|-------------------|--------------|----------|----------------|--------------------------------------------------------------------------------------------------------------|
| EN                | R/W          | G_RST    | 0              | Image Enable<br>0 = Disable<br>1 = Enable                                                                    |
| BS[3:0]           | See<br>Below | PCI_RST  | See<br>Below   | Block Size<br>(64 Kbyte*2)                                                                                   |
| PREN              | R/W          | G_RST    | 0              | Prefetch Read Enable<br>0 = Disable<br>1 = Enable                                                            |
| BRSTWREN          | R/W          | G_RST    | 0              | Burst Write Enable<br>0 = Disable<br>1 = Enable                                                              |
| INVEND            | R/W          | G_RST    | 0              | Invert Endian-ness from QB_BOC Setting in<br>MISC_CTL<br>0 = Use QB_BOC setting<br>1 = Invert QB_BOC setting |
| TC[3:0]           | R/W          | G_RST    | 0              | QBus Transaction Code<br>User Defined                                                                        |
| DSIZE             | R/W          | G_RST    | 0              | QBus Destination Port Size<br>00b = 32-bit<br>01b = 8-bit<br>10b = 16-bit<br>11b = Reserved                  |
| PWEN <sup>a</sup> | R/W          | G_RST    | 0              | Posted Write Enable<br>0 = Disable<br>1 = Enable                                                             |
| PAS               | See<br>Below | PCI_RST  | See<br>Below   | PCI Bus Address Space<br>0 = PCI Bus Memory Space<br>1 = PCI Bus I/O Space                                   |

a. Only PCI bus memory space transactions can be posted.

The BS[3:0] and PAS fields can be loaded from an external serial EEPROM (see "Mapping of EEPROM Bits to QSpan II Registers" on page 130). There are three cases:

- 1. If the fields are loaded from the EEPROM, then the EEPROM determines their reset state, and they become read only (except as described in (3)). In this case, the PAS bit has the same value as the bit of the same name in the PCI\_BST0 register (see Table 75 on page 214).
- 2. If the BS[3:0] and PAS fields are not loaded from the EEPROM, their reset state is 0, and they are writable. Note that in this case the PCI\_BST0 register is disabled.
- 3. If the power-up option (PCI\_DIS) is set high during reset, then BS[3:0] and PAS fields are writable from the QBus, even if they were loaded from the EEPROM.

### Table 90: PCI Bus Target Image 0 Address Register

| Register N | Register Name: PBTI0_ADD |          | Register Offset: 104 |
|------------|--------------------------|----------|----------------------|
| Bits       |                          | Function |                      |
| 31–24      |                          | BA       |                      |
| 23–16      |                          | BA       |                      |
| 15–08      |                          | TA       |                      |
| 07–00      |                          | TA       |                      |

#### PBTI0\_ADD Description

| Name      | Туре         | Reset By | Reset<br>State | Function            |
|-----------|--------------|----------|----------------|---------------------|
| BA[31:16] | See<br>Below | PCI_RST  | See<br>below   | Base Address        |
| TA[31:16] | R/W          | G_RST    | 0              | Translation Address |

The Base Address specifies the contiguous PCI bus address line values compared by the QSpan II during PCI bus address phases. The number of address lines compared for this image is based on the Block Size (programmed in the PBTI0\_CTL register on Table 89 on page 228).

The Translation Address specifies the values of the address lines substituted when generating the address for the translation on the QBus. If no translation is to occur, the Translation Address must be programmed with the same value as that of the Base Address (see "Transaction Decoding" on page 65 and "Address Translation" on page 46 for more details).

| BS   | Block Size | Address Lines<br>Compared/Translated |
|------|------------|--------------------------------------|
| 0000 | 64 Kbytes  | AD31–AD16                            |
| 0001 | 128 Kbytes | AD31–AD17                            |
| 0010 | 256 Kbytes | AD31–AD18                            |
| 0011 | 512 Kbytes | AD31–AD19                            |
| 0100 | 1 Mbyte    | AD31–AD20                            |
| 0101 | 2 Mbytes   | AD31–AD21                            |
| 0110 | 4 Mbytes   | AD31–AD22                            |
| 0111 | 8 Mbytes   | AD31–AD23                            |
| 1000 | 16 Mbytes  | AD31–AD24                            |
| 1001 | 32 Mbytes  | AD31–AD25                            |
| 1010 | 64 Mbytes  | AD31–AD26                            |
| 1011 | 128 Mbytes | AD31–AD27                            |
| 1100 | 256 Mbytes | AD31–AD28                            |
| 1101 | 512 Mbytes | AD31–AD29                            |
| 1110 | 1 Gbyte    | AD31–AD30                            |
| 1111 | 2 Gbytes   | AD31                                 |

Table 91: PCI Address Lines Compared as a Function of Block Size

The read/write type and reset value of the BA[31:16] field depends on whether the PCI\_BST0 register (see Table 75 on page 214) is "enabled" (for example, whether bit 5 of byte 7 of the EEPROM is 1 or power-up pin PCI\_DIS is latched high during PCI reset). There are two cases:

- 1. If the EEPROM bit is 1 or PCI\_DIS is latched high, the BA field of PBTI0\_ADD is read only and has the same value as the PCI\_BST0 register from reset onwards.
- 2. If one of the following occurs then the entire BA field of PBTI0\_ADD is readable and writable: the EEPROM bit was 0, the SDA pin and ENID pins are 0 at PCI reset, or PCI\_DIS is latched low. A read from this field after reset returns all 0s. In this case, the BA field of this register is independent of the PCI\_BST0 register (the PCI\_BST0 register does not exist).

The presence of EEPROM does not affect TA[31:16].

## Table 92: PCI Bus Target Image 1 Control Register

| Register Name: PBTI1_CTL |               |          |          |  |        |       | Register Offset: 110 |
|--------------------------|---------------|----------|----------|--|--------|-------|----------------------|
| Bits                     | Bits Function |          |          |  |        |       |                      |
| 31–24                    | EN            |          | Reserved |  |        | BS    |                      |
| 23–16                    | PREN          | BRSTWREN | Reserved |  | INVEND |       | Reserved             |
| 15–08                    |               | TC       |          |  | DS     | IZE   | Reserved             |
| 07–00                    | PWEN          | PAS      |          |  | Rese   | erved |                      |

### PBTI1\_CTL Description

| Name              | Туре         | Reset<br>By | Reset<br>State | Function                                                                                                     |
|-------------------|--------------|-------------|----------------|--------------------------------------------------------------------------------------------------------------|
| EN                | R/W          | G_RST       | 0              | Image Enable<br>0 = Disable<br>1 = Enable                                                                    |
| BS[3:0]           | See<br>Below | PCI_RST     | See<br>Below   | Block Size<br>(64 Kbyte*2)                                                                                   |
| PREN              | R/W          | G_RST       | 0              | Prefetch Read Enable<br>0 = Disable<br>1 = Enable                                                            |
| BRSTWREN          | R/W          | G_RST       | 0              | Burst Write Enable<br>0 = Disable<br>1 = Enable                                                              |
| INVEND            | R/W          | G_RST       | 0              | Invert Endian-ness from QB_BOC Setting in<br>MISC_CTL<br>0 = Use QB_BOC setting<br>1 = Invert QB_BOC setting |
| TC[3:0]           | R/W          | G_RST       | 0              | QBus Transaction Code<br>User Defined                                                                        |
| DSIZE[1:0]        | R/W          | G_RST       | 0              | QBus Destination Port Size<br>00b = 32-bit<br>01b = 8-bit<br>10b = 16-bit<br>11b = Reserved                  |
| PWEN <sup>a</sup> | R/W          | G_RST       | 0              | Posted Write Enable<br>0 = Disable<br>1 = Enable                                                             |
| PAS               | See<br>Below | PCI_RST     | See<br>Below   | PCI Bus Address Space<br>0 = PCI Bus Memory Space<br>1 = PCI Bus I/O Space                                   |

a. Only PCI bus Memory Space transactions can be posted.

The BS[3:0] and PAS fields can be loaded from an external serial EEPROM. (see "Mapping of EEPROM Bits to QSpan II Registers" on page 130) for more details). There are three cases:

- 1. If the BS[3:0] and PAS fields are loaded from the EEPROM, then the EEPROM determines their reset state and they become read only; except as described in 3. In this case, the PAS bit has the same value as the bit of the same name in the PCI\_BST1 register (see Table 77 on page 216).
- 2. If the fields are not loaded from the EEPROM, their reset state is 0, and they are writable. Note that in this case the PCI\_BST1 register is disabled.
- 3. If the power-up option (PCI\_DIS) is set high during reset, then BS[3:0] and PAS fields are writable from the QBus, even if they were loaded from the EEPROM.

### Table 93: PCI Bus Target Image 1 Address Register

| Register N | Name: PBTI1_ADD | Register Offset | t: 114 |
|------------|-----------------|-----------------|--------|
| Bits       |                 | Function        |        |
| 31–24      |                 | BA              |        |
| 23–16      |                 | ВА              |        |
| 15–08      |                 | ТА              |        |
| 07–00      |                 | ТА              |        |

#### PBTI1\_ADD Description

| Name      | Туре         | Reset By | Reset<br>State | Function                 |
|-----------|--------------|----------|----------------|--------------------------|
| BA[31:16] | See<br>Below | PCI_RST  | See<br>Below   | Base Address<br>See Note |
| TA[31:16] | R/W          | G_RST    | 0              | Translation Address      |

The Base Address specifies the contiguous PCI bus address line values compared by the QSpan II during PCI bus address phases. The number of address lines compared for this image is based on the Block Size (programmed in the PBTI1\_CTL register on Table 92 on page 232).

The Translation Address specifies the values of the address lines substituted when generating the address for the translation on the QBus. If no translation is to occur, the Translation Address must be programmed with the same value as that of the Base Address (see "Transaction Decoding" on page 65 and "Address Translation" on page 46 for more details).

| BS   | Block Size | Address lines Compared/Translated |
|------|------------|-----------------------------------|
| 0000 | 64 Kbytes  | AD31–AD16                         |
| 0001 | 128 Kbytes | AD31–AD17                         |
| 0010 | 256 Kbytes | AD31–AD18                         |
| 0011 | 512 Kbytes | AD31–AD19                         |
| 0100 | 1 Mbyte    | AD31–AD20                         |
| 0101 | 2 Mbytes   | AD31–AD21                         |
| 0110 | 4 Mbytes   | AD31–AD22                         |
| 0111 | 8 Mbytes   | AD31–AD23                         |
| 1000 | 16 Mbytes  | AD31–AD24                         |
| 1001 | 32 Mbytes  | AD31–AD25                         |
| 1010 | 64 Mbytes  | AD31–AD26                         |
| 1011 | 128 Mbytes | AD31–AD27                         |
| 1100 | 256 Mbytes | AD31–AD28                         |
| 1101 | 512 Mbytes | AD31–AD29                         |
| 1110 | 1 Gbyte    | AD31–AD30                         |
| 1111 | 2 Gbytes   | AD31                              |

Table 94: PCI Address Lines Compared as a Function of Block Size

The read/write type of this register depends on whether the PCI\_BST1 register (see Table 77 on page 216) is enabled. For example, whether bit 7 of byte 9 of the EEPROM is 1 or power-up pin PCI\_DIS is latched high during PCI reset. There are two cases:

- 1. If the EEPROM bit is 1 or PCI\_DIS pin is latched high, the BA field of PBTI1\_ADD is read only and has the same value as the PCI\_BST1 register from reset onwards.
- 2. If the EEPROM bit is 0 (or the SDA pin and ENID pins are 0 at PCI reset) or PCI\_DIS pin is latched low, then the entire BA field of PBTI1\_ADD is readable and writable. A read from this field after reset returns a 16-bit vector of 0s. In this case, the BA field of this register is independent of the PCI\_BST1 register (the PCI\_BST1 register does not exist).

The presence of EEPROM does not affect TA[31:16].

### Table 95: PCI Bus Expansion ROM Control Register

| Register I | Name: PBR | ROM_CTL        |  |  | Register Offset: 13C |  |
|------------|-----------|----------------|--|--|----------------------|--|
| Bits       | Function  |                |  |  |                      |  |
| 31–24      |           | Reserved DSIZE |  |  |                      |  |
| 23–16      | 0         | 0 BS TC        |  |  | с                    |  |
| 15–08      | TA        |                |  |  |                      |  |
| 07–00      |           | ТА             |  |  |                      |  |

#### PBROM\_CTL Description

| Name       | Туре         | Reset By | Reset<br>State | Function                                                                                    |
|------------|--------------|----------|----------------|---------------------------------------------------------------------------------------------|
| DSIZE[1:0] | See<br>Below | PCI_RST  | See<br>below   | QBus Destination Port Size<br>00b = 32-bit<br>01b = 8-bit<br>10b = 16-bit<br>11b = reserved |
| BS[2:0]    | See<br>Below | PCI_RST  | See<br>below   | Block Size (64 Kbyte*2 <sup>BS</sup> )                                                      |
| TC[3:0]    | See<br>Below | PCI_RST  | See<br>below   | QBus Transaction Code<br>User Defined                                                       |
| TA[31:16]  | See<br>Below | PCI_RST  | See<br>below   | Translation Address<br>See below                                                            |

The PCI Bus Expansion ROM Control Register is loaded from an external serial EEPROM at the conclusion of the PCI bus reset (RST#) if the state of the SDA I/O pin or ENID is latched as high during the reset and bit 7 of byte 5 of the EEPROM is a 1 (see "Mapping of EEPROM Bits to QSpan II Registers" on page 130). Otherwise the reset state of the register will be zero and the register will be write disabled.

The PCI Expansion ROM Base Address register specifies the address line values that are compared during the address decoding. The number of address lines that are compared is based upon the value of Block Size value in the PCI Expansion ROM Control register.

The Translation Address field specifies the values of the address lines that are substituted when generating the address for the QBus. If no translation is to occur, the Translation Address field is programmed with the same value as that of the PCI Configuration Expansion ROM Base Address register.

| BS  | Block Size | Address Lines Compared/translated |
|-----|------------|-----------------------------------|
| 000 | 64 Kbytes  | A31–A16                           |
| 001 | 128 Kbytes | A31–A17                           |
| 010 | 256 Kbytes | A31–A18                           |
| 011 | 512 Kbytes | A31–A19                           |
| 100 | 1 Mbyte    | A31–A20                           |
| 101 | 2 Mbytes   | A31–A21                           |
| 110 | 4 Mbytes   | A31–A22                           |
| 111 | 8 Mbytes   | A31–A23                           |

Table 96: PCI Address Lines Compared as a Function of Block Size

### Table 97: PCI Bus Error Log Control and Status Register

| Register I | Name: PB_E | ERRCS       |      | Register | Offset: 140 |
|------------|------------|-------------|------|----------|-------------|
| Bits       |            |             | Fund | tion     |             |
| 31–24      | EN         | Reserved ES |      |          |             |
| 23–16      | UNL_QSC    | Reserved    |      |          |             |
| 15–08      |            |             | Rese | rved     |             |
| 07–00      |            | CMDERR      |      | BE_ERR   |             |

#### **PB\_ERRCS** Description

| Name             | Туре                     | Reset<br>By | Reset<br>State | Function                                                                                                                                                                    |
|------------------|--------------------------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EN               | R/W                      | G_RST       | 0              | Enable PCI Error Log<br>0 = disable error logging<br>1 = enable error logging                                                                                               |
| ES               | R/Write<br>1 to<br>Clear | G_RST       | 0              | Error Status<br>0 = no error currently logged,<br>1 = error currently logged                                                                                                |
| UNL_QSC          | R/W                      | G_RST       | 0              | Unlock QBus Slave Channel<br>0 = Transfers in QBus Slave Channel are suspended<br>when ES bit is set<br>1 = Transfers in QBus Slave Channel continue while<br>ES bit is set |
| CMD_ERR<br>[3:0] | R                        | N/A         | 0111           | PCI Command Error Log                                                                                                                                                       |
| BE_ERR[3:0]      | R                        | G_RST       | 0              | PCI Byte Enable Error Log<br>0 = byte enable active<br>1 = byte enable inactive                                                                                             |

The PCI Master Module sets the ES bit if one of the following occurs:

- a posted write transaction results in a Target-Abort
- a posted write transaction results in a Master-Abort

The assertion of the ES bit can be mapped to the QSpan II's interrupt pins by programming the Interrupt Control and Interrupt Direction Control registers. The mapping of interrupts can only occur if the EN bit in the PCI Bus Error Log register is set.

To disable the PCI Error Logging after it has been enabled, the ES bit must not be set. If ES is set, it can be cleared (by writing a 1) at the same time as a 0 is written to the EN bit.

The BE\_ERR field only contains valid information when the ES bit is set. At all other times these fields return all zeros when read.

Setting the UNL\_QSC enables the QBus Master to service the QBus Slave Channel while the ES bit is set and the Error log is frozen. The ES bit must be cleared to log a new error. If error logging is enabled, it recommended that the UNL\_QSC bit be set to 1.

### Table 98: PCI Bus Address Error Log Register

| Register N | Name: PB_AERR | Register Offset: 144 |
|------------|---------------|----------------------|
| Bits       |               | Function             |
| 31–24      |               | PAERR                |
| 23–16      |               | PAERR                |
| 15–08      |               | PAERR                |
| 07–00      |               | PAERR                |

#### **PB\_AERR Description**

| Name        | Туре | Reset<br>By | Reset<br>State | Function              |
|-------------|------|-------------|----------------|-----------------------|
| PAERR[31:0] | R    | G_RST       | 0              | PCI Address Error Log |

The QSpan II as PCI master will log errors if a posted write transaction results in a Target-Abort, or a posted write transaction results in a Master-Abort.

This register logs the PCI bus address information. Its content are qualified by bit ES of the PCI Bus Error Log Control and Status Register (see Table 97). The PAERR field contains valid information when the ES bit is set. At all other times a read of this register will return all zeros.

### Table 99: PCI Bus Data Error Log Register

| Register N | Name: PB_DERR | Register Offset: 148 |
|------------|---------------|----------------------|
| Bits       |               | Function             |
| 31–24      |               | PDERR                |
| 23–16      |               | PDERR                |
| 15–08      |               | PDERR                |
| 07–00      |               | PDERR                |

### **PB\_DERR Description**

| Name        | Туре | Reset<br>By | Reset<br>State | Function           |
|-------------|------|-------------|----------------|--------------------|
| PDERR[31:0] | R    | G_RST       | 0              | PCI Data Error Log |

The QSpan II as PCI master will log errors if a posted write transaction results in a Target-Abort, or a posted write transaction results in a Master-Abort.

This register logs the PCI bus data information. Its content are qualified by bit ES of the PCI Bus Error Log Control and Status register (see Table 97). The PDERR field contains valid information when the ES bit is set. At all other times, a read of this register will return all zeros.

## Table 100: I<sub>2</sub>O Control and Status Register

| Register Name: I2O_CS Register Offset: 2 |
|------------------------------------------|
|------------------------------------------|

| Bits  |          | Function           |           |  |          |          |       |        |
|-------|----------|--------------------|-----------|--|----------|----------|-------|--------|
| 31–24 |          | QIBA               |           |  |          |          |       |        |
| 23–16 |          | QI                 | BA        |  | Rese     | erved    |       |        |
| 15–08 | IF_E     | F_E IP_E OF_E OP_E |           |  |          | IP_F     | OF_F  | OP_F   |
| 07–00 | Reserved |                    | FIFO_SIZE |  | Reserved | Reserved | RR_BP | 120_EN |

### I2O\_CS Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                 |
|-------------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA[31:20] | R/W  | G_RST       | 0              | QBus $I_2O$ Base Address<br>Base address of the block of memory that contains the<br>four FIFOs in QBus memory. The four FIFOs (two<br>Inbound and two Outbound) are of equal size, but need<br>not be in contiguous memory locations. QIBA is aligned<br>to a 1-Mbyte address boundary. |
| IF_E        | R    | G_RST       | 1              | Inbound Free_List FIFO Empty<br>0 = Not Empty<br>1 = Empty                                                                                                                                                                                                                               |
| IP_E        | R    | G_RST       | 1              | Inbound Post_List FIFO Empty<br>0 = Not Empty<br>1 = Empty                                                                                                                                                                                                                               |
| OF_E        | R    | G_RST       | 1              | Outbound Free_List FIFO Empty<br>0 = Not Empty<br>1 = Empty                                                                                                                                                                                                                              |
| OP_E        | R    | G_RST       | 1              | Outbound Post_List FIFO Empty<br>0 = Not Empty<br>1 = Empty                                                                                                                                                                                                                              |
| IF_F        | R    | G_RST       | 0              | Inbound Free_List FIFO Full<br>0 = Not Full<br>1 = Full                                                                                                                                                                                                                                  |
| IP_F        | R    | G_RST       | 0              | Inbound Post_List FIFO Full<br>0 = Not Full<br>1 = Full                                                                                                                                                                                                                                  |
| OF_F        | R    | G_RST       | 0              | Outbound Free_List FIFO Full<br>0 = Not Full<br>1 = Full                                                                                                                                                                                                                                 |

I2O\_CS Description (Continued)

| Name            | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OP_F            | R    | G_RST       | 0              | Outbound Post_List FIFO Full<br>0 = Not Full<br>1 = Full                                                                                                                                                                                                                                                                                                                                                                          |
| FIFO_SIZE [2:0] | R/W  | G_RST       | 0              | This field specifies the size of the circular FIFO. All four<br>FIFOs are the same size and queue 32-bit entries. Total<br>FIFO memory allocation is four times the single FIFO<br>size.<br>000b = 256 entries (1 Kbyte FIFO size)<br>001b = 1K entries (4 Kbyte FIFO size)<br>010b = 4K entries (16 Kbyte FIFO size)<br>011b = 16K entries (64 Kbyte FIFO size)<br>100b = 64K entries (256 Kbyte FIFO size)<br>others = Reserved |
| RR_BP           | R/W  | G_RST       | 0              | Register Read of Bottom Pointer<br>0 = Register read of bottom pointer will return value of<br>bottom pointer<br>1 = same as 0, except when the top and bottom pointers<br>are equal, returns 0xFFFFFFF                                                                                                                                                                                                                           |
| I2O_EN          | R/W  | G_RST       | 0              | $I_2O$ Enable<br>$0 = accesses to I_2O$ Inbound and Outbound Queue are<br>enabled<br>$1 = accesses to I_2O$ Inbound and Outbound Queue are<br>disabled. Writes are accepted but ignored, reads return<br>0xFFFF FFFF. All pointer initialization and frame<br>allocation should be completed before enabling this bit.                                                                                                            |

## Table 101: I<sub>2</sub>O Inbound Free\_List Top Pointer Register

| Register | Name: IIF_TP |         | Register Offset: 204 |
|----------|--------------|---------|----------------------|
| Bits     |              | Functio | on                   |
| 31–24    |              | QIBA    |                      |
| 23–16    | QIBA         |         | IF_TP                |
| 15–08    |              | IF_TP   |                      |
| 07–00    | IF_TP        |         | Reserved             |

### **IIF\_TP Description**

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                          |
|--------------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                          |
| IF_TP [19:2] | R/W  | G_RST       | 0              | Inbound Free_List Top Pointer<br>This pointer gives the address offset for the Inbound<br>Free-List Top Pointer. This register is initialized and<br>maintained by the QBus Host. |

# Table 102: I<sub>2</sub>O Inbound Free\_List Bottom Pointer Register

| Register Name: IIF_BP |                |  |  | Register Offset: 208 |
|-----------------------|----------------|--|--|----------------------|
| Bits                  | Function       |  |  |                      |
| 31–24                 | QIBA           |  |  |                      |
| 23–16                 | QIBA IF_BP     |  |  | BP                   |
| 15–08                 | IF_BP          |  |  |                      |
| 07–00                 | IF_BP Reserved |  |  | Reserved             |

### **IIF\_BP** Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                |
|--------------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                                                                                                |
| IF_BP [19:2] | R/W  | G_RST       | 0              | Inbound Free_List Bottom Pointer<br>This pointer gives the address offset for the Inbound<br>Free-List Bottom Pointer. This register is initialized by<br>the QBus Host, but is maintained by QSpan II and is<br>incremented by four (modulo boundary of<br>FIFO_SIZE). |

## Table 103: I<sub>2</sub>O Inbound Post\_List Top Pointer Register

| Register Name: IIP_TP |       |       | Register Offset: 20C |  |
|-----------------------|-------|-------|----------------------|--|
| Bits Function         |       |       |                      |  |
| 31–24                 |       | QIBA  |                      |  |
| 23–16                 | QIBA  |       | IP_TP                |  |
| 15–08                 |       | IP_TP |                      |  |
| 07–00                 | IP_TP |       | Reserved             |  |

### **IIP\_TP Description**

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                          |
|--------------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                                                                                          |
| IP_TP [19:2] | R/W  | G_RST       | 0              | Inbound Post_List Top Pointer<br>This pointer gives the address offset for the Inbound<br>Post-List Top Pointer. This register is initialized by the<br>QBus Host, but is maintained by QSpan II and is<br>incremented by four (modulo boundary of<br>FIFO_SIZE). |

# Table 104: I<sub>2</sub>O Inbound Post\_List Bottom Pointer Register

| Register Name: IIP_BP |          |                |  | Register Offset: 210 |  |
|-----------------------|----------|----------------|--|----------------------|--|
| Bits                  | Function |                |  |                      |  |
| 31–24                 |          | QIBA           |  |                      |  |
| 23–16                 | QIBA     | QIBA IP_BP     |  |                      |  |
| 15–08                 |          | IP_BP          |  |                      |  |
| 07–00                 | IP_BP    | IP_BP Reserved |  |                      |  |

### **IIP\_BP** Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                |
|--------------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                |
| IP_BP [19:2] | R/W  | G_RST       | 0              | Inbound Post_List Bottom Pointer<br>This pointer gives the address offset for the Inbound<br>Post-List Bottom Pointer. This register is initialized<br>and maintained by the QBus Host. |

## Table 105: I<sub>2</sub>O Outbound Free\_List Top Pointer Register

| Register Name: IOF_TP |       |                | Register Offset: 214 |  |
|-----------------------|-------|----------------|----------------------|--|
| Bits Function         |       |                |                      |  |
| 31–24                 | QIBA  |                |                      |  |
| 23–16                 | QIBA  |                | OF_TP                |  |
| 15–08                 | OF_TP |                |                      |  |
| 07–00                 | OF_TP | OF_TP Reserved |                      |  |

## **IOF\_TP Description**

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                |
|--------------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                                                                                                |
| OF_TP [19:2] | R/W  | G_RST       | 0              | Outbound Free_List Top Pointer<br>This pointer gives the address offset for the Outbound<br>Free-List Top Pointer. This register is initialized by the<br>QBus Host, but is maintained by the QSpan II and is<br>incremented by four (modulo boundary of<br>FIFO_SIZE). |

# Table 106: I<sub>2</sub>O Outbound Free\_List Bottom Pointer Register

| Register Name: IOF_BP |          |                |  | Register Offset: 218 |  |
|-----------------------|----------|----------------|--|----------------------|--|
| Bits                  | Function |                |  |                      |  |
| 31–24                 |          | QIBA           |  |                      |  |
| 23–16                 | QIBA     | QIBA OF_BP     |  |                      |  |
| 15–08                 |          | OF_BP          |  |                      |  |
| 07–00                 | OF_BP    | OF_BP Reserved |  |                      |  |

### **IOF\_BP** Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                  |
|--------------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                  |
| OF_BP [19:2] | R/W  | G_RST       | 0              | Outbound Free_List Bottom Pointer<br>This pointer gives the address offset for the Outbound<br>Free-List Bottom Pointer. This register is initialized<br>and maintained by the QBus Host. |

## Table 107: I<sub>2</sub>O Outbound Post\_List Top Pointer Register

| Register Name: IOP_TP |       |                | Register Offset: 21C |  |
|-----------------------|-------|----------------|----------------------|--|
| Bits Function         |       |                |                      |  |
| 31–24                 | QIBA  |                |                      |  |
| 23–16                 | QIBA  |                | OP_TP                |  |
| 15–08                 |       | OP_TP          |                      |  |
| 07–00                 | OP_TP | OP_TP Reserved |                      |  |

## **IOP\_TP Description**

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                               |
|--------------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                               |
| OP_TP [19:2] | R/W  | G_RST       | 0              | Outbound Post_List Top Pointer<br>This pointer gives the address offset for the Outbound<br>Post-List Bottom Pointer. This register is initialized<br>and maintained by the QBus Host. |

# Table 108: I<sub>2</sub>O Outbound Post\_List Bottom Pointer Register

| Register Name: IOP_BP |          | Register Offset: 220 |  |  |  |
|-----------------------|----------|----------------------|--|--|--|
| Bits                  | Function |                      |  |  |  |
| 31–24                 | QIBA     |                      |  |  |  |
| 23–16                 | QIBA     | BA OP_BP             |  |  |  |
| 15–08                 |          | OP_BP                |  |  |  |
| 07–00                 | OP_BP    | OP_BP Reserved       |  |  |  |

#### **IOP\_BP** Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                               |
|--------------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QIBA [31:20] | R    | G_RST       | 0              | QBus I <sub>2</sub> O Base Address (specified in I2O_CS)                                                                                                                                                                                                               |
| OP_BP [19:2] | R/W  | G_RST       | 0              | Outbound Post_List Bottom Pointer<br>This pointer gives the address offset for the Outbound<br>Post-List Bottom Pointer. This register is initialized by the<br>QBus Host, but is maintained by QSpan II and is<br>incremented by four (modulo boundary of FIFO_SIZE). |

## Table 109: IDMA Control and Status Register

#### Register Name: IDMA/DMA\_CS

Register Offset: 400

| Bits  | Function  |          |          |     |         |       |       |        |
|-------|-----------|----------|----------|-----|---------|-------|-------|--------|
| 31–24 | GO        | IRST_REQ | Reserved |     |         |       |       |        |
| 23–16 | ACT       | IRST     | DONE     | IPE | IQE     | CMD   | Rese  | erved  |
| 15–08 | IWM [3:0] |          |          |     | TC[3:0] |       |       |        |
| 07–00 | TC_EN     | CHAIN    | DMA      | DIR | IMODE   | QTERM | STERM | PORT16 |

#### IDMA/DMA\_CS Description

| Name     | Туре                     | Reset<br>By | Reset<br>State | Function                                                                                                                                         |
|----------|--------------------------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| GO       | W/Read<br>0 Always       | G_RST       | 0              | IDMA/DMA Go<br>0 = No effect<br>1 = Enable IDMA/DMA transfers                                                                                    |
| IRST_REQ | W/Read<br>0 Always       | G_RST       | 0              | IDMA/DMA Reset Request<br>0 = No effect<br>1 = Request reset of IDMA/DMA control                                                                 |
| ACT      | R                        | G_RST       | 0              | IDMA/DMA Active Status<br>0 = No IDMA/DMA transfer is active,<br>1 = IDMA/DMA transfer in progress                                               |
| IRST     | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA Reset Status<br>0 = Not reset<br>1 = Reset                                                                                              |
| DONE     | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA Done Status<br>0 = Not done<br>1 = Done                                                                                                 |
| IPE      | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA PCI Bus Error Status<br>0 = No error occurred<br>1 = Error occurred on the PCI bus during IDMA/DMA<br>transfer                          |
| IQE      | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA QBus Error Status<br>0 = No error occurred<br>1 = Error occurred on the QBus during IDMA/DMA<br>transfer                                |
| CMD      | R/W                      | G_RST       | 0              | PCI Command Option for IDMA/DMA PCI Transaction<br>0 = PCI Memory Write or Memory Read<br>1 = PCI Memory Write Invalidate or Memory Read<br>Line |

IDMA/DMA\_CS Description (Continued)

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                             |
|-----------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IWM [3:0] | R/W  | G_RST       | 0              | Programmable I-FIFO Watermark (for IDMA transfers)<br>0000 = use the value programmed into the<br>CLINE[1:0] field of the PCI_MISC0 register<br>x = when 16x bytes have been queued in the I-FIFO,<br>the IDMA channel will request the PCI bus.<br>Watermark can be set to a maximum of 240 bytes.  |
| TC [3:0]  | R/W  | G_RST       | 0              | Programmable TC Encoding with MPC860 IDMA<br>Program to the value expected on the QSpan II's<br>TC[3:0] lines during an IDMA transfer. The intent of<br>this field is to allow users to use the TC lines to<br>encode an IDMA transaction for the QSpan II (add a<br>qualifier for SDACK assertion). |
| TC_EN     | R/W  | G_RST       | 0              | TC Encoding Enable (IDMA transfers only)<br>0 = QSpan II does not decode TC[3:0] for IDMA<br>accesses<br>1 = QSpan II decodes TC[3:0] for IDMA accesses                                                                                                                                              |
| CHAIN     | R/W  | G_RST       | 0              | DMA chaining<br>0 = Direct Mode DMA<br>1 = Linked List Mode DMA                                                                                                                                                                                                                                      |
| DMA       | R/W  | G_RST       | 0              | DMA<br>0 = QSpan II does an IDMA transfer<br>1 = QSpan II does a DMA transfer                                                                                                                                                                                                                        |
| DIR       | R/W  | G_RST       | 0              | Direction<br>0 = Transfer from PCI Bus to QBus<br>1 = Transfer from QBus to PCI bus                                                                                                                                                                                                                  |
| IMODE     | R/W  | G_RST       | 0              | IDMA Mode<br>0 = IDMA transfer is MC68360<br>1 = IDMA transfer is MPC860                                                                                                                                                                                                                             |
| QTERM     | R/W  | G_RST       | 0              | Termination Mode<br>0 = QSpan II uses normal termination during<br>MC68360 dual address IDMA transfers<br>1 = QSpan II uses fast termination during MC68360<br>dual address IDMA transfers                                                                                                           |
| STERM     | R/W  | G_RST       | 0              | Slave Termination Mode<br>0 = External slave uses normal termination mode<br>during MC68360 single address IDMA transfers<br>1 = External slave uses fast termination during<br>MC68360 single address IDMA transfers                                                                                |
| PORT16    | R/W  | G_RST       | 0              | QBus Port 16<br>0 = Source/destination on QBus is a 32-bit port<br>1 = Source/destination on QBus is a 16-bit port                                                                                                                                                                                   |



The programmable I-FIFO Watermark (IWM[3:0]) must be programmed with a value less than or equal to the value programmed in the IDMA Transfer Count Register.

The QTERM bit is important when the QSpan II is operating as an MC68360 IDMA peripheral device during dual address IDMA transfers. During all other conditions this bit does not affect the QSpan II's operation.

The STERM bit is important when the QSpan II is operating as an MC68360 IDMA peripheral device during single address IDMA transfers. During all other conditions this bit does not affect the QSpan II's operation.

The IDMA/DMA Channel can be reset from either bus while it is in progress by writing 1 to the IRST\_REQ bit (see "IDMA Errors, Resets, and Interrupts" on page 95). If the ACT bit is 0, then setting IRST\_REQ to 1 has no effect.

The DONE bit is set by the QSpan II if its transfer count expires in the IDMA/DMA Transfer Count register, or the DONE\_ signal is asserted by the MC68360 during IDMA transfers. Under either condition the QSpan II's IDMA controller will return to the idle state, which is indicated by the ACT bit.

The IRST, DONE, IPE and IQE events can be mapped to the interrupt pins on either bus using the QSpan II's Interrupt Control Registers (see Table 120 on page 269). See Chapter 5: "The IDMA Channel" on page 89 for more information.

### Table 110: IDMA/DMA PCI Address Register

| Register N | Name: IDMA/DMA_PADD |          | Register | Offset: 404 |
|------------|---------------------|----------|----------|-------------|
| Bits       |                     | Function |          |             |
| 31–24      |                     | ADDR     |          |             |
| 23–16      |                     | ADDR     |          |             |
| 15–08      |                     | ADDR     |          |             |
| 07–00      | ADDR                |          | 0        | 0           |

#### IDMA/DMA\_PADD Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                               |
|------------|------|-------------|----------------|----------------------------------------|
| ADDR[31:2] | R/W  | G_RST       | 0              | PCI Bus Address for IDMA/DMA transfers |

The ADDR field must be programmed with the absolute PCI address for an IDMA/DMA transaction. This address is aligned to a 4-byte boundary. An IDMA/DMA transfer wraps-around at the A24 boundary. If an IDMA/DMA transfer is required to cross an A24 boundary, it must be programmed as two separate transactions. This field is incremented by the QSpan II during a transfer. Progress of the IDMA/DMA transfer on the PCI bus can be monitored by reading the IDMA/DMA\_CNT register (see Table 111 on page 256).

This register can be programmed from either bus, or by the DMA controller when it loads a command packet from QBus or PCI memory.

### Table 111: IDMA/DMA Transfer Count Register

| Register N | Name: IDMA/DMA_CNT |          | Register | Offset: 408 |
|------------|--------------------|----------|----------|-------------|
| Bits       |                    | Function |          |             |
| 31–24      |                    | Reserved |          |             |
| 23–16      |                    | CNT      |          |             |
| 15–08      |                    | CNT      |          |             |
| 07–00      | CNT                |          | 0        | 0           |

#### IDMA/DMA\_CNT Description<sup>a</sup>

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                          |
|-----------|------|-------------|----------------|-----------------------------------------------------------------------------------|
| CNT[23:2] | R/W  | G_RST       | 0              | IDMA/DMA Transfer Count<br>Number of Bytes to Transfer (Max = $2^{22} * 4$ bytes) |

a. The IDMA/DMA\_CNT should not be programmed to be less than the specified value in the watermark field, IWM.

CNT[23:2] indicates the number of bytes left to transfer in an IDMA/DMA transaction (see Table 111 on page 256). The QSpan II decreases this transfer counter by four with every 32-bit transfer on the PCI bus. (The IDMA/DMA Channel on the PCI Interface transfers 32-bit data.) The amount of data that can be transferred within an IDMA/DMA transaction is 16 Mbytes (for example, 2<sup>22</sup> 32-bit transfers).

The CNT[23:2] field must be programmed with a minimum value of 0x000010 (corresponding to 16 bytes) otherwise the IDMA/DMA channel will not start when the GO bit is set. The CNT field must initially be programmed with the same value as the processor's IDMA's Byte Count register when IDMA transfers are initiated.

This register can be programmed from either bus, or is programmed by the DMA controller when it loads a command packet from QBus or PCI memory. The command packet only contains CNT[19:2], making the maximum Linked List transfer size 1 Mbyte.

### Table 112: DMA QBus Address Register

| Register N | Name: DMA_QADD |          | Register ( | Offset: 40C |
|------------|----------------|----------|------------|-------------|
| Bits       |                | Function |            |             |
| 31–24      |                | Q_ADDR   |            |             |
| 23–16      |                | Q_ADDR   |            |             |
| 15–08      |                | Q_ADDR   |            |             |
| 07–00      | Q_ADDR         |          | 0          | 0           |

#### DMA\_QADD Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                       |
|--------------|------|-------------|----------------|--------------------------------|
| Q_ADDR[31:2] | R/W  | G_RST       | 0              | QBus Address for DMA transfers |

The Q\_ADDR[31:2] field must be programmed with the absolute QBus address for the DMA transaction. This address is aligned to a 4-byte boundary. A DMA transfer wraps-around at an A24 boundary. If a DMA transfer is required to cross an A24 boundary, it must be programmed as two separate transactions. This field is not incremented by the QSpan II during a transfer: progress of the DMA transfer on the PCI bus can be monitored by reading the IDMA/DMA\_CNT register (see Table 111 on page 256).

This register can be programmed from either bus, or is programmed by the DMA controller when it loads a command packet from QBus or PCI memory.

## Table 113: DMA Control and Status Register

| Register Name: DMA_CS   Register Offset: 410 |
|----------------------------------------------|
|----------------------------------------------|

| Bits  |         |               | Fund | ction    |       |       |        |
|-------|---------|---------------|------|----------|-------|-------|--------|
| 31–24 |         | Т             | с    | DIR      | DS    | IZE   | INVEND |
| 23–16 | IWM     |               |      | Reserved |       | Q_OFF |        |
| 15–08 | BURST_4 | BRSTEN        | Rese | erved    |       | MDBS  | CP_LOC |
| 07–00 | STOP    | STOP_<br>STAT |      | Rese     | erved |       |        |

## DMA\_CS Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                 |
|------------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TC[3:0]    | R/W  | G_RST       | 0              | QBus Transaction Code (for DMA transfers)<br>User Defined                                                                                                                                                                                                                                                |
| DIR        | R    | G_RST       | 0              | DMA Direction<br>0 = Transfer from PCI Bus to QBus<br>1 = Transfer from QBus to PCI bus (read-only copy of<br>DIR bit in IDMA/DMA_CS)                                                                                                                                                                    |
| DSIZE[1:0] | R/W  | G_RST       | 0              | QBus Destination Port Size<br>00 = 32-bit<br>01 = 8-bit<br>10 = 16-bit<br>11 = reserved                                                                                                                                                                                                                  |
| INVEND     | R/W  | G_RST       | 0              | Invert Endian-ness from QB_BOC Setting in<br>MISC_CTL<br>0 = Use QB_BOC setting<br>1 = Invert QB_BOC setting                                                                                                                                                                                             |
| IWM[3:0]   | R/W  | G_RST       | 0              | Programmable I-FIFO Watermark<br>0000 = use the value programmed into the<br>CLINE[1:0] field of the PCI_MISC0 register<br>x = when 16x bytes have been queued in the I-FIFO,<br>the DMA channel will request the PCI bus. Watermark<br>can be set to a maximum of 128 bytes (1000)<br>others = Reserved |

DMA\_CS Description (Continued)

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                     |
|-----------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q_OFF     | R/W  | G_RST       | 0              | DMA QBus Off Counter<br>000b = 0<br>001b = 64<br>010b = 128<br>011b = 256<br>100b = 512<br>101b = 1024<br>others = Reserved<br>The DMA controller will not request the QBus until the<br>programmed number of QCLKs expires. |
| BURST_4   | R/W  | G_RST       | 0              | QBus Burst Four Dataphases<br>0 = QSpan II will generate partial QBus burst (2 or 3<br>dataphases)<br>1 = QSpan II will only generate QBus burst with 4<br>dataphases                                                        |
| BRSTEN    | R/W  | G_RST       | 0              | QBus Burst Enable<br>0 = Disable<br>1 = Enable                                                                                                                                                                               |
| MDBS      | R/W  | G_RST       | 0              | Maximum DMA Burst Size on QBus<br>0 = 256 Bytes<br>1 = 64 Bytes                                                                                                                                                              |
| CP_LOC    | R/W  | G_RST       | 0              | Command Packet Location<br>0 = PCI Bus<br>1 = QBus                                                                                                                                                                           |
| STOP      | R/W  | G_RST       | 0              | DMA Stop<br>0 = Resume DMA transfer<br>1 = Stop DMA transfer                                                                                                                                                                 |
| STOP_STAT | R    | G_RST       | 0              | DMA Stop Status<br>0 = DMA transfer is not stopped<br>1 = DMA transfer is stopped                                                                                                                                            |

The generation of burst cycles is supported when the QSpan II is powered up in MPC860 Master mode. The DMA QBus OFF counter is activated when a DMA transfer crosses a 256-byte address boundary on the QBus. For example, the counter is active after each 256-byte transfer on the QBus when MDBS = 0, otherwise 64-byte boundary is used.

A DMA transfer in progress can be stopped by setting the STOP bit. The DMA transfer is stopped once any active transfer is completed. The STOP\_STAT is set when the DMA is stopped. To restart the DMA, a 0 must be written to the STOP bit.

This register can be programmed from either bus. The upper 12 bits [31:20] can also be loaded from a command packet when in Linked List mode.

The CP\_LOC indicates the location of the command packet in either QBus or PCI Bus memory. All the command packets in a linked list must be in either PCI or QBus memory, and not both.

### Table 114: DMA Command Packet Pointer Register

| Register | Name: DMA_CPP |         | Register Offset: 414 |  |  |
|----------|---------------|---------|----------------------|--|--|
| Bits     |               | Functio | n                    |  |  |
| 31–24    |               | CPP     |                      |  |  |
| 23–16    |               | CPP     |                      |  |  |
| 15–08    |               | CPP     |                      |  |  |
| 07–00    | CPP           |         | Reserved             |  |  |

### DMA\_CPP Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                   |
|-----------|------|-------------|----------------|----------------------------|
| CPP[31:4] | R/W  | G_RST       | 0              | DMA Command Packet Pointer |

This register contains the pointer to the next command packet. Initially it is programmed to the starting packet of the Linked List, and is updated with the address to the next command packet when a command packet is loaded from memory. The packets must be aligned to a 16-byte address.

### Table 115: Configuration Address Register

| Register N | lame: CON | _ADD             |   |   |   |   | Register | Offset: 500 |  |
|------------|-----------|------------------|---|---|---|---|----------|-------------|--|
| Bits       | Function  |                  |   |   |   |   |          |             |  |
| 31–24      | 0         | 0                | 0 | 0 | 0 | 0 | 0        | 0           |  |
| 23–16      |           | BUS_NUM          |   |   |   |   |          |             |  |
| 15–08      | 0         | DEV_NUM FUNC_NUM |   |   |   |   |          |             |  |
| 07–00      |           | REG_NUM 0 TYPE   |   |   |   |   |          |             |  |

### **CON\_ADD** Description

| Name              | Туре | Reset<br>By | Reset<br>State | Function                                             |
|-------------------|------|-------------|----------------|------------------------------------------------------|
| BUS_NUM<br>[7:0]  | R/W  | G_RST       | 0              | Bus Number                                           |
| DEV_NUM<br>[3:0]  | R/W  | G_RST       | 0              | Device Number                                        |
| FUNC_NUM<br>[2:0] | R/W  | G_RST       | 0              | Function Number                                      |
| REG_NUM<br>[5:0]  | R/W  | G_RST       | 0              | Register Number                                      |
| TYPE              | R/W  | G_RST       | 0              | Configuration Cycle Type<br>0 = Type 0<br>1 = Type 1 |

An access to the PCI Configuration Data Register (see Table 117 on page 264) from the QBus Interface performs a corresponding Configuration cycle on the PCI bus. The type of configuration cycle generated by the QSpan II is a function of the TYPE bit.

If the TYPE bit set to 1, an access of the PCI Configuration Data register from the QBus interface performs a corresponding Configuration Type 1 cycle on the PCI bus. During the address phase of the Configuration Type 1 cycle on the PCI bus, the PCI address lines carry the values encoded in the Configuration Address Register  $(AD[31:0] = CON\_ADDR[31:0]).$ 



The QSpan II cannot perform a Type 0 Configuration cycle to a PCI target that has its IDSEL input connected to one of the AD[15..11] signals — bit 15 of the CON\_ADD register is hardcoded as 0. Therefore, for host bridging applications the hardware designer must choose to drive each PCI target's IDSEL input from one of the AD[31..16] signals.

If the TYPE bit set to 0, an access of the PCI Configuration Data register from the QBus interface performs a corresponding Configuration Type 0 cycle on the PCI bus. Programming the Device Number causes one of the upper address lines, AD[31:16], to be asserted during the address phase of the Configuration Type 0 cycle. (Table 115 shows which PCI address line is asserted as a function of the DEV\_NUM[3:0] field.) The remaining address lines during the address phase of the Configuration cycle are controlled by the Function Number and Register Number:

- AD[15:11] = 00000
- AD[10:8] = FUNC\_NUM[2:0]
- AD[7:2] = REG\_NUM[5:0]
- AD[1:0] = 00

| DEV_NUM[3:0] | AD[31:16]           |
|--------------|---------------------|
| 0000         | 0000 0000 0000 0001 |
| 0001         | 0000 0000 0000 0010 |
| 0010         | 0000 0000 0000 0100 |
| 0011         | 0000 0000 0000 1000 |
| 0100         | 0000 0000 0001 0000 |
| 0101         | 0000 0000 0010 0000 |
| 0110         | 0000 0000 0100 0000 |
| 0111         | 0000 0000 1000 0000 |
| 1000         | 0000 0001 0000 0000 |
| 1001         | 0000 0010 0000 0000 |
| 1010         | 0000 0100 0000 0000 |
| 1011         | 0000 1000 0000 0000 |
| 1100         | 0001 0000 0000 0000 |
| 1101         | 0010 0000 0000 0000 |
| 1110         | 0100 0000 0000 0000 |
| 1111         | 1000 0000 0000 0000 |

#### Table 116: PCI AD[31:16] lines asserted as a function of DEV\_NUM field

| Register N | Name: CON_DATA | Register Offset: 504 |
|------------|----------------|----------------------|
| Bits       |                | Function             |
| 31–24      |                | CDATA                |
| 23–16      |                | CDATA                |
| 15–08      |                | CDATA                |
| 07–00      |                | CDATA                |

#### Table 117: Configuration Data Register

#### **CON\_DATA** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function           |
|-------------|------|-------------|----------------|--------------------|
| CDATA[31:0] | R/W  | G_RST       | 0              | Configuration Data |

A write to the PCI Configuration Data register from the PCI bus has no effect. A read from the PCI bus always returns all zeros. A write to the Configuration Data register from the QBus causes a Configuration Write Cycle to be generated on the PCI as defined by the Configuration Address register (see Table 115). A read of this register from the QBus causes a Configuration Read Cycle to be generated on the PCI bus. The PCI bus Configuration cycles generated by accessing the Configuration Data register are processed as delayed transfers.

The QSpan II does not perform byte swapping of data in the Register Channel regardless of whether the QBus is configured as big or little endian. Bit 31 in the register is bit 31 on the QBus regardless of the QB\_BOC bit in the MISC\_CTL register (see Table 127 on page 280). Therefore, software on the QBus may need to swap the data when performing configuration cycles.



The QSpan II generates a bus error upon a register access to the CON\_DATA register if the bus master (BM) bit in the PCI\_CS register is not set.

### Table 118: IACK Cycle Generator Register

| Register N | Name: IACK_GEN | Register Offset: 508 |
|------------|----------------|----------------------|
| Bits       |                | Function             |
| 31–24      |                | IACK_VEC             |
| 23–16      |                | IACK_VEC             |
| 15–08      |                | IACK_VEC             |
| 07–00      |                | IACK_VEC             |

### **IACK\_GEN** Description

| Name               | Туре | Reset By | Reset<br>State | Function              |
|--------------------|------|----------|----------------|-----------------------|
| IACK_VEC<br>[31:0] | R    | GEN_RST  | 0              | PCI IACK Cycle Vector |

This register generates an Interrupt Acknowledge cycle originating on the QBus. Reading this register from the QBus causes an IACK cycle to be generated on the PCI bus. The byte lanes enabled on the PCI bus are determined by SIZ[1:0] and A[1:0] of the QBus read. The address on the QBus used to access the IACK\_GEN register is passed to the PCI bus during the PCI IACK cycle. Address information, however, is ignored during PCI IACK cycles, so this has no effect.

Reads from this register act as delayed transfers. This means that the QBus master is retried until the read data is latched from the PCI target. When the IACK cycle completes on the PCI bus, the IACK\_VEC[31:0] field is returned as read data when the QBus master returns after the retry.

Writing to this register from the QBus or PCI bus has no effect. Reads from the PCI bus return all zeros.

The QSpan II does not perform byte swapping of data in the Register Channel regardless of whether the QBus is configured as big or little endian. Bit 31 in the register is bit 31 on the QBus regardless of the QB\_BOC bit in the MISC\_CTL register (see Table 127 on page 280). Therefore, software on the QBus may need to swap the data when performing IACK cycles.



QSpan II generates a bus error upon register access to the IACK\_GEN register if the bus master (BM) bit in the PCI\_CS register is not set.

## Table 119: Interrupt Status Register

# Register Name: INT\_STAT

Register Offset: 600

| Bits  |        | Function |          |         |        |        |         |         |  |
|-------|--------|----------|----------|---------|--------|--------|---------|---------|--|
| 31–24 | PEL_IS | QEL_IS   | MDPED_IS | PCSR_IS | IQE_IS | IPE_IS | IRST_IS | DONE_IS |  |
| 23–16 | INT_IS | PERR_IS  | SERR_IS  | QINT_IS | MB3_IS | MB2_IS | MB1_IS  | MB0_IS  |  |
| 15–08 | QDPE_S | PSC_IS   | OPNE_S   | IFE_S   | OFE_S  | IPF_S  | OFF_S   |         |  |
| 07–00 |        | Res      | erved    | SI3_IS  | SI2_IS | SI1_IS | SI0_IS  |         |  |

#### **INT\_STAT** Description

| Name     | Туре                     | Reset<br>By | Reset<br>State | Function                                               |
|----------|--------------------------|-------------|----------------|--------------------------------------------------------|
| PEL_IS   | R/Write<br>1 to<br>Clear | G_RST       | 0              | PCI Bus Error Log Interrupt Status                     |
| QEL_IS   | R/Write<br>1 to<br>Clear | G_RST       | 0              | QBus Error Log Interrupt Status                        |
| MDPED_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | PCI Master Data Parity Detected Interrupt Status       |
| PCSR_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | PCI_CS Register Interrupt Status                       |
| IQE_IS   | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA QBus Error Interrupt Status                   |
| IPE_IS   | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA PCI Error Interrupt Status                    |
| IRST_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA Reset Interrupt Status                        |
| DONE_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | IDMA/DMA Done Interrupt Status                         |
| INT_IS   | R/Write<br>1 to<br>Clear | G_RST       | 0              | Status of PCI interrupt input to QBus interrupt output |

**INT\_STAT Description (Continued)** 

| Name    | Туре                     | Reset<br>By | Reset<br>State | Function                                                                                                                  |
|---------|--------------------------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------|
| PERR_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Status of PCI bus PERR# input to QBus interrupt<br>output                                                                 |
| SERR_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Status of PCI bus SERR# input to QBus interrupt output                                                                    |
| QINT_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Status of QBus interrupt input to PCI interrupt output                                                                    |
| MB3_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | MailBox3 Interrupt Status                                                                                                 |
| MB2_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | MailBox2 Interrupt Status                                                                                                 |
| MB1_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | MailBox1 Interrupt Status                                                                                                 |
| MB0_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | MailBox0 Interrupt Status                                                                                                 |
| QDPE_S  | R/Write<br>1 to<br>Clear | G_RST       | 0              | QBus Data Parity Error Status                                                                                             |
| PSC_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | Power State Changed Interrupt Status                                                                                      |
| OPNE_S  | R                        | G_RST       | 0              | Outbound Post_List Not Empty Status<br>This bit is set when the Outbound Post_List is not<br>empty.                       |
| IPN_IS  | R/Write<br>1 to<br>Clear | G_RST       | 0              | Inbound Post_List New Entry Interrupt Status<br>This bit is set when a new entry is posted into the<br>Inbound Post_List. |
| IFE_S   | R                        | G_RST       | 1              | Inbound Free_List Empty Status<br>This bit is set when the Inbound Free_List is empty.                                    |
| OFE_S   | R                        | G_RST       | 1              | Outbound Free_List Empty Status<br>This bit is set when the Outbound Free_List is empty.                                  |
| IPF_S   | R                        | G_RST       | 0              | Inbound Post_List Full Status<br>This bit is set when the Inbound Post_List is full.                                      |

| Name   | Туре                     | Reset<br>By | Reset<br>State | Function                                                                               |
|--------|--------------------------|-------------|----------------|----------------------------------------------------------------------------------------|
| OFF_S  | R                        | G_RST       | 0              | Outbound Free_List Full Status<br>This bit is set when the Outbound Free_List is full. |
| SI3_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Software Interrupt 3 Status                                                            |
| SI2_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Software Interrupt 2 Status                                                            |
| SI1_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Software Interrupt 1 Status                                                            |
| SI0_IS | R/Write<br>1 to<br>Clear | G_RST       | 0              | Software Interrupt 0 Status                                                            |

INT\_STAT Description (Continued)

Interrupt status bits are set upon the assertion of the interrupt condition. Each interrupt status bit in the Interrupt Status register will remain set until a 1 is written to it. Clearing of the interrupt status bit will not clear the source status bit that may have caused the interrupt to be asserted. As part of the interrupt handling routine, a separate register transaction to the corresponding status register must occur.

For instance, the MDPED\_IS bit is set — if it is enabled — when the MD\_PED bit in the PCI Configuration Control and Status Register is set. To clear this interrupt, clear both status bits.

I<sub>2</sub>O related status bits (OPNE\_S, IFE\_S, OFE\_S, IPF\_S, OFF\_S) are set regardless of the corresponding interrupt enable bit in INT\_CTL register. Only IPN\_IS status bit is set when the interrupt enable bit (IPN\_EN in INT\_CTL) is set and a new entry (MFA) is posted into the Inbound Post\_List FIFO.

## Table 120: Interrupt Control Register

| Register Name: INT_CTL | Register Offset: 604 |
|------------------------|----------------------|
|------------------------|----------------------|

| Bits  |                                             | Function |          |         |        |        |         |         |  |
|-------|---------------------------------------------|----------|----------|---------|--------|--------|---------|---------|--|
| 31–24 | PEL_EN                                      | QEL_EN   | MDPED_EN | PCSR_EN | IQE_EN | IPE_EN | IRST_EN | DONE_EN |  |
| 23–16 | INT_EN                                      | PERR_EN  | SERR_EN  | QINT_EN | MB3_EN | MB2_EN | MB1_EN  | MB0_EN  |  |
| 15–08 | QDPE_EN PSC_EN OPNE_EN IPN_EN IFE_EN OFE_EN |          |          |         |        |        | IPF_EN  | OFF_EN  |  |
| 07–00 | Reserved                                    |          |          |         |        |        | SI1     | SI0     |  |

### **INT\_CTL** Description

| Name     | Туре | Reset By | Reset<br>State                                                                                                         | Function                                                                                                                                                                                     |
|----------|------|----------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PEL_EN   | R/W  | G_RST    | 0                                                                                                                      | PCI Bus Error Log Interrupt Enable<br>0 = Disable mapping of PCI error log interrupt<br>1 = Enable mapping of interrupt                                                                      |
| QEL_EN   | R/W  | G_RST    | 0                                                                                                                      | QBus Error Log Interrupt Enable<br>0 = Disable mapping of QBus error log interrupt<br>1 = Enable mapping of interrupt                                                                        |
| MDPED_EN | R/W  | G_RST    | 0                                                                                                                      | <ul> <li>PCI Master Data Parity Detected Interrupt Enable</li> <li>0 = Disable mapping of Master Data Parity Detected</li> <li>interrupt</li> <li>1 = Enable mapping of interrupt</li> </ul> |
| PCSR_EN  | R/W  | G_RST    | 0                                                                                                                      | PCI_CS Register status bit set Interrupt Enable<br>0 = Disable mapping of PCI_CS Register status bit<br>set interrupt<br>1 = Enable mapping of interrupt                                     |
| IQE_EN   | R/W  | G_RST    | 0 IDMA/DMA QBus Error Interrupt Enable<br>0 = Disable mapping of IDMA QBus error in<br>1 = Enable mapping of interrupt |                                                                                                                                                                                              |
| IPE_EN   | R/W  | G_RST    | 0                                                                                                                      | IDMA/DMA PCI Error Interrupt Enable<br>0 = Disable mapping of IDMA PCI error interrupt<br>1 = Enable mapping of interrupt                                                                    |
| IRST_EN  | R/W  | G_RST    | 0                                                                                                                      | IDMA/DMA Reset Interrupt Enable<br>0 = Disable mapping of IDMA reset interrupt<br>1 = Enable mapping of IDMA reset interrupt                                                                 |
| DONE_EN  | R/W  | G_RST    | 0                                                                                                                      | IDMA/DMA Done Interrupt Enable<br>0 = Disable mapping of IDMA done interrupt<br>1 = Enable mapping of interrupt                                                                              |

INT\_CTL Description (Continued)

| Name    | Туре | Reset By | Reset<br>State                                                                                                                                    | Function                                                                                                                                                                                          |
|---------|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT_EN  | R/W  | G_RST    | 0                                                                                                                                                 | Map PCI bus Interrupt Input to QBus Interrupt Output<br>Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                          |
| PERR_EN | R/W  | G_RST    | <ul> <li>Map Parity Error on PCI bus to QBus Interrup<br/>Enable</li> <li>0 = Disable mapping</li> <li>1 = Enable mapping of interrupt</li> </ul> |                                                                                                                                                                                                   |
| SERR_EN | R/W  | G_RST    | 0                                                                                                                                                 | Map SERR# Input to QBus Interrupt Output Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                         |
| QINT_EN | R/W  | G_RST    | 0                                                                                                                                                 | Map QBus Interrupt Input to PCI Bus Interrupt Output<br>Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                          |
| MB3_EN  | R/W  | G_RST    | 0                                                                                                                                                 | MailBox3 Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                                               |
| MB2_EN  | R/W  | G_RST    | 0                                                                                                                                                 | MailBox2 Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                                               |
| MB1_EN  | R/W  | G_RST    | 0 MailBox1 Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                             |                                                                                                                                                                                                   |
| MB0_EN  | R/W  | G_RST    | 0                                                                                                                                                 | MailBox0 Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                                               |
| QDPE_EN | R/W  | G_RST    | 0                                                                                                                                                 | QBus Data Parity Error Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                                 |
| PSC_EN  | R/W  | G_RST    | 0                                                                                                                                                 | Power State Changed Interrupt Enable<br>0 = Disable mapping<br>1 = Enable mapping of interrupt                                                                                                    |
| OPNE_EN | R    | G_RST    | 0                                                                                                                                                 | Outbound Post_List Not Empty Interrupt Enable<br>(read-only copy based on OP_IM in I2O_OPIM<br>register)<br>0 = Disable interrupt<br>1 = Enable interrupt when Outbound Post List is not<br>empty |

INT\_CTL Description (Continued)

| Name   | Туре               | Reset By | Reset<br>State | Function                                                                                                                                           |
|--------|--------------------|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| IPN_EN | R/W                | G_RST    | 0              | Inbound Post_List New Entry Interrupt Enable<br>0 = Disable interrupt<br>1 = Enable interrupt when a new entry is posted into<br>Inbound Post_List |
| IFE_EN | R/W                | G_RST    | 0              | Inbound Free_List Empty Interrupt Enable<br>0 = Disable interrupt<br>1 = Enable interrupt when Inbound Free_List Empty<br>Status is set            |
| OFE_EN | R/W                | G_RST    | 0              | Outbound Free_List Empty Interrupt Enable<br>0 = Disable interrupt<br>1 = Enable interrupt when Outbound Free_List Empty<br>Status is set          |
| IPF_EN | R/W                | G_RST    | 0              | Inbound Post_List Full Interrupt Enable<br>0 = Disable interrupt<br>1 = Enable interrupt when Inbound Post_List Full<br>Status is set              |
| OFF_EN | R/W                | G_RST    | 0              | Outbound Free_List Full Interrupt Enable<br>0 = Disable interrupt<br>1 = Enable interrupt when Outbound Free_List Full<br>Status is set            |
| SI1    | W/Read<br>0 Always | G_RST    | 0              | Software Interrupt 1<br>0 = No effect<br>1 = Sets SI1_IS status bit                                                                                |
| SIO    | W/Read<br>0 Always | G_RST    | 0              | Software Interrupt 0<br>0 = No effect<br>1 = Sets SI0_IS status bit                                                                                |

## Table 121: Interrupt Direction Register

### Register Name: INT\_DIR

Register Offset: 608

| Bits  |          | Function |           |          |         |         |          |          |  |
|-------|----------|----------|-----------|----------|---------|---------|----------|----------|--|
| 31–24 | PEL_DIR  | QEL_DIR  | MDPED_DIR | PCSR_DIR | IQE_DIR | IPE_DIR | IRST_DIR | DONE_DIR |  |
| 23–16 | INT_DIR  | PERR_DIR | SERR_DIR  | QINT_DIR | MB3_DIR | MB2_DIR | MB1_DIR  | MB0_DIR  |  |
| 15–08 | QDPE_DIR | PSC_DIR  | OPNE_DIR  | IPN_DIR  | IFE_DIR | OFE_DIR | IPF_DIR  | OFF_DIR  |  |
| 07–00 |          | Res      | erved     | SI3_DIR  | SI2_DIR | SI1_DIR | SI0_DIR  |          |  |

### **INT\_DIR Description**

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                  |
|-----------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| PEL_DIR   | R/W  | G_RST       | 0              | PCI Error Log Interrupt Direction<br>0 = Map PCI error log interrupt to the QBus<br>1 = Map interrupt to the PCI bus                                      |
| QEL_DIR   | R/W  | G_RST       | 0              | QBus Error Log Interrupt Direction<br>0 = Map QBus error log interrupt to the QBus<br>1 = Map interrupt to the PCI bus                                    |
| MDPED_DIR | R/W  | G_RST       | 0              | PCI Master Data Parity Detected Interrupt Direction<br>0 = Map Master Data Parity Detected interrupt to the<br>QBus<br>1 = Map interrupt to the PCI bus   |
| PCSR_DIR  | R/W  | G_RST       | 0              | PCI_CS Register status bit set Interrupt Direction<br>0 = Map PCI_CS Register status bit set interrupt to the<br>QBus<br>1 = Map interrupt to the PCI bus |
| IQE_DIR   | R/W  | G_RST       | 0              | IDMA\DMA QBus Error Interrupt Direction<br>0 = Map IDMA\DMA QBus error interrupt to the QBus<br>1 = Map interrupt to the PCI bus                          |
| IPE_DIR   | R/W  | G_RST       | 0              | IDMA\DMA PCI Error Interrupt Direction<br>0 = Map IDMA\DMA PCI error interrupt to the QBus<br>1 = Map interrupt to the PCI bus                            |
| IRST_DIR  | R/W  | G_RST       | 0              | IDMA\DMA Reset Interrupt Direction<br>0 = Map IDMA\DMA reset interrupt to the QBus<br>1 = Map interrupt to the PCI bus                                    |
| DONE_DIR  | R/W  | G_RST       | 0              | IDMA\DMA Done Interrupt Direction<br>0 = Map IDMA done interrupt to the QBus<br>1 = Map IDMA done interrupt to the PCI bus                                |
| INT_DIR   | R    | G_RST       | 0              | PCI Interrupt mapping Direction<br>Always mapped to QBus.                                                                                                 |

### INT\_DIR Description (Continued)

| Name     | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                |
|----------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| PERR_DIR | R    | G_RST       | 0              | PCI Parity Error mapping Direction<br>Always mapped to the QBus.                                                                        |
| SERR_DIR | R    | G_RST       | 0              | PCI SERR# mapping Direction<br>Always mapped to QBus.                                                                                   |
| QINT_DIR | R    | G_RST       | 1              | QBus Interrupt mapping Direction<br>Always mapped to PCI Bus.                                                                           |
| MB3_DIR  | R/W  | G_RST       | 0              | MailBox3 Interrupt Direction<br>0 = Map MailBox3 interrupt to the QBus<br>1 = Map MailBox3 interrupt to the PCI bus                     |
| MB2_DIR  | R/W  | G_RST       | 0              | MailBox2 Interrupt Direction<br>0 = Map MailBox2 interrupt to the QBus,<br>1 = Map MailBox2 interrupt to the PCI bus                    |
| MB1_DIR  | R/W  | G_RST       | 0              | MailBox1 Interrupt Direction<br>0 = Map MailBox1 interrupt to the QBus<br>1 = Map MailBox1 interrupt to the PCI bus                     |
| MB0_DIR  | R/W  | G_RST       | 0              | MailBox0 Interrupt Direction<br>0 = Map MailBox0 interrupt to the QBus,<br>1 = Map MailBox0 interrupt to the PCI bus                    |
| QDPE_DIR | R/W  | G_RST       | 0              | QBus Data Parity Error Interrupt Direction<br>0 = Map QBus Data Parity Error interrupt to the QBus,<br>1 = Map interrupt to the PCI bus |
| PSC_DIR  | R    | G_RST       | 0              | Power State Changed Interrupt Direction<br>Always mapped to QBus.                                                                       |
| OPNE_DIR | R    | G_RST       | 1              | Outbound Post_List Not Empty Interrupt Direction<br>Always mapped to PCI Bus.                                                           |
| IPN_DIR  | R    | G_RST       | 0              | Inbound Post_List New Entry Interrupt Direction<br>Always mapped to QBus.                                                               |
| IFE_DIR  | R/W  | G_RST       | 0              | Inbound Free_List Empty Interrupt Direction<br>0 = Map Inbound Free_List Empty interrupt to QBus<br>1 = Map interrupt to the PCI bus    |
| OFE_DIR  | R/W  | G_RST       | 0              | Outbound Free_List Empty Interrupt Direction<br>0 = Map Outbound Free_List Empty interrupt to QBus<br>1 = Map interrupt to the PCI bus  |
| IPF_DIR  | R/W  | G_RST       | 0              | Inbound Post_List Full Interrupt Direction<br>0 = Map Inbound Post_List Full interrupt to QBus<br>1 = Map interrupt to the PCI bus      |

| INT | DIR | Descri | ption | (Continued) |
|-----|-----|--------|-------|-------------|
|     |     |        | P     |             |

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                             |
|---------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
| OFF_DIR | R/W  | G_RST       | 0              | Outbound Free_List Full Interrupt Direction<br>0 = Map Outbound Free_List Full interrupt to QBus<br>1 = Map interrupt to the PCI bus |
| SI3_DIR | R/W  | G_RST       | 0              | Software Interrupt 3 Direction<br>0 = Map software interrupt to the QBus<br>1 = Map interrupt to the PCI bus                         |
| SI2_DIR | R/W  | G_RST       | 0              | Software Interrupt 2 Direction<br>0 = Map software interrupt to the QBus<br>1 = Map interrupt to the PCI bus                         |
| SI1_DIR | R/W  | G_RST       | 0              | Software Interrupt 1 Direction<br>0 = Map software interrupt to the QBus<br>1 = Map interrupt to the PCI bus                         |
| SI0_DIR | R/W  | G_RST       | 0              | Software Interrupt 0 Direction<br>0 = Map software interrupt to the QBus<br>1 = Map interrupt to the PCI bus                         |



In order for an interrupt to be mapped to either bus, it must also have its corresponding interrupt enable set in the Interrupt Control Register (see Table 120 on page 269).

## Table 122: Interrupt Control Register 2

| Register | Name: INT_CTL2 |          |     |     | Register Offset: 60C |  |
|----------|----------------|----------|-----|-----|----------------------|--|
| Bits     |                | Function |     |     |                      |  |
| 31–24    | Reserved       |          |     |     |                      |  |
| 23–16    | Reserved       |          |     |     |                      |  |
| 15–08    | Reserved       |          |     |     |                      |  |
| 07–00    | Reserved       |          | SI3 | SI2 | Reserved             |  |

### **INT\_CTL2** Description

| Name | Туре               | Reset<br>By | Reset<br>State | Function                                                            |
|------|--------------------|-------------|----------------|---------------------------------------------------------------------|
| SI3  | W/Read<br>0 Always | G_RST       | 0              | Software Interrupt 3<br>0 = No effect<br>1 = Sets SI3_IS status bit |
| SI2  | W/Read<br>0 Always | G_RST       | 0              | Software Interrupt 2<br>0 = No effect<br>1 = Sets SI2_IS status bit |

## Table 123: Mailbox 0 Register

| Register Name: MBOX0 |  | Register Offset: 700 |
|----------------------|--|----------------------|
| Bits                 |  | Function             |
| 31–24                |  | MB_DATA              |
| 23–16                |  | MB_DATA              |
| 15–08                |  | MB_DATA              |
| 07–00                |  | MB_DATA              |

### **MBOX0** Description

| Name              | Туре | Reset By | Reset<br>State | Function     |
|-------------------|------|----------|----------------|--------------|
| MB_DATA<br>[31:0] | R/W  | GEN_RST  | 0              | MailBox Data |

## Table 124: Mailbox 1 Register

| Register I | Name: MBOX1 | Register Offset: 704 |
|------------|-------------|----------------------|
| Bits       |             | Function             |
| 31–24      |             | MB_DATA              |
| 23–16      |             | MB_DATA              |
| 15–08      |             | MB_DATA              |
| 07–00      |             | MB_DATA              |

### **MBOX1** Description

| Name              | Туре | Reset By | Reset<br>State | Function     |
|-------------------|------|----------|----------------|--------------|
| MB_DATA<br>[31:0] | R/W  | GEN_RST  | 0              | MailBox Data |

## Table 125: Mailbox 2 Register

| Register Name: MBOX2 |  | Register Offset: 708 |
|----------------------|--|----------------------|
| Bits                 |  | Function             |
| 31–24                |  | MB_DATA              |
| 23–16                |  | MB_DATA              |
| 15–08                |  | MB_DATA              |
| 07–00                |  | MB_DATA              |

### **MBOX2** Description

| Name              | Туре | Reset By | Reset<br>State | Function     |
|-------------------|------|----------|----------------|--------------|
| MB_DATA<br>[31:0] | R/W  | GEN_RST  | 0              | MailBox Data |

## Table 126: Mailbox 3 Register

| Register Name: MBOX3 |  | Register Offset: 70C |
|----------------------|--|----------------------|
| Bits                 |  | Function             |
| 31–24                |  | MB_DATA              |
| 23–16                |  | MB_DATA              |
| 15–08                |  | MB_DATA              |
| 07–00                |  | MB_DATA              |

#### **MBOX3** Description

| Name              | Туре | Reset By | Reset<br>State | Function     |
|-------------------|------|----------|----------------|--------------|
| MB_DATA<br>[31:0] | R/W  | GEN_RST  | 0              | MailBox Data |

## Table 127: Miscellaneous Control and Status Register

| Register Name: MISC_CTL | Register Offset: 800 |
|-------------------------|----------------------|
|-------------------------|----------------------|

| Bits  |                 | Function          |  |      |       |                |                |  |  |
|-------|-----------------|-------------------|--|------|-------|----------------|----------------|--|--|
| 31–24 | SW_RST          | SW_RST Reserved   |  |      |       |                |                |  |  |
| 23–16 |                 | Reserved          |  | S_BG | S_BB  | 0              | QB_BOC         |  |  |
| 15–08 | Reserved MA_BE_ |                   |  | Rese | erved | QFIFO_B<br>LK8 | QFIFO_<br>MODE |  |  |
| 07–00 |                 | PRCNT[5:0] MSTSLV |  |      |       |                | SLV            |  |  |

#### **MISC\_CTL** Description

| Name                 | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------|------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SW_RST               | R/W  | G_RST    | 0              | QBus Software Reset Control<br>0 = software reset not active<br>1 = software reset active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| S_BG                 | R/W  | G_RST    | See<br>below   | Synchronous Bus Grant<br>0 = BG_ input is asynchronous to QCLK<br>1 = BG_ input is synchronous to QCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| S_BB                 | R/W  | G_RST    | See<br>below   | Synchronous Bus Grant Acknowledge<br>0 = BG_ input is asynchronous to QCLK<br>1 = BG_ input is synchronous to QCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| QB_BOC               | R/W  | G_RST    | 0              | QBus Byte Ordering Control<br>0 = QBus uses Big-Endian byte ordering<br>1 = QBus uses PCI Little-Endian byte ordering                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MA_BE_D <sup>a</sup> | R/W  | G_RST    | 0              | Master-Abort - Bus Error Mapping Disable<br>Applies to delayed transfers.<br>0 = When QSpan II issues a PCI Master-Abort, it<br>maps this termination to the QBus as a bus error<br>(behaves in the same manner as previous QSpan<br>designs)<br>1 = When QSpan II receives a PCI Master-Abort it<br>maps this as a normal termination on the QBus. On<br>writes, data is flushed from the channel, and on reads<br>the QSpan II returns all ones. In order to comply with<br>the <i>PCI 2.2 Specification</i> , the MA_BE_D bit should be<br>set to 1 before any PCI configuration cycles are<br>performed, if the QSpan II is being used as a host<br>bridge. |
| QFIFO_BLK8           | R/W  | G_RST    | 0              | This bit must be set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| QFIFO_MODE           | R/W  | G_RST    | 0              | This bit must be set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

MISC\_CTL Description (Continued)

| Name        | Туре | Reset By | Reset<br>State   | Function                                                                                                                                                                                                                             |
|-------------|------|----------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRCNT[5:0]  | R/W  | G_RST    | 000001           | Prefetch Read Byte Count<br>This field controls how much data the QSpan II<br>prefetches on the QBus. The number of bytes<br>prefetched is four times the number programmed into<br>this register (for example, 001100b is 48 bytes) |
| MSTSLV[1:0] | R    | G_RST    | See<br>Table 128 | Master/Slave Mode                                                                                                                                                                                                                    |

a. If you want to map a PCI Target-Abort as an Error on the QBus — and the MA\_BE\_D bit is set — the TA\_BE\_EN bit in MISC\_CTL2 register must also be set.

The SW\_RST bit allows the QBus reset output (RESETO\_) to be controlled in software from the PCI bus. When 1 is written to this bit, the QSpan II asserts RESETO\_. There are three ways to cause the QSpan II to terminate the software reset state:

- 1. Clear the SW\_RST bit by writing 0 to it. In this case, RESETO\_ is immediately negated.
- 2. Assert RESETI\_. In this case, the SW\_RST bit is immediately cleared (set to 0) and RESETO\_ is immediately negated.
- 3. Assert RST#. In this case, SW\_RST is immediately cleared (set to 0), however RESETO\_ continues to be asserted until RST# is negated.



Unexpected results can occur if the output RESETO\_ on the QBus Interface of the QSpan II is used to generate the input RESETI\_.

The reset state of S\_BG and S\_BB depends on the master mode of the QSpan II (see Table 127). If the Master Mode is MC68360, then the reset state of S\_BG and S\_BB is 0. If the Master Mode is MPC860 or M68040, then the reset state of S\_BG and S\_BB is 1.

The QB\_BOC bit affects the transfer of data onto the QBus Interface in cases where the data passes through the QBus Slave Channel, the PCI Target Channel, or the IDMA/DMA Channel. There are two situations to be aware of:

- 1. The PBTIx\_CTL and DMA\_CS registers contain an INVEND bit which causes the QSpan II to use the logical inversion of the QB\_BOC.
- 2. The QB\_BOC bit does not affect the presentation of data on the QBus Interface in the case where the Register Channel is accessed.

With the second situation, the QSpan II does not perform byte swapping of data in the Register Channel regardless of whether the QBus is configured as Big or Little endiar; this applies to all QBus register accesses, including the CON\_DATA and IACK registers. Bit 31 in any QSpan II register is presented on bit 31 of the QBus (and bit 31 of the PCI bus) regardless of the QB\_BOC bit.

The MSTSLV field indicates the Master and Slave modes of the QSpan II. The first bit of this field is determined by the value of BDIP\_ at reset. The second bit is determined by the value of SIZ[1] at reset. The MSTSLV field is described in Table 127.

| MSTSLV field | Master Mode | Slave Mode         |
|--------------|-------------|--------------------|
| 00           | MC68360     | MC68360 and M68040 |
| 01           | MC68360     | MC68360 and MPC860 |
| 10           | M68040      | MC68360 and M68040 |
| 11           | MPC860      | MC68360 and MPC860 |

Table 128: Master/Slave Mode — MSTSLV field

### Table 129: EEPROM Control and Status Register

| Register | Name: EEPI | ROM_CS |           | Register Offset: 804 |  |  |  |
|----------|------------|--------|-----------|----------------------|--|--|--|
| Bits     |            |        | Function  |                      |  |  |  |
| 31–24    |            |        | ADDR[7:0] |                      |  |  |  |
| 23–16    |            |        | DATA[7:0] |                      |  |  |  |
| 15–08    |            |        | Reserved  |                      |  |  |  |
| 07–00    | ACT        | READ   |           | Reserved             |  |  |  |

#### EEPROM\_CS Description

| Name      | Туре         | Reset By | Reset<br>State | Function                                                     |
|-----------|--------------|----------|----------------|--------------------------------------------------------------|
| ADDR[7:0] | See<br>Below | PCI_RST  | See<br>Below   | EEPROM read and write address                                |
| DATA[7:0] | See<br>Below | PCI_RST  | See<br>Below   | EEPROM read and write data                                   |
| ACT       | R            | PCI_RST  | 0              | EEPROM Active<br>0 = No<br>1 = Yes                           |
| READ      | R/W          | PCI_RST  | 0              | EEPROM Read bit<br>0 = Write to EEPROM<br>1 = Read to EEPROM |

This register is provided for users to read to, or write from the EEPROM through the QBus or the PCI bus. This register accepts reads or writes when the ACT bit is 0, therefore the ACT bit might need to be polled before a write is attempted. The ACT bit is 1 when the QSpan II is loading data from the EEPROM, or is in the process of completing a read or write to the EEPROM caused by an access to this register.

Writes complete on the QBus or the PCI bus regardless of the state of the ACT bit (and, therefore, regardless of whether the write to the DATA field was effective).

It there is no EEPROM (the SDA pin and ENID pin are low at PCI reset), then this register is read-only and reads return all zeros (see "Programming the EEPROM from the QBus or PCI Bus" on page 133 for more information). Access to EEPROM can be enabled after power-up using the EEPROM\_ACC bit in the MISC\_CTL2 register (see "EEPROM Access" on page 134).

## Table 130: Miscellaneous Control 2 Register

| Register Name: MISC_CTL2 | Register Offset: 808 |
|--------------------------|----------------------|
|--------------------------|----------------------|

| Bits  |         |          |       | Function     | on             |              |              |              |
|-------|---------|----------|-------|--------------|----------------|--------------|--------------|--------------|
| 31–24 | PCI_DIS |          |       | Reserved     |                |              |              |              |
| 23–16 | PTP_IB  | KEEP_BB  | MAX_F | TRY          | PTC_PD         | TA_BE_<br>EN | BURST_<br>4  | PR_<br>SING  |
| 15–08 |         |          | PRCN  | Г2           |                |              | REG_AC       | QSC_PW       |
| 07–00 |         | Reserved |       | QBUS_<br>PAR | EEPROM<br>_ACC | NOTO         | PSC_<br>QRST | QINT_<br>PME |

### **MISC\_CTL2** Description

| Name              | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI_DIS           | R/W  | G_RST    | See<br>below   | PCI Access Disabled<br>0 = Access from PCI interface is enabled<br>1 = All access to QSpan II from PCI interface is<br>retried                                                                                                                                                                                                                                                    |
| PTP_IB            | R/W  | G_RST    | 0              | PCI Target Channel Prefetch Count Image Based<br>0 = Prefetch count is not image based (use PRCNT<br>in MISC_CTL)<br>1 = Prefetch count is image based<br>(PRCNT = Image 0, PRCNT2 = Image 1)                                                                                                                                                                                     |
| KEEP_BB           | R/W  | G_RST    | 0              | Keep Bus Busy (BB_) asserted for back-to-back<br>cycles<br>This bit applies to all QSpan II PCI target cycles.<br>0 = Bus Busy is negated after each cycle; allows<br>change of Bus mastership<br>1 = Bus Busy is kept asserted for multiple cycles<br><b>Note</b> : Do not set this bit when the QSpan II DMA<br>channel is used with the PowerQUICC memory<br>controller (UPM). |
| MAX_RTRY<br>[1:0] | R/W  | G_RST    | 0              | Maximum Number of Retries completed by<br>QSpan II as a master on the PCI Bus<br>00b = Forever<br>01b = 128<br>10b = 256<br>11b = 384                                                                                                                                                                                                                                             |
| PTC_PD            | R/W  | G_RST    | 0              | PCI Target Channel Prefetch Disconnect<br>0 = TRDY# is negated between databeats until the<br>next data is available<br>1 = Cycle is terminated with Disconnect if the<br>TRDY# is going to be negated for more than eight<br>PCI clocks.                                                                                                                                         |

MISC\_CTL2 Description (Continued)

| Name         | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|------|----------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA_BE_EN     | R/W  | G_RST    | 0              | PCI Target-Abort - Bus Error Mapping Enable<br>0 = When QSpan II receives a PCI Target-Abort it<br>maps this as a normal termination on the QBus (if<br>MA_BE_D bit in MISC_CTL is set to 1). If<br>MA_BE_D is set to 0, then both PCI Master-Abort<br>and Target-Abort terminations are translated to a<br>Bus Error on QBus for delayed cycles.<br>1 = When the QSpan II receives a PCI Target-Abort<br>it maps it to a Bus Error termination on the QBus for<br>delayed cycles. |
| BURST_4      | R/W  | G_RST    | 0              | QBus Burst 4 Data phases (for PCI target channel<br>write transfers)<br>0 = QSpan II will generate partial burst on QBus (2<br>or 3 data phases)<br>1 = QSpan II will only generate QBus burst with 4<br>data phases (required for use with MPC860's<br>memory controller)                                                                                                                                                                                                         |
| PR_SING      | R/W  | G_RST    | 0              | QBus Prefetch Single Dataphase<br>0 = QSpan II will prefetch using burst cycles as an<br>MPC860 master<br>1 = QSpan II will generate single cycles to prefetch<br>data as an MPC860 master                                                                                                                                                                                                                                                                                         |
| PR_CNT2[5:0] | R/W  | G_RST    | 000001         | Prefetch Read Byte Count 2<br>This field controls how much data the Qspan II<br>prefetches on the QBus for an access through the<br>PCI target image 1 (when above PTP_IB bit is set).<br>The number of bytes prefetched is 4 times the<br>number programmed into this field (for example,<br>001100 is 48 bytes)                                                                                                                                                                  |
| QSC_PW       | R/W  | G_RST    | 0              | QBus Slave Channel Posted Write<br>0 = Default mode (for QSpan (CA91C860B,<br>CA91L860B) backward compatibility)<br>1 = Improves the dequeuing of posted writes in the<br>QBus Slave Channel                                                                                                                                                                                                                                                                                       |
| REG_AC       | R/W  | G_RST    | 0              | Register Access Control<br>0 = Normal Mode, register access defaults to PCI<br>bus<br>1 = Register Access port is parked at the last bus to<br>access the register block                                                                                                                                                                                                                                                                                                           |
| QBUS_PAR     | R/W  | G_RST    | 0              | QBus Parity Encoding<br>0 = Even Parity<br>1 = Odd Parity                                                                                                                                                                                                                                                                                                                                                                                                                          |

| MISC | CTL2 Descript | ion (Continued) |
|------|---------------|-----------------|
|      |               |                 |

| Name           | Туре | Reset By | Reset<br>State | Function                                                                                                                                                                                                                                                              |
|----------------|------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EEPROM_<br>ACC | R/W  | G_RST    | 0              | EEPROM Access after Power-up<br>0 = EEPROM access is disabled, if powered up<br>without EEPROM (SDA and ENID low at power-up)<br>1 = EEPROM access is enabled, if powered up<br>without EEPROM                                                                        |
| NOTO           | R/W  | G_RST    | 0              | No Transaction Ordering<br>0 = Enable Transaction Ordering between the PCI<br>Target Channel and QBus Slave Channel<br>1 = Disable Transaction Ordering between the PCI<br>Target Channel and QBus Slave Channel                                                      |
| PSC_QRST       | R/W  | G_RST    | 0              | Power State Change (D3 <sub>hot</sub> to D0) causes QBus<br>reset<br>$0 = Power State Change from D3hot to D0, does notcause a QBus reset1 = Power State Change from D3hot to D0 (initiatedby the Host), causes an internal QSpan II reset andRESETO_ to be asserted$ |
| QINT_PME       | R/W  | G_RST    | 0              | QINT_ assertion in D3 <sub>hot</sub> Power State generates<br>PME#<br>0 = QINT_ assertion does not generate PME#<br>1 = QINT_ assertion in D3 <sub>hot</sub> Power State can<br>generate PME# (if enabled by PME_SP in<br>PCI_PMC register)                           |

If an EEPROM is only used for storing Vital Product Data (VPD), access to EEPROM can be enabled after power-up — SDA and ENID low during Reset — by setting the EEPROM\_ACC bit.

To maximize the performance improvements of the QSpan II, set the following bits to 1: BURST\_4, PWEN bit in PBTIx\_CTL, REG\_AC, QSC\_PW, and NOTO. This will maximize performance if there are no ordering requirements between transactions in the PCI Target Channel and the QBus Slave Channel.

QSpan II can be setup to retry all PCI access while the QBus processor is used to configure the PCI configuration registers. This can be accomplished using the PCI\_DIS bit in MISC\_CTL2. The power-up pin, PCI\_DIS, must be pulled high during PCI reset to set the PCI\_DIS bit to 1. The PCI\_DIS bit can be set to 0 by the QBus processor when it completes programming the QSpan II registers. Once completed, this will then allow the QSpan II to respond to PCI configuration cycles.

The PCI\_DIS bit can also be programmed from the EEPROM, in this case after the QSpan II registers are loaded from EEPROM, the registers can be modified by the QBus processor before the external Host configures the QSpan II.

## Table 131: PCI Bus Arbiter Control Register

| Register Name: PARB_CTL   Register Offset: 810 |
|------------------------------------------------|
|------------------------------------------------|

| Bits  |                | Function           |  |        |        |        |         |        |
|-------|----------------|--------------------|--|--------|--------|--------|---------|--------|
| 31–24 |                | Reserved           |  |        |        |        |         |        |
| 23–16 |                |                    |  | Reserv | ed     |        |         |        |
| 15–08 | M7_PRI         | M6_PRI M5_PRI M4_P |  |        | M3_PRI | M2_PRI | M1_PRI  | QS_PRI |
| 07–00 | PCI_<br>ARB_EN | Reserved           |  |        | PARK   |        | BM_PARK |        |

## PARB\_CTL Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                           |
|--------------|------|-------------|----------------|------------------------------------------------------------------------------------|
| Mx_PRI       | R/W  | G_RST       | 0              | Arbitration Level for PCI Master Device x<br>0 = Low priority<br>1 = High priority |
| QS_PRI       | R/W  | G_RST       | 0              | Arbitration Level for Qspan II<br>0 = Low priority<br>1 = High priority            |
| PCI_ARB_EN   | R    | G_RST       | See<br>Below   | QSpan II's PCI Bus Arbiter<br>0 = Disabled<br>1 = Enabled                          |
| PARK         | R/W  | G_RST       | 0              | PCI Bus Parking Scheme<br>0 = Last Master<br>1 = Select Master based on BM_PARK    |
| BM_PARK[2:0] | R/W  | G_RST       | 0              | Select Master for PCI Bus Parking                                                  |

QSpan II's internal PCI Bus arbiter is enabled by a power-up option. If the PCI\_ARB\_EN pin is sampled high at the negation of Reset, the QSpan II arbiter is enabled. When disabled, an external arbiter is used and REQ#/GNT# are used by the QSpan II to arbitrate for access to the PCI Bus. If the internal arbiter is used, the REQ#/GNT# lines can be used by an external Bus master to arbitrate for the PCI Bus.

| BM_PARK [2:0] | Parked PCI Master | External Pins           |
|---------------|-------------------|-------------------------|
| 000           | Qspan II          | None                    |
| 001           | M1                | EXT_REQ#[1]/EXT_GNT#[1] |
| 010           | M2                | EXT_REQ#[2]/EXT_GNT#[2] |
| 011           | М3                | EXT_REQ#[3]/EXT_GNT#[3] |
| 100           | M4                | EXT_REQ#[4]/EXT_GNT#[4] |
| 101           | M5                | EXT_REQ#[5]/EXT_GNT#[5] |
| 110           | M6                | EXT_REQ#[6]/EXT_GNT#[6] |
| 111           | M7                | REQ#/EXT_GNT#           |

#### Table 132: Parked PCI Master

#### Table 133: QBus Slave Image 0 Control Register

| Register Name: QBSI0_CTL |          |  | Registe  | r Offset: F00 |
|--------------------------|----------|--|----------|---------------|
| Bits                     |          |  | Function |               |
| 31–24                    | PWEN     |  | Reserved | PAS           |
| 23–16                    | PREN     |  | Reserved |               |
| 15–08                    | Reserved |  |          |               |
| 07–00                    |          |  | Reserved |               |

#### QBSI0\_CTL Description

| Name | Туре  | Reset By | Reset<br>State | Function                                                                   |
|------|-------|----------|----------------|----------------------------------------------------------------------------|
| PWEN | R/W/E | PCI_RST  | See<br>Below   | Posted Write Enable<br>0 = Disable<br>1 = Enable                           |
| PAS  | R/W/E | PCI_RST  | See<br>Below   | PCI Bus Address Space<br>0 = PCI Bus Memory Space<br>1 = PCI Bus I/O Space |
| PREN | R/W   | PCI_RST  | See<br>Below   | Prefetch Read Enable<br>0 = Disable<br>1 = Enable                          |

The QBSI0 slave image is used when QSpan II is selected by the assertion of CSPCI\_ and IMSEL (Image Select) is 0. It indicates, among other things, that the QSpan II does not burst to PCI I/O space and responds to such attempts by generating a bus error on the QBus (see "Transaction Decoding and QBus Slave Images" on page 43.

Tables 134 to 137 indicate how the QSpan II Slave module responds to QBus masters as a function of the PWEN and PAS bits settings.

Values in this register (except PREN) can be programmed from a serial EEPROM (for more information, see Chapter 9: "The EEPROM Channel" on page 127). If they are not, their reset state is 0.

| PREN | PAS | Read Cycle (R/W_ negated) |
|------|-----|---------------------------|
| 0    | 0   | Delayed Read              |
| 0    | 1   | Delayed Read              |
| 1    | 0   | Delayed Prefetched Read   |
| 1    | 1   | Delayed Read              |

 Table 134: QSpan II Response to a Single-Read Cycle Access

#### Table 135: QSpan II Response to a Burst-Read Cycle Access

| PREN | PAS | Read Cycle (R/W_ negated) |
|------|-----|---------------------------|
| 0    | 0   | Delayed Read              |
| 0    | 1   | Bus Error                 |
| 1    | 0   | Delayed Read              |
| 1    | 1   | Bus Error                 |

#### Table 136: QSpan II Response to a Single-Write Cycle Access

| PWEN | PAS | Write Cycle (R/W_ asserted) |
|------|-----|-----------------------------|
| 0    | 0   | Delayed Write               |
| 0    | 1   | Delayed Write               |
| 1    | 0   | Posted Write                |
| 1    | 1   | Delayed Write               |

Table 137: QSpan II Response to a Burst-Write Cycle Access

| PWEN | PAS | Write Cycle (R/W_ asserted) |
|------|-----|-----------------------------|
| 0    | 0   | Posted Write                |
| 0    | 1   | Bus Error                   |
| 1    | 0   | Posted Write                |
| 1    | 1   | Bus Error                   |

# Table 138: QBus Slave Image 0 Address Translation Register

| Register Name: QBSI0_AT |          |  | Register | Offset: F04 |
|-------------------------|----------|--|----------|-------------|
| Bits                    | Function |  |          |             |
| 31–24                   | ТА       |  |          |             |
| 23–16                   | TA       |  |          |             |
| 15–08                   | Reserved |  |          |             |
| 07–00                   | BS       |  | Reserved | EN          |

#### QBSI0\_AT Description

| Name      | Туре  | Reset By | Reset<br>State | Function                                                |
|-----------|-------|----------|----------------|---------------------------------------------------------|
| TA[31:16] | R/W/E | PCI_RST  | See<br>Below   | Translation Address                                     |
| BS[3:0]   | R/W/E | PCI_RST  | See<br>Below   | Block Size<br>(64 Kbyte*2)                              |
| EN        | R/W/E | PCI_RST  | See<br>Below   | Enable Address Translation<br>0 = Disable<br>1 = Enable |

The Translation Address specifies the values of the address lines substituted when generating the address for the transaction on the PCI bus. Address translation is enabled by setting the EN bit. Block Size is used to determine which address lines are translated (see Table 139 and "Mapping of EEPROM Bits to QSpan II Registers" on page 130). Otherwise, their reset state is 0.

| BS   | Block Size | Address Lines Translated |
|------|------------|--------------------------|
| 0000 | 64 Kbytes  | A31–A16                  |
| 0001 | 128 Kbytes | A31–A17                  |
| 0010 | 256 Kbytes | A31–A18                  |
| 0011 | 512 Kbytes | A31–A19                  |
| 0100 | 1 Mbyte    | A31–A20                  |
| 0101 | 2 Mbytes   | A31–A21                  |
| 0110 | 4 Mbytes   | A31–A22                  |
| 0111 | 8 Mbytes   | A31–A23                  |
| 1000 | 16 Mbytes  | A31–A24                  |
| 1001 | 32 Mbytes  | A31–A25                  |
| 1010 | 64 Mbytes  | A31–A26                  |
| 1011 | 128 Mbytes | A31–A27                  |
| 1100 | 256 Mbytes | A31–A28                  |
| 1101 | 512 Mbytes | A31–A29                  |
| 1110 | 1 Gbyte    | A31–A30                  |
| 1111 | 2 Gbytes   | A31                      |

Table 139: Address Lines Translated as a Function of Block Size

#### Table 140: QBus Slave Image 1 Control Register

| Register Name: QBSI1_CTL |          |  | Registe  | r Offset: F10 |
|--------------------------|----------|--|----------|---------------|
| Bits                     |          |  | Function |               |
| 31–24                    | PWEN     |  | Reserved | PAS           |
| 23–16                    | PREN     |  | Reserved |               |
| 15–08                    | Reserved |  |          |               |
| 07–00                    |          |  | Reserved |               |

#### QBSI1\_CTL Description

| Name | Туре | Reset<br>By | Reset<br>State                                     | Function                                                                   |
|------|------|-------------|----------------------------------------------------|----------------------------------------------------------------------------|
| PWEN | R/W  | G_RST       | 0 Posted Write Enable<br>0 = Disable<br>1 = Enable |                                                                            |
| PAS  | R/W  | G_RST       | 0                                                  | PCI Bus Address Space<br>0 = PCI Bus Memory Space<br>1 = PCI Bus I/O Space |
| PREN | R/W  | G_RST       | 0                                                  | Prefetch Read Enable<br>0 = Disable<br>1 = Enable                          |

This slave image definition is used when QSpan II is selected by the assertion of CSPCI\_ and IMSEL (Image Select) is 1. It indicates, among other things, that the QSpan II does not burst to PCI I/O space and responds to such attempts by generating a bus error on the QBus. Single posted writes to I/O space are treated as delayed writes (see "Transaction Decoding and QBus Slave Images" on page 43).

Tables 141 to 144 indicate how the QSpan II Slave module responds to QBus masters as a function of the PWEN and PAS bits setting.

Unlike Slave Image 0, this register cannot be programmed with a serial EEPROM.

| PREN | PAS | Read Cycle (R/W_ negated) |
|------|-----|---------------------------|
| 0    | 0   | Delayed Read              |
| 0    | 1   | Delayed Read              |
| 1    | 0   | Delayed Prefetched Read   |
| 1    | 1   | Delayed Read              |

 Table 141: QSpan II Response to a Single-Read Cycle Access

#### Table 142: QSpan II Response to a Burst-Read Cycle Access

| PREN | PAS | Read Cycle (R/W_ negated) |
|------|-----|---------------------------|
| 0    | 0   | Delayed Read              |
| 0    | 1   | Bus Error                 |
| 1    | 0   | Delayed Read              |
| 1    | 1   | Bus Error                 |

Table 143: QSpan II Response to a Single-Write Cycle Access

| PWEN | PAS | Write Cycle (R/W_ asserted) |
|------|-----|-----------------------------|
| 0    | 0   | Delayed Write               |
| 0    | 1   | Delayed Write               |
| 1    | 0   | Posted Write                |
| 1    | 1   | Delayed Write               |

Table 144: QSpan II Response to a Burst-Write Cycle Access

| PWEN | PAS | Write Cycle (R/W_ asserted) |
|------|-----|-----------------------------|
| 0    | 0   | Posted Write                |
| 0    | 1   | Bus Error                   |
| 1    | 0   | Posted Write                |
| 1    | 1   | Bus Error                   |

| Register Name: QBSI1_AT |          |      | Register | Offset: F14 |
|-------------------------|----------|------|----------|-------------|
| Bits                    |          | tion |          |             |
| 31–24                   | ТА       |      |          |             |
| 23–16                   | ТА       |      |          |             |
| 15–08                   | Reserved |      |          |             |
| 07–00                   | BS       |      | Reserved | EN          |

#### Table 145: QBus Slave Image 1 Address Translation Register

#### QBSI1\_AT Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                |
|-----------|------|-------------|----------------|---------------------------------------------------------|
| TA[31:16] | R/W  | G_RST       | 0              | Translation Address<br>See below                        |
| BS[3:0]   | R/W  | G_RST       | 0              | Block Size<br>(64 Kbyte*2)                              |
| EN        | R/W  | G_RST       | 0              | Enable Address Translation<br>0 = Disable<br>1 = Enable |

The Translation Address specifies the values of the address lines substituted when generating the address for the transaction on the PCI bus. Address translation is enabled by setting the EN bit. The Block Size determines which address lines are translated (see Table 146).

Unlike Slave Image 0, this register cannot be programmed with a serial EEPROM.

| BS   | Block Size | Address Lines Translated |
|------|------------|--------------------------|
| 0000 | 64 Kbytes  | A31–A16                  |
| 0001 | 128 Kbytes | A31–A17                  |
| 0010 | 256 Kbytes | A31–A18                  |
| 0011 | 512 Kbytes | A31–A19                  |
| 0100 | 1 Mbyte    | A31–A20                  |
| 0101 | 2 Mbytes   | A31–A21                  |
| 0110 | 4 Mbytes   | A31–A22                  |
| 0111 | 8 Mbytes   | A31–A23                  |
| 1000 | 16 Mbytes  | A31–A24                  |
| 1001 | 32 Mbytes  | A31–A25                  |
| 1010 | 64 Mbytes  | A31–A26                  |
| 1011 | 128 Mbytes | A31–A27                  |
| 1100 | 256 Mbytes | A31–A28                  |
| 1101 | 512 Mbytes | A31–A29                  |
| 1110 | 1 Gbyte    | A31–A30                  |
| 1111 | 2 Gbytes   | A31                      |

Table 146: QBus Address Lines Compared as a function of Block Size

| Table 147: QBus Error Log Control a | and Status Register |
|-------------------------------------|---------------------|
|-------------------------------------|---------------------|

| Register Name: QB_ERRCS |            |        |  |          | Register | Offset: F80 |
|-------------------------|------------|--------|--|----------|----------|-------------|
| Bits                    |            |        |  | tion     |          |             |
| 31–24                   | EN Reserve |        |  | erved    |          | ES          |
| 23–16                   | Reserved   |        |  |          |          |             |
| 15–08                   | Reserved   |        |  |          |          |             |
| 07–00                   |            | TC_ERR |  | Reserved | SIZ_     | ERR         |

#### **QB\_ERRCS** Description

| Name         | Туре                     | Reset<br>By | Reset<br>State | Function                                                                         |
|--------------|--------------------------|-------------|----------------|----------------------------------------------------------------------------------|
| EN           | R/W                      | G_RST       | 0              | Enable QBus Error Log<br>0 = Disable error logging<br>1 = Enable error logging   |
| ES           | R/Write<br>1 to<br>Clear | G_RST       | 0              | QBus Error Status<br>0 = No error currently logged<br>1 = Error currently logged |
| TC_ERR[3:0]  | R                        | G_RST       | 0              | QBus Transaction Code Error Log                                                  |
| SIZ_ERR[1:0] | R                        | G_RST       | 0              | QBus SIZ Field Error Log                                                         |

The QBus Master Module logs errors when a posted write transaction from the Px-FIFO results in a bus error. The assertion of the ES bit can be mapped to the QSpan II's interrupt pins by programming the Interrupt Control Register and the Interrupt Direction Register (see Table 120 on page 269 and Table 121 on page 272, respectively). The mapping of interrupts occurs if the EN bit in the QBus Error Log Control and Status Register is set.

To disable the QBus Error Logging after it is enabled, the ES bit must not be set. If the ES bit is set, it can be cleared by writing a 1 at the same time as a 0 is written to the EN bit.

The TC\_ERR and SIZ\_ERR fields contain valid information when the ES bit is set. At all other times these fields will return all zeros when read.

#### Table 148: QBus Address Error Log

| Register N | Name: QB_AERR | Register Offset: F84 |
|------------|---------------|----------------------|
| Bits       |               | Function             |
| 31–24      |               | QAERR                |
| 23–16      |               | QAERR                |
| 15–08      |               | QAERR                |
| 07–00      |               | QAERR                |

#### **QB\_AERR** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function               |
|-------------|------|-------------|----------------|------------------------|
| QAERR[31:0] | R    | G_RST       | 0              | QBus Address Error Log |

The QBus Master Module will log errors when a posted write transaction results in a bus error.

This register logs the QBus address information. Its contents are qualified by bit ES of the QBus Error Log Control and Status Register (see Table 147 on page 297). The QAERR field contains valid information when ES is set. At all other times, a read of this register will return all zeros.

#### Table 149: QBus Data Error Log

| Register N | Name: QB_DERR | Register Offset: F88 |
|------------|---------------|----------------------|
| Bits       |               | Function             |
| 31–24      |               | QDERR                |
| 23–16      |               | QDERR                |
| 15–08      |               | QDERR                |
| 07–00      |               | QDERR                |

#### **QB\_DERR** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function            |
|-------------|------|-------------|----------------|---------------------|
| QDERR[31:0] | R    | G_RST       | 0              | QBus Data Error Log |

The QBus Master Module will log errors when a posted write transaction results in a bus error.

This register logs the QBus data information. Its contents are qualified by bit ES of the QBus Error Log Control and Status register (see Table 147 on page 297).

# Table 150: I<sub>2</sub>0 Outbound Post\_List Interrupt Status Register

| Register | Name: I2O_OPIS |          |        | Register Offset: 030 |  |  |  |
|----------|----------------|----------|--------|----------------------|--|--|--|
| Bits     |                | Functio  | on     |                      |  |  |  |
| 31–24    | Reserved       |          |        |                      |  |  |  |
| 23–16    |                | Reserved |        |                      |  |  |  |
| 15–08    | Reserved       |          |        |                      |  |  |  |
| 07–00    | Reserved       |          | OP_ISR | Reserved             |  |  |  |

#### I2O\_OPIS Description

| Name   | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                           |
|--------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OP_ISR | R/W  | G_RST       | 0              | Outbound Post_List Interrupt Service Request<br>0 = Outbound Post_List FIFO is empty<br>1 = Outbound Post_List FIFO is not empty. The value<br>of the interrupt mask bit does not affect this bit. |

Reserved

# Table 151: I<sub>2</sub>0 Outbound Post\_List Interrupt Mask Register

Reserved

| Register | Name: I2O_OPIM | Register Offset: 034 |
|----------|----------------|----------------------|
| Bits     |                | Function             |
| 31–24    |                | Reserved             |
| 23–16    |                | Reserved             |
| 15–08    |                | Reserved             |

OP\_IM

#### I2O\_OPIM Description

07-00

| Name  | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                       |
|-------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|
| OP_IM | R    | G_RST       | 1              | Outbound Post_List Interrupt Mask<br>0 = Outbound Post_List Interrupt is enabled<br>1 = Outbound Post_List Interrupt is masked |

| Table | 152: | $I_2O$ | Inbound | Queue | Register |
|-------|------|--------|---------|-------|----------|
|-------|------|--------|---------|-------|----------|

| Register I | Name: I2O_INQ | Register Offset: 04 |  |  |  |  |
|------------|---------------|---------------------|--|--|--|--|
| Bits       |               | Function            |  |  |  |  |
| 31–24      |               | IN_Q                |  |  |  |  |
| 23–16      |               | IN_Q                |  |  |  |  |
| 15–08      |               | IN_Q                |  |  |  |  |
| 07–00      |               | IN_Q                |  |  |  |  |

#### I2O\_INQ Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IN_Q[31:0] | R/WP | G_RST       | 0              | I <sub>2</sub> O Inbound Queue<br>This register controls the access to the inbound<br>queue. The 32-bit value written into this register is<br>written by QSpan II to the Inbound Post_List FIFO<br>which is located in Qbus memory at the address<br>specified by the Inbound Post_List Top Pointer.<br>Accesses to this register result in retries from the<br>time of the PCI write until the write completes on the<br>QBus.<br>PCI reads to this register return data from the<br>Inbound Free_List FIFO, located in Qbus memory on<br>the QBus at the address specified by the Inbound<br>Free_List Bottom Pointer. A value of 0xFFFF FFFF is<br>returned if the Inbound Free_List FIFO is empty. |

# Table 153: I<sub>2</sub>O Outbound Queue Register

| Register Name: I2O_OUTQ |  | Register Offset: 044 |
|-------------------------|--|----------------------|
| Bits                    |  | Function             |
| 31–24                   |  | OUT_Q                |
| 23–16                   |  | OUT_Q                |
| 15–08                   |  | OUT_Q                |
| 07–00                   |  | OUT_Q                |

# I2O\_OUTQ Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OUT_Q[31:0] | R/WP | G_RST       | 0              | I <sub>2</sub> O Outbound Queue<br>This register controls the host processor access to<br>the outbound queue. The 32-bit value written into this<br>register is written by<br>QSpan II to the Outbound Post_List FIFO which is<br>located in Qbus memory at the address specified by<br>the Outbound Post_List Top Pointer. Accesses to this<br>register result in retries from the time of the PCI write<br>until the write completes on the QBus.<br>PCI reads to this register return data from the<br>Outbound Free_List FIFO, located in Qbus memory<br>on the QBus at the address specified by the<br>Outbound Free_List Bottom Pointer. A value of<br>0xFFFF FFFF is returned if the Outbound Free_List<br>FIFO is empty. |

# **Appendix B: Timing**

This appendix provides timing information for the QBus interface. PCI interface timing is not detailed since the QSpan II is *PCI 2.2 Specification* compliant. Timing parameters for all processors are listed first, followed by the timing diagrams.

The following topics are discussed:

- "Timing Parameters" on page 306
- "Wait State Insertion QBus Slave Module" on page 320
- "Timing Diagrams" on page 321

# B.1 Overview

The timing tables described in this appendix include the following:

- Table 154, "Timing Parameters for MC68360 Interface" on page 307
- Table 155, "Timing Parameters for MPC860 Interface" on page 312
- Table 156, "Timing Parameters for M68040 Interface" on page 316
- Table 157, "Timing Parameters for Interrupts and Resets" on page 319
- Table 158, "Timing Parameters for Reset Options" on page 319

The sets of diagrams described in this appendix include the following:

- "QBus Interface MC68360" on page 321
- "QBus Interface MPC860" on page 336
- "QBus Interface M68040" on page 351
- "Interrupts and Resets" on page 361
- "Reset Options" on page 363

# **B.2** Timing Parameters

Test conditions for timing parameters in Table 154 to Table 158 are:

- Test Conditions for 3.3V
  - Commercial (C): 0°C to 70°C, 3.3V±5%
  - Industrial (I): -40°C to 85°C, 3.3V±5%

Use the following figure as a reference when reading the timing diagrams in this appendix.

Figure 24: Reference Voltages for AC Timing Specification







In order to condense the diagrams and tables, certain multifunctional QBus signals are presented in their bus specific forms (for example, DSACK1\_/TA\_ is referred to as TA\_ in the MPC860 and M68040 sections).

|                     |                                                        | 50Cx/50lx |      |     |      |       |      |
|---------------------|--------------------------------------------------------|-----------|------|-----|------|-------|------|
| Timing<br>Parameter | Description                                            | Min       | Max  | Min | Max  | Units | Note |
| t <sub>200</sub>    | QCLK Frequency                                         | -         | 33   | -   | 25   | MHz   | -    |
| t <sub>201</sub>    | Period                                                 | 30        | -    | 40  | -    | ns    | -    |
| t <sub>202</sub>    | Clock Pulse Width (Low)                                | 14        | -    | 19  | -    | ns    | -    |
| t <sub>204</sub>    | Clock Pulse Width (High)                               | 14        | -    | 19  | -    | ns    | -    |
| t <sub>205</sub>    | Clock Rise Time (tr)                                   | -         | 2    | -   | 2    | ns    | -    |
| t <sub>206</sub>    | Clock Fall Time ( $t_{\rm f}$ )                        | -         | 2    | -   | 2    | ns    | -    |
| t <sub>210a</sub>   | A asserted from QCLK (positive edge)                   | -         | 9.6  | -   | 10.7 | ns    | 2    |
| t <sub>210b</sub>   | BERR_ asserted from QCLK (positive edge)               | -         | 9.2  | -   | 10.2 | ns    | 2    |
| t <sub>210c</sub>   | DSACK0_, DSACK1_ asserted<br>from QCLK (positive edge) | -         | 9.4  | -   | 10.4 | ns    | 2    |
| t <sub>210d</sub>   | HALT_ asserted from QCLK (positive edge)               | -         | 8.9  | -   | 9.9  | ns    | 2    |
| t <sub>210e</sub>   | R/W_ asserted from QCLK (positive edge)                | -         | 8    | -   | 8.9  | ns    | 2    |
| t <sub>210f</sub>   | SIZ asserted from QCLK (positive edge)                 | -         | 7.9  | -   | 8.8  | ns    | 2    |
| t <sub>210g</sub>   | TC asserted from QCLK (positive edge)                  | -         | 8.4  | -   | 9.3  | ns    | 2    |
| t <sub>211a</sub>   | BGACK_ asserted from QCLK (positive edge)              | -         | 9.2  | -   | 10.2 | ns    | 1    |
| t <sub>211b</sub>   | BR_ asserted from QCLK (positive edge)                 | -         | 7.4  | -   | 8.2  | ns    | 2    |
| t <sub>212a</sub>   | DSACK0_, DSACK1_ tristated from QCLK (negative edge)   | -         | 9.4  | -   | 10.4 | ns    | -    |
| t <sub>212b</sub>   | BERR_ tristated from QCLK (negative edge)              | -         | 9.6  | -   | 10.6 | ns    | -    |
| t <sub>212c</sub>   | HALT_ tristated from QCLK (negative edge)              | -         | 9.1  | -   | 10.1 | ns    | -    |
| t <sub>213</sub>    | D asserted (slave reads) from QCLK (negative edge)     | -         | 14.8 | -   | 16.4 | ns    | 1    |

Table 154: Timing Parameters for MC68360 Interface

|                     |                                                     | Freque | ency/Tem | perature | Options |       |      |
|---------------------|-----------------------------------------------------|--------|----------|----------|---------|-------|------|
| The last            |                                                     | 50C    | x/50lx   | 40       | Cx      |       |      |
| Timing<br>Parameter | Description                                         | Min    | Max      | Min      | Max     | Units | Note |
| t <sub>214</sub>    | D tristated (slave reads) from QCLK (positive edge) | -      | 13.7     | -        | 15.2    | ns    | -    |
| t <sub>215a</sub>   | AS_ asserted from QCLK (negative edge)              | -      | 8        | -        | 8.9     | ns    | 1    |
| t <sub>215b</sub>   | DS_ asserted from QCLK (negative edge)              | -      | 7.8      | -        | 8.7     | ns    | -    |
| t <sub>216a</sub>   | AS_ tristated from QCLK (positive edge)             | -      | 7.9      | -        | 8.8     | ns    | -    |
| t <sub>216b</sub>   | DS_ tristated from QCLK (positive edge)             | -      | 8.1      | -        | 9       | ns    | -    |
| t <sub>217a</sub>   | BERR_setup to QCLK (negative edge)                  | 0      | -        | 0        | -       | ns    | -    |
| t <sub>217b</sub>   | BG_ setup to QCLK (negative edge)                   | -0.9   | -        | -1.0     | -       | ns    | -    |
| t <sub>217c</sub>   | BGACK_ setup to QCLK (negative edge)                | 0      | -        | 0        | -       | ns    | -    |
| t <sub>217d</sub>   | DSACK0_, DSACK1_ setup to QCLK (negative edge)      | 0      | -        | 0        | -       | ns    | -    |
| t <sub>217e</sub>   | HALT_ setup to QCLK (negative edge)                 | 0      | -        | 0        | -       | ns    | -    |
| t <sub>218a</sub>   | BERR_ hold from QCLK<br>(negative edge)             | 0      | -        | 0        | -       | ns    | -    |
| t <sub>218b</sub>   | BG_ hold from QCLK (negative edge)                  | 0      | -        | 0        | -       | ns    | -    |
| t <sub>218c</sub>   | BGACK_ hold from QCLK<br>(negative edge)            | 1.4    | -        | 1.5      | -       | ns    | -    |
| t <sub>218d</sub>   | DSACK0_, DSACK1_ hold from QCLK (negative edge)     | 0      | -        | 0        | -       | ns    | -    |
| t <sub>218e</sub>   | HALT_ hold from QCLK<br>(negative edge)             | 0      | -        | 0        | -       | ns    | -    |
| t <sub>219a</sub>   | A setup to QCLK (negative edge)                     | 7      | -        | 7.8      | -       | ns    | -    |
| t <sub>219b</sub>   | AS_ setup to QCLK (negative edge)                   | 3.4    | -        | 3.8      | -       | ns    | -    |

# Table 154: Timing Parameters for MC68360 Interface (Continued)

|                     |                                                 | Freque | ency/Tem | Options |     |       |      |
|---------------------|-------------------------------------------------|--------|----------|---------|-----|-------|------|
| Timina              |                                                 | 50C)   | «/50lx   | 40      | Cx  |       |      |
| Timing<br>Parameter | Description                                     | Min    | Max      | Min     | Max | Units | Note |
| t <sub>219c</sub>   | CSPCI_ setup to QCLK<br>(negative edge)         | 2.8    | -        | 3.1     | -   | ns    | -    |
| t <sub>219d</sub>   | CSREG_ setup to QCLK (negative edge)            | 7      | -        | 7.8     | -   | ns    | -    |
| t <sub>219e</sub>   | IMSEL setup to QCLK (negative edge)             | 3      | -        | 3.3     | -   | ns    | -    |
| t <sub>219f</sub>   | R/W_ setup to QCLK (negative edge)              | 3.2    | -        | 3.6     | -   | ns    | -    |
| t <sub>219g</sub>   | SIZ setup to QCLK (negative edge)               | 6.6    | -        | 7.3     | -   | ns    | -    |
| t <sub>219h</sub>   | TC setup to QCLK (negative edge)                | 4.5    | -        | 5       | -   | ns    | -    |
| t <sub>220a</sub>   | A hold from QCLK (negative edge)                | 0.1    | -        | 0.1     | -   | ns    | -    |
| t <sub>220b</sub>   | AS_ hold from QCLK (negative edge)              | 0.5    | -        | 0.5     | -   | ns    | -    |
| t <sub>220c</sub>   | CSPCI_ hold from QCLK<br>(negative edge)        | 0.9    | -        | 1       | -   | ns    | -    |
| t <sub>220d</sub>   | CSREG_ hold from QCLK<br>(negative edge)        | 1.5    | -        | 1.7     | -   | ns    | -    |
| t <sub>220e</sub>   | IMSEL hold from QCLK<br>(negative edge)         | 0      | -        | 0       | -   | ns    | -    |
| t <sub>220f</sub>   | R/W_ hold from QCLK (negative edge)             | 0.9    | -        | 1       | -   | ns    | -    |
| t <sub>220g</sub>   | SIZ hold from QCLK (negative edge)              | 0      | -        | 0       | -   | ns    | -    |
| t <sub>220h</sub>   | TC hold from QCLK (negative edge)               | 0      | -        | 0       | -   | ns    | -    |
| t <sub>221</sub>    | D setup (master reads) to QCLK (negative edge)  | 0      | -        | 0       | -   | ns    | -    |
| t <sub>222</sub>    | D hold (master reads) from QCLK (negative edge) | 2.1    | -        | 2.3     | -   | ns    | -    |
| t <sub>223</sub>    | D setup (slave writes) to QCLK (positive edge)  | 0      | -        | 0       | -   | ns    | -    |

Table 154: Timing Parameters for MC68360 Interface (Continued)

|                     |                                                                       | Freque | ency/Temp | Options |      |       |      |
|---------------------|-----------------------------------------------------------------------|--------|-----------|---------|------|-------|------|
|                     |                                                                       | 50C    | x/50lx    | 40      | Cx   |       |      |
| Timing<br>Parameter | Description                                                           | Min    | Max       | Min     | Max  | Units | Note |
| t <sub>224</sub>    | D hold (slave writes) from QCLK (positive edge)                       | 1.8    | -         | 2       | -    | ns    | -    |
| t <sub>225</sub>    | D asserted (master writes) from QCLK (positive edge)                  | -      | 9.8       | -       | 10.9 | ns    | 1    |
| t <sub>226</sub>    | D tristated (master writes) from QCLK (positive edge)                 | 3.9    | 9.8       | 4.3     | 10.9 | ns    | -    |
| t <sub>234</sub>    | BGACK_ tristated from QCLK (negative edge)                            | -      | 9.2       |         | 10.2 | ns    | -    |
| t <sub>235a</sub>   | BGACK_ negated from QCLK (positive edge)                              | 3.2    | 7.4       | 3.6     | 8.2  | ns    | 2    |
| t <sub>235b</sub>   | BR_ negated from QCLK (positive edge)                                 | 3.2    | 7.3       | 3.5     | 8.1  | ns    | 1    |
| t <sub>236a</sub>   | A tristated or negated from QCLK (positive edge)                      | 3.8    | 9.6       | 4.3     | 10.7 | ns    | 1    |
| t <sub>236b</sub>   | BERR_tristated or negated from QCLK (positive edge)                   | 3.7    | 9.2       | 4.1     | 10.2 | ns    | 1    |
| t <sub>236c</sub>   | DSACK0_, DSACK1_ tristated<br>or negated from QCLK (positive<br>edge) | 3.3    | 9.4       | 3.7     | 10.4 | ns    | 1    |
| t <sub>236d</sub>   | HALT_ tristated or negated from QCLK (positive edge)                  | 3.5    | 8.9       | 3.9     | 9.9  | ns    | 1    |
| t <sub>236e</sub>   | R/W_ tristated or negated from QCLK (positive edge)                   | 3.2    | 8         | 3.6     | 8.9  | ns    | 1    |
| t <sub>236f</sub>   | SIZ tristated or negated from QCLK (positive edge)                    | 3.1    | 7.9       | 3.5     | 8.8  | ns    | 1    |
| t <sub>236g</sub>   | TC tristated or negated from QCLK (positive edge)                     | 3.3    | 8.4       | 3.7     | 9.3  | ns    | 1    |
| t <sub>250</sub>    | DREQ_asserted (or negated) from QCLK (negative edge)                  | 4      | 9.3       | 4.4     | 10.4 | ns    | 2    |
| t <sub>251</sub>    | D asserted (valid) from DACK_<br>(negative edge)                      | -      | 12.5      | -       | 13.9 | ns    | 1    |
| t <sub>252</sub>    | D tristated from DACK_ (positive edge)                                | 3.9    | 12.5      | 4.4     | 13.9 | ns    | -    |
| t <sub>253a</sub>   | AS_ setup to QCLK (negative edge)                                     | 3.4    | -         | 3.8     | -    | ns    | -    |

Table 154: Timing Parameters for MC68360 Interface (Continued)

|                     |                                                 | Freque | ency/Tem | Options |     |       |      |
|---------------------|-------------------------------------------------|--------|----------|---------|-----|-------|------|
| Timein a            |                                                 | 50C)   | «/50lx   | 40      | Cx  |       |      |
| Timing<br>Parameter | Description                                     | Min    | Max      | Min     | Max | Units | Note |
| t <sub>253b</sub>   | CSPCI_ setup to QCLK (negative edge)            | 2.8    | -        | 3.1     | -   | -     | -    |
| t <sub>254</sub>    | DACK_setup to QCLK (negative edge)              | 2.5    | -        | 2.8     | -   | ns    | -    |
| t <sub>255</sub>    | DSACK0_, DSACK1_ setup to QCLK (negative edge)  | 0.6    | -        | 0.6     | -   | ns    | -    |
| t <sub>256</sub>    | BERR_setup to QCLK (negative edge)              | 3      | -        | 3.3     | -   | ns    | -    |
| t <sub>257</sub>    | HALT_ setup to QCLK (negative edge)             | 2      | -        | 2.2     | -   | ns    | -    |
| t <sub>258</sub>    | D setup to QCLK (negative edge)                 | 0      | -        | 0       | -   | ns    | -    |
| t <sub>259a</sub>   | AS_ hold from QCLK (negative edge)              | 0.5    | -        | 0.5     | -   | ns    | -    |
| t <sub>259b</sub>   | CSPCI_ hold from QCLK<br>(negative edge)        | 0.9    | -        | 1       | -   | ns    | -    |
| t <sub>259c</sub>   | D hold from QCLK (negative edge)                | 2.1    | -        | 2.4     | -   | ns    | -    |
| t <sub>259d</sub>   | DACK_ hold from QCLK<br>(negative edge)         | 0.6    | -        | 0.7     | -   | ns    | -    |
| t <sub>259e</sub>   | DSACK0_, DSACK1_ hold from QCLK (negative edge) | 0.7    | -        | 0.8     | -   | ns    | -    |
| t <sub>259f</sub>   | BERR_ hold from QCLK<br>(negative edge)         | 0.5    | -        | 0.6     | -   | ns    | -    |
| t <sub>259g</sub>   | HALT_ hold from QCLK<br>(negative edge)         | 1.2    | -        | 1.3     | -   | ns    | -    |
| t <sub>260</sub>    | DONE_ setup to QCLK<br>(negative edge)          | 0.1    | -        | 0.1     | -   | ns    | -    |
| t <sub>261</sub>    | DONE_ hold from QCLK<br>(negative edge)         | 1.8    | -        | 2       | -   | ns    | -    |
| t <sub>262a</sub>   | AS_ negated from QCLK<br>(negative edge)        | 3.4    | 8        | 3.8     | 8.9 | ns    | 1    |
| t <sub>262b</sub>   | DS_ negated from QCLK<br>(negative edge)        | 3.4    | 7.8      | 3.8     | 8.7 | ns    | 1    |

Table 154: Timing Parameters for MC68360 Interface (Continued)

1. Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 50 pF.

2. Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 35 pF.



During IDMA fast termination cycles the maximum MC68360 QCLK frequency is 30 MHz. This applies to every variant of QSpan II.

#### Table 155: Timing Parameters for MPC860 Interface

|                     |                                            | Frequency/Temperature Option |        |     |      |       |      |
|---------------------|--------------------------------------------|------------------------------|--------|-----|------|-------|------|
|                     |                                            | 50C)                         | x/50lx | 40  | Cx   |       |      |
| Timing<br>Parameter | Description                                | Min                          | Max    | Min | Max  | Units | Note |
| t <sub>300</sub>    | QCLK Frequency                             | -                            | 50     | -   | 40   | MHz   | -    |
| t <sub>301</sub>    | Period                                     | 20                           | -      | 25  | -    | ns    | -    |
| t <sub>302</sub>    | Clock Pulse Width (Low)                    | 8                            | -      | 10  | -    | ns    | -    |
| t <sub>304</sub>    | Clock Pulse Width (High)                   | 8                            | -      | 10  | -    | ns    | -    |
| t <sub>305</sub>    | Clock Rise Time (t <sub>r</sub> )          | -                            | 2      | -   | 2    | ns    | -    |
| t <sub>306</sub>    | Clock Fall Time (t <sub>f</sub> )          | -                            | 2      | -   | 2    | ns    | -    |
| t <sub>310a</sub>   | A asserted from QCLK (positive edge)       | -                            | 8.9    | -   | 10.7 | ns    | 1    |
| t <sub>310b</sub>   | BB_ asserted from QCLK (positive edge)     | -                            | 8.2    | -   | 9.8  | ns    | 1    |
| t <sub>310c</sub>   | BURST_ asserted from QCLK (positive edge)  | -                            | 7.5    | -   | 9.6  | ns    | 1    |
| t <sub>310d</sub>   | R/W_ asserted from QCLK (positive edge)    | -                            | 6.9    | -   | 8.9  | ns    | 1    |
| t <sub>310e</sub>   | SIZ asserted from QCLK (positive edge)     | -                            | 6.9    | -   | 8.8  | ns    | 1    |
| t <sub>310f</sub>   | TA_ asserted from QCLK (positive edge)     | -                            | 8.2    | -   | 10.5 | ns    | 1    |
| t <sub>310g</sub>   | TC asserted from QCLK (positive edge)      | -                            | 7.3    | -   | 9.3  | ns    | 1    |
| t <sub>310h</sub>   | TEA_ asserted from QCLK (positive edge)    | -                            | 8.0    | -   | 9.6  | ns    | 1    |
| t <sub>310i</sub>   | TRETRY_ asserted from QCLK (positive edge) | -                            | 8      | -   | 10.2 | ns    | 1    |
| t <sub>310j</sub>   | TS_ asserted from QCLK (positive edge)     | -                            | 7.3    | -   | 9.4  | ns    | 1    |
| t <sub>310k</sub>   | BDIP_ asserted from QCLK (positive edge)   | -                            | 7.6    | -   | 9.8  | ns    | 1    |

|                     |                                                     | Frequ | ency/Tem | perature O | ptions |       |      |
|---------------------|-----------------------------------------------------|-------|----------|------------|--------|-------|------|
|                     |                                                     | 50C)  | k/50lx   | 40         | Cx     |       |      |
| Timing<br>Parameter | Description                                         | Min   | Max      | Min        | Max    | Units | Note |
| t <sub>311</sub>    | BR_ asserted (or negated) from QCLK (positive edge) | 2.8   | 6.4      | 3.6        | 8.2    | ns    | 2    |
| t <sub>312a</sub>   | BB_ tristated from QCLK (negative edge)             | -     | 8        | -          | 10.2   | ns    | -    |
| t <sub>312b</sub>   | TS_ tristated from QCLK (negative edge)             | -     | 7.5      | -          | 9.6    | ns    | -    |
| t <sub>313a</sub>   | BB_ setup to QCLK (positive edge)                   | 4.5   | -        | 5.8        | -      | ns    | -    |
| t <sub>313b</sub>   | BDIP_ setup to QCLK (positive edge)                 | 2.4   | -        | 3          | -      | ns    | -    |
| t <sub>313c</sub>   | BG_ setup to QCLK (positive edge)                   | 4.7   | -        | 6          | -      | ns    | -    |
| t <sub>313d</sub>   | BURST_ setup to QCLK (positive edge)                | 4.4   | -        | 5.6        | -      | ns    | -    |
| t <sub>313e</sub>   | D setup to QCLK (positive edge)                     | 6     | -        | 7.7        | -      | ns    | 3    |
| t <sub>313f</sub>   | IMSEL setup to QCLK (positive edge)                 | 3.9   | -        | 5          | -      | ns    | -    |
| t <sub>313g</sub>   | TA_ setup to QCLK (positive edge)                   | 5.5   | -        | 7          | -      | ns    | -    |
| t <sub>313h</sub>   | TEA_ setup to QCLK (positive edge)                  | 6     | -        | 7.6        | -      | ns    | -    |
| t <sub>313i</sub>   | TRETRY_ setup to QCLK (positive edge)               | 5.3   | -        | 6.8        | -      | ns    | -    |
| t <sub>314</sub>    | D valid (slave reads) from QCLK (positive edge)     | 3     | 9.5      | 3.9        | 12.2   | ns    | 1,3  |
| t <sub>315a</sub>   | A_ hold from QCLK (positive edge)                   | 0.7   | -        | 0.8        | -      | ns    | -    |
| t <sub>315b</sub>   | BB_ hold from QCLK (positive edge)                  | 0     | -        | 0          | -      | ns    | -    |
| t <sub>315c</sub>   | BDIP_ hold from QCLK (positive edge)                | 0.6   | -        | 0.7        | -      | ns    | -    |
| t <sub>315d</sub>   | BG_ hold from QCLK (positive edge)                  | 0     | -        | 0          | -      | ns    | -    |
| t <sub>315e</sub>   | BURST_ hold from QCLK (positive edge)               | 0.5   | -        | 0.6        | -      | ns    | -    |
| t <sub>315f</sub>   | CSPCI_hold from QCLK (positive edge)                | 0.4   | -        | 0.5        | -      | ns    | -    |
| t <sub>315g</sub>   | CSREG_ hold from QCLK (positive edge)               | 0.5   | -        | 0.6        | -      | ns    | -    |
| t <sub>315h</sub>   | D hold from QCLK (positive edge)                    | 1.6   | -        | 2          | -      | ns    | 3    |
| t <sub>315i</sub>   | IMSEL hold from QCLK (positive edge)                | 0     | -        | 0          | -      | ns    | -    |
| t <sub>315j</sub>   | R/W_ hold from QCLK (positive edge)                 | 0.6   | -        | 0.7        | -      | ns    | -    |

Table 155: Timing Parameters for MPC860 Interface (Continued)

|                     |                                                   | Frequ | ency/Temj | perature O | ptions |       |      |
|---------------------|---------------------------------------------------|-------|-----------|------------|--------|-------|------|
|                     |                                                   | 50C)  | «/50lx    | 40         | Cx     |       |      |
| Timing<br>Parameter | Description                                       | Min   | Max       | Min        | Max    | Units | Note |
| t <sub>315k</sub>   | SIZ hold from QCLK (positive edge)                | 0.9   | -         | 1.1        | -      | ns    | -    |
| t <sub>3151</sub>   | TA_ hold from QCLK (positive edge)                | 0.2   | -         | 0.2        | -      | ns    | -    |
| t <sub>315m</sub>   | TC hold from QCLK (positive edge)                 | 1.8   | -         | 2.2        | -      | ns    | -    |
| t <sub>315n</sub>   | TEA_ hold from QCLK (positive edge)               | 0.3   | -         | 0.4        | -      | ns    | -    |
| t <sub>3150</sub>   | TRETRY_ hold from QCLK (positive edge)            | 0.3   | -         | 0.3        | -      | ns    | -    |
| t <sub>315p</sub>   | TS_ hold from QCLK (positive edge)                | 0.6   | -         | 0.8        | -      | ns    | -    |
| t <sub>316</sub>    | D tristated from QCLK (positive edge)             | 3.4   | 12.0      | 4.3        | 15.2   | ns    | 3    |
| t <sub>317</sub>    | D enabled from QCLK (positive edge)               | -     | 12.0      | -          | 15.2   | ns    | 3    |
| t <sub>334</sub>    | D valid (master writes) from QCLK (positive edge) | -     | 8.5       | -          | 10.9   | ns    | 1,3  |
| t <sub>335a</sub>   | TA_ tristated from QCLK (negative edge)           | -     | 8.2       | -          | 10.5   | ns    | -    |
| t <sub>335b</sub>   | TEA_ tristated from QCLK (negative edge)          | -     | 8.1       | -          | 10.4   | ns    | -    |
| t <sub>335c</sub>   | TRETRY_ tristated from QCLK (negative edge)       | -     | 7.8       | -          | 10     | ns    | -    |
| t <sub>336a</sub>   | A negated from QCLK (positive edge)               | -     | 8.4       | -          | 10.7   | ns    | 1    |
| t <sub>336b</sub>   | BB_ negated from QCLK (positive edge)             | 2.7   | 6.4       | 3.5        | 8.1    | ns    | 1    |
| t <sub>336c</sub>   | BURST_ negated from QCLK (positive edge)          | -     | 7.8       | -          | 10     | ns    | 1    |
| t <sub>336d</sub>   | R/W_ negated from QCLK (positive edge)            | -     | 6.9       | -          | 8.9    | ns    | 1    |
| t <sub>336e</sub>   | SIZ negated from QCLK (positive edge)             | -     | 6.9       | -          | 8.8    | ns    | 1    |
| t <sub>336f</sub>   | TA_ negated from QCLK (positive edge)             | 2.8   | 7.3       | 3.7        | 9.3    | ns    | 1    |
| t <sub>336g</sub>   | TC negated from QCLK (positive edge)              | -     | 8.2       | -          | 10.5   | ns    | 1    |
| t <sub>336h</sub>   | TEA_ negated from QCLK (positive edge)            | 3.2   | 9.3       | 4.1        | 11.9   | ns    | 1    |
| t <sub>336i</sub>   | TRETRY_ negated from QCLK (positive edge)         | 3     | 8.1       | 3.8        | 10.3   | ns    | 1    |
| t <sub>336j</sub>   | TS_negated from QCLK (positive edge)              | 3.5   | 6.4       | 4.6        | 8.2    | ns    | 1    |

# Table 155: Timing Parameters for MPC860 Interface (Continued)

|                     |                                                          | Frequ | ency/Temj | perature O | ptions |       |      |
|---------------------|----------------------------------------------------------|-------|-----------|------------|--------|-------|------|
|                     |                                                          | 50C)  | «/50lx    | 40         | Cx     |       |      |
| Timing<br>Parameter | Description                                              | Min   | Мах       | Min        | Max    | Units | Note |
| t <sub>336k</sub>   | BDIP_ negated from QCLK (positive edge)                  | -     | 7.8       | -          | 10     | ns    | 1    |
| t <sub>337a</sub>   | A setup to QCLK (positive edge)                          | 5.3   | -         | 6.8        | -      | ns    | -    |
| t <sub>337b</sub>   | CSPCI_ setup to QCLK (positive edge)                     | 3.4   | -         | 4.4        | -      | ns    | -    |
| t <sub>337c</sub>   | CSREG_ setup to QCLK (positive edge)                     | 5.3   | -         | 6.8        | -      | ns    | -    |
| t <sub>337d</sub>   | R/W_ setup to QCLK (positive edge)                       | 3.6   | -         | 4.6        | -      | ns    | -    |
| t <sub>337e</sub>   | SIZ setup to QCLK (positive edge)                        | 4.9   | -         | 6.3        | -      | ns    | -    |
| t <sub>337f</sub>   | TC setup to QCLK (positive edge)                         | 5     | -         | 7.1        | -      | ns    | -    |
| t <sub>337g</sub>   | TS_ setup to QCLK (positive edge)                        | 3.7   | -         | 4.7        | -      | ns    | -    |
| t <sub>350</sub>    | DREQ_ asserted (or negated) from<br>QCLK (positive edge) | 3.7   | 9.2       | 4.8        | 11.8   | ns    | 2    |
| t <sub>351</sub>    | D asserted (valid) from SDACK_<br>(negative edge)        |       | 10.8      | -          | 13.9   | ns    | 1,3  |
| t <sub>352</sub>    | D tristated from TA_ (positive edge)                     | 4.1   | 12.4      | 5.3        | 15.9   | ns    | 3    |
| t <sub>353a</sub>   | CSPCI_ setup to QCLK (positive edge)                     | 3.5   | -         | 4.4        | -      | ns    | -    |
| t <sub>353b</sub>   | TS_ setup to QCLK (positive edge)                        | 4.1   | -         | 5.2        | -      | ns    | -    |
| t <sub>354</sub>    | SDACK_ setup to QCLK (positive edge)                     | 0     | -         | 0          | -      | ns    | -    |
| t <sub>355a</sub>   | TA_ setup to QCLK (positive edge)                        | 3.1   | -         | 3.9        | -      | ns    | -    |
| t <sub>355b</sub>   | TEA_ setup to QCLK (positive edge)                       | 3.5   | -         | 4.5        | -      | ns    | -    |
| t <sub>356</sub>    | TRETRY_ setup to QCLK (positive edge)                    | 3.1   | -         | 4          | -      | ns    | -    |
| t <sub>357a</sub>   | TA_ asserted to SDACK_ (positive edge)                   | 2     | -         | 2          | -      | ns    | -    |
| t <sub>357b</sub>   | TEA_ asserted to SDACK_ (positive edge)                  | 2     | -         | 2          | -      | ns    | -    |
| t <sub>357c</sub>   | TRETRY_ asserted to SDACK_<br>(positive edge)            | 2     | -         | 2          | -      | ns    | -    |
| t <sub>359a</sub>   | CSPCI_ hold from QCLK (positive edge)                    | 0.8   | -         | 1          | -      | ns    | -    |
| t <sub>359b</sub>   | D hold from QCLK (positive edge)                         | 1.6   | -         | 2          | -      | ns    | -    |

Table 155: Timing Parameters for MPC860 Interface (Continued)

|                   |                                        | Frequency/Temperature Options |        |      | ptions |       |      |
|-------------------|----------------------------------------|-------------------------------|--------|------|--------|-------|------|
| <b>_</b>          | Timing                                 |                               | c/50lx | 40Cx |        |       |      |
| Parameter         | Description                            | Min                           | Max    | Min  | Max    | Units | Note |
| t <sub>359c</sub> | SDACK_ hold from QCLK (positive edge)  | 0                             | -      | 0    | -      | ns    | -    |
| t <sub>359d</sub> | TA_ hold from QCLK (positive edge)     | 0.7                           | -      | 0.8  | -      | ns    | -    |
| t <sub>359e</sub> | TEA_ hold from QCLK (positive edge)    | 0                             | -      | 0    | -      | ns    | -    |
| t <sub>359f</sub> | TRETRY_ hold from QCLK (positive edge) | 0                             | -      | 0    | -      | ns    | -    |
| t <sub>359g</sub> | TS_ hold from QCLK (positive edge)     | 0.2                           | -      | 0.2  | -      | ns    | -    |
| t <sub>360</sub>  | TC setup to QCLK (positive edge)       | 5.0                           | -      | 7.1  | -      | -     | -    |
| t <sub>361</sub>  | TC hold from QCLK (positive edge)      | 0.4                           | -      | 0.4  | -      | -     | -    |

Table 155: Timing Parameters for MPC860 Interface (Continued)

1. Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 50 pF.

2. Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 35 pF.3. QSpan II's DP[3:0] signals have the same timing as the data bus (D[31:0]).

 Table 156: Timing Parameters for M68040 Interface

| Time                |                                           | 40  | Cx   |       |      |
|---------------------|-------------------------------------------|-----|------|-------|------|
| Timing<br>Parameter | Description                               | Min | Max  | Units | Note |
| t <sub>400</sub>    | QCLK Frequency                            | -   | 40   | MHz   | -    |
| t <sub>401</sub>    | Period                                    | 25  | -    | ns    | -    |
| t <sub>402</sub>    | Clock Pulse Width (Low)                   | 12  | -    | ns    | 3    |
| t <sub>404</sub>    | Clock Pulse Width (High)                  | 10  | -    | ns    | 3    |
| t <sub>405</sub>    | Clock Rise Time (t <sub>r</sub> )         | -   | 3    | ns    | -    |
| t <sub>406</sub>    | Clock Fall Time (t <sub>f</sub> )         | -   | 3    | ns    | -    |
| t <sub>409a</sub>   | TA_ tristated from QCLK (negative edge)   | -   | 11.4 | ns    | -    |
| t <sub>409b</sub>   | TEA_, tristated from QCLK (negative edge) | -   | 10.4 | ns    | -    |
| t <sub>410a</sub>   | A asserted from QCLK (positive edge)      | -   | 10.7 | ns    | 1    |
| t <sub>410b</sub>   | BB_ asserted from QCLK (positive edge)    | -   | 9.8  | ns    | 1    |
| t <sub>410c</sub>   | R/W_asserted from QCLK (positive edge)    | -   | 8.9  | ns    | 1    |
| t <sub>410d</sub>   | SIZ asserted from QCLK (positive edge)    | -   | 8.8  | ns    | 1    |

| <b>_</b>            |                                                   | 40  | Cx   |       |      |
|---------------------|---------------------------------------------------|-----|------|-------|------|
| Timing<br>Parameter | Description                                       | Min | Мах  | Units | Note |
| t <sub>410e</sub>   | TA_ asserted from QCLK (positive edge)            | -   | 11.4 | ns    | 1    |
| t <sub>410f</sub>   | TC asserted from QCLK (positive edge)             | -   | 9.3  | ns    | 1    |
| t <sub>410g</sub>   | TEA_ asserted from QCLK (positive edge)           | -   | 11.9 | ns    | 1    |
| t <sub>410h</sub>   | BURST_/TIP_ asserted from QCLK (positive edge)    | -   | 9.6  | ns    | 1    |
| t <sub>410i</sub>   | TS_asserted from QCLK (positive edge)             | -   | 9.4  | ns    | 1    |
| t <sub>411</sub>    | BR_ asserted from QCLK (positive edge)            | 3.6 | 8.2  | ns    | 2    |
| t <sub>412a</sub>   | BB_ tristated from QCLK (negative edge)           | -   | 10.2 | ns    | -    |
| t <sub>412b</sub>   | TS_tristated from QCLK (negative edge)            | -   | 9.6  | ns    | -    |
| t <sub>413a</sub>   | BB_ setup to QCLK (positive edge)                 | 5.8 | -    | ns    | -    |
| t <sub>413b</sub>   | BG_ setup to QCLK (positive edge)                 | 6.0 | -    | ns    | -    |
| t <sub>413c</sub>   | D setup to QCLK (positive edge)                   | 7.7 | -    | ns    | -    |
| t <sub>413d</sub>   | IMSEL setup to QCLK (positive edge)               | 5.0 | -    | ns    | -    |
| t <sub>413e</sub>   | TA_ setup to QCLK (positive edge)                 | 7.0 | -    | ns    | -    |
| t <sub>413f</sub>   | TEA_ setup to QCLK (positive edge)                | 7.6 | -    | ns    | -    |
| t <sub>413g</sub>   | BURST_/TIP_ setup to QCLK (positive edge)         | 5.6 | -    | ns    | -    |
| t <sub>414</sub>    | D valid from QCLK (positive edge) (master writes) | 4.3 | 10.9 | ns    | 1    |
| t <sub>415a</sub>   | A hold from QCLK (positive edge)                  | 0.8 | -    | ns    | -    |
| t <sub>415b</sub>   | BB_ hold from QCLK (positive edge)                | 0   | -    | ns    | -    |
| t <sub>415c</sub>   | BG_ hold from QCLK (positive edge)                | 0   | -    | ns    | -    |
| t <sub>415d</sub>   | BURST_/TIP_ hold from QCLK (positive edge)        | 0.6 | -    | ns    | -    |
| t <sub>415e</sub>   | CSPCI_ hold from QCLK (positive edge)             | 0.5 | -    | ns    | -    |
| t <sub>415f</sub>   | CSREG_ hold from QCLK (positive edge)             | 0.6 | -    | ns    | -    |
| t <sub>415g</sub>   | D hold from QCLK (positive edge)                  | 2.0 | -    | ns    | -    |
| t <sub>415h</sub>   | IMSEL hold from QCLK (positive edge)              | 0.0 | -    | ns    | -    |
| t <sub>415i</sub>   | R/W_ hold from QCLK (positive edge)               | 0.7 | -    | ns    | -    |
| t <sub>415j</sub>   | SIZ hold from QCLK (positive edge)                | 1.1 | -    | ns    | -    |
| t <sub>415k</sub>   | TA_ hold from QCLK (positive edge)                | 0.2 | -    | ns    | -    |
| t <sub>415l</sub>   | TC hold from QCLK (positive edge)                 | 2.2 | -    | ns    | -    |

Table 156: Timing Parameters for M68040 Interface (Continued)

| <b></b>             |                                                 | 40  | Cx   |       |      |
|---------------------|-------------------------------------------------|-----|------|-------|------|
| Timing<br>Parameter | Description                                     | Min | Мах  | Units | Note |
| t <sub>415m</sub>   | TEA_ hold from QCLK (positive edge)             | 0.4 | -    | ns    | -    |
| t <sub>415n</sub>   | TRETRY_ hold from QCLK (positive edge)          | 0.3 | -    | ns    | -    |
| t <sub>4150</sub>   | TS_ hold from QCLK (positive edge)              | 0.8 | -    | ns    | -    |
| t <sub>416</sub>    | D tristated from QCLK (positive edge)           | 4.3 | 15.2 | ns    | -    |
| t <sub>417</sub>    | D valid from QCLK (positive edge) (slave reads) | -   | 12.2 | ns    | 1    |
| t <sub>418</sub>    | D hold from QCLK (positive edge)                | 3.9 | -    | ns    | -    |
| t <sub>419a</sub>   | A setup to QCLK (positive edge)                 | 6.8 | -    | ns    | -    |
| t <sub>419b</sub>   | CSPCI_ setup to QCLK (positive edge)            | 4.4 | -    | ns    | -    |
| t <sub>419c</sub>   | CSREG_ setup to QCLK (positive edge)            | 6.8 | -    | ns    | -    |
| t <sub>419d</sub>   | R/W_ setup to QCLK (positive edge)              | 4.6 | -    | ns    | -    |
| t <sub>419e</sub>   | SIZ setup to QCLK (positive edge)               | 6.3 | -    | ns    | -    |
| t <sub>419f</sub>   | TC setup to QCLK (positive edge)                | 6.4 | -    | ns    | -    |
| t <sub>419g</sub>   | TS_setup to QCLK (positive edge)                | 4.7 | -    | ns    | -    |
| t <sub>436a</sub>   | A negated from QCLK (positive edge)             | -   | 10.7 | ns    | 1    |
| t <sub>436b</sub>   | BB_ negated from QCLK (positive edge)           | -   | 7.8  | ns    | 1    |
| t <sub>436c</sub>   | R/W_ negated from QCLK (positive edge)          | -   | 8.8  | ns    | 1    |
| t <sub>436d</sub>   | SIZ negated from QCLK (positive edge)           | -   | 7.8  | ns    | 1    |
| t <sub>436e</sub>   | TA_ negated from QCLK (positive edge)           | 4.3 | 11.4 | ns    | 1    |
| t <sub>436f</sub>   | TC negated from QCLK (positive edge)            | -   | 9.3  | ns    | 1    |
| t <sub>436g</sub>   | TEA_ negated from QCLK (positive edge)          | 4.1 | 11.3 | ns    | 1    |
| t <sub>436h</sub>   | BURST_/TIP_ negated from QCLK (positive edge)   | -   | 9.9  | ns    | 1    |
| t <sub>436i</sub>   | TS_ negated from QCLK (positive edge)           | -   | 7.9  | ns    | 1    |

Table 156: Timing Parameters for M68040 Interface (Continued)

1. Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 50 pF.

Minimum output hold time specified for load of 10 pF. Maximum output delay specified for load of 35 pF.
 Measured at 1.5 volts.

| Timina              |                                           | 3.  | 3V   |       |      |
|---------------------|-------------------------------------------|-----|------|-------|------|
| Timing<br>Parameter | Description                               | Min | Max  | Units | Note |
| t <sub>001</sub>    | RST# asserted to RESETO_ asserted         | -   | 10.8 | ns    | -    |
| t <sub>002</sub>    | RST# negated to RESETO_ tristated         | -   | 10.8 | ns    | -    |
| t <sub>003</sub>    | RESETO_ asserted from PCLK (rising edge)  | -   | 10.1 | ns    | -    |
| t <sub>004</sub>    | RESETO_ tristated from PCLK (rising edge) | -   | 10.1 | ns    | -    |
| t <sub>005</sub>    | QINT_ asserted from PCLK (rising edge)    | -   | 10.7 | ns    | -    |
| t <sub>006</sub>    | QINT_ tristated from PCLK (rising edge)   | -   | 10.7 | ns    | -    |

Table 157: Timing Parameters for Interrupts and Resets

# Table 158: Timing Parameters for Reset Options

| <b>-</b>            |                                                  | All Parts |     |       |      |
|---------------------|--------------------------------------------------|-----------|-----|-------|------|
| Timing<br>Parameter | Description                                      | Min       | Max | Units | Note |
| t <sub>007</sub>    | SIZ[1] setup to RESETI_ or RST# (rising edge)    | 1         | -   | ns    | 1    |
| t <sub>008</sub>    | TMODE[1] setup to RESETI_ or RST# (rising edge)  | 2.5       | -   | ns    | 1    |
| t <sub>009</sub>    | TMODE[0] setup to RESETI_ or RST# (rising edge)  | 2.5       | -   | ns    | 1    |
| t <sub>010</sub>    | BDIP_setup to RESETI_ or RST# (rising edge)      | 2.0       | -   | ns    | 1    |
| t <sub>011</sub>    | BM_EN setup to RESETI_ or RST# (rising edge)     | 1.5       | -   | ns    | 1    |
| t <sub>012</sub>    | SDA setup to RESETI_ or RST# (rising edge)       | 2.25      | -   | ns    | 1    |
| t <sub>013</sub>    | SIZ[1] hold from RESETI_ or RST# (rising edge)   | 1.75      | -   | ns    | 1    |
| t <sub>014</sub>    | TMODE[1] hold from RESETI_ or RST# (rising edge) | 2.75      | -   | ns    | 1    |
| t <sub>015</sub>    | TMODE[0] hold from RESETI_ or RST# (rising edge) | 2.75      | -   | ns    | 1    |
| t <sub>016</sub>    | BDIP hold from RESETI or RST# (rising edge)      | 2.0       | -   | ns    | 1    |
| t <sub>017</sub>    | BM_EN hold from RESETI_ or RST# (rising edge)    | 1.5       | -   | ns    | 1    |
| t <sub>018</sub>    | SDA hold from RESETI_ or RST# (rising edge)      | 2.75      | -   | ns    | 1    |
| t <sub>019a</sub>   | RST# or RESETI_ pulse width (asserted) @ 25MHz   | 40        | -   | ns    | -    |
| t <sub>019b</sub>   | RST# or RESETI_ pulse width (asserted) @ 33MHz   | 30        | -   | ns    | -    |
| t <sub>019c</sub>   | RST# or RESETI_ pulse width (asserted) @ 50MHz   | 20        | -   | ns    | -    |
| t <sub>020</sub>    | ENID setup to RESETI_ or RST# (rising edge)      | 2.5       | -   | ns    | -    |
| t <sub>021</sub>    | ENID hold from RESETI_ or RST# (rising edge)     | 2.75      | -   | ns    | -    |
| t <sub>022</sub>    | PCI_DIS setup to RESETI_ or RST# (rising edge)   | 2.5       | -   | ns    | -    |

| Timing           |                                                    | All F | Parts |       |      |
|------------------|----------------------------------------------------|-------|-------|-------|------|
| Parameter        | Description                                        | Min   | Max   | Units | Note |
| t <sub>023</sub> | PCI_DIS hold from RESETI_ or RST# (rising edge)    | 2.75  | -     | ns    | -    |
| t <sub>024</sub> | PCI_ARB_EN setup to RESETI_ or RST# (rising edge)  |       | -     | ns    | -    |
| t <sub>025</sub> | PCI_ARB_EN hold from RESETI_ or RST# (rising edge) | 2.75  | -     | ns    | -    |

1. These setup and hold times also apply to the falling edge of HS\_HEALTHY\_.

# **B.3** Wait State Insertion — QBus Slave Module



The following wait-state list does not apply to IDMA transfers.

QSpan II as QBus slave inserts wait states as follows:

- One wait state for all retried cycles
- One wait state for burst writes
- One wait states for single posted writes
- Two wait states for complete delayed reads and writes
- One wait state for complete delayed burst reads

See the following section for register accesses.

When the QBus processor is accessing the QSpan II's registers, the maximum number of retries the QSpan II asserts is two. The minimum response time for successful (non-retried) QBus accesses from TS\_ (or AS\_) asserted to TA\_ (or DSACKx\_) asserted is three QCLKs (including two wait states) for reads, and six for writes.

Use Figure 24 when reading the timing diagrams in this Appendix.

# B.4Timing DiagramsB.4.1QBus Interface — MC68360

#### Figure 25: QCLK Input Timing — MC68360 CLKO1



The timing parameters t005 and t006 are measured between 0.8 and 2 Volts. The timing parameters t005 and t006 can be found in Table 154 on page 307.

# B.4.2 QBus Master Cycles — MC68360



Figure 26: QBus Arbitration — MC68360

This figure depicts timing in the case where the QSpan II requests ownership of the QBus while another QBus master currently owns the bus (BB\_/BGACK\_ asserted by the other master). QSpan II obtains ownership of the bus after the other master negates BB\_/BGACK\_.



Figure 27: Single Read — QSpan II as MC68360 Master

Wait states are not required by the QSpan II.



Figure 28: Single Write — QSpan II as MC68360 Master

Wait states are not required by the QSpan II.

# B.4.2.1 QBus Slave Cycles — MC68360

|                 | 0ns   100ns   200           | ins                | 300ns [400ns        |
|-----------------|-----------------------------|--------------------|---------------------|
| l               |                             | 1 1 1 1            |                     |
| QCLK /          |                             |                    |                     |
|                 | t219c                       | ⇒   <del>•</del> t | 220c                |
| CSPCI_          |                             |                    |                     |
| IMSEL           | -⊷ <mark>⊲</mark> t219e     |                    | t220e               |
| _               | <b>⊲</b> ► t219a            | * *                | 1220a               |
| A[31:0]         |                             |                    |                     |
| <b>TO</b> (0.01 | -► <mark>-</mark> - + t219h | ►   <              | 1220h               |
| TC[3:0]         |                             |                    |                     |
| SIZ[1:0]        | ->                          |                    | t220g               |
|                 | <b>→</b> t213               |                    | → t214              |
| D[31:0]         |                             |                    |                     |
| R/W_            | -► <= t219f                 | -► t220            | xf  ←               |
| FV/VV_          | -> <del>&lt;</del> t219b    |                    | 1220b               |
| AS_             |                             | ▶ ►                |                     |
|                 |                             |                    | . <b>►</b> t212a    |
| SACK0_a         |                             | 210c               | - 1236c             |
| <u>a</u>        | <u> </u>                    |                    | → t212a             |
|                 |                             | 210c               | → t212a<br>→ t236c  |
| SACK1_a         |                             |                    |                     |
| $BERR_a$        |                             |                    |                     |
| HALT_a          |                             |                    |                     |
|                 |                             | a. Normal          |                     |
|                 |                             | 210c               | + t212a<br>-▶ t236c |
| SACK0_b         |                             |                    |                     |
|                 |                             | 210c               | → t212a<br>→ t236c  |
| SACK1_b         |                             | 100                |                     |
|                 |                             |                    | → t212b             |
| BERR_b          |                             | 210b               | + t236b             |
| _0              |                             |                    | → t212c<br>→ t236d  |
| HALT_b          |                             | 210d               | - 1236d             |
| IIALI_b         |                             |                    |                     |
|                 |                             | b. Retry           | 12120               |
|                 |                             | 210c               | + t212a<br>+ t236c  |
| SACK0_c         |                             |                    |                     |
|                 |                             | 210c               | → t212a<br>→ t236c  |
| SACK1 c         |                             |                    |                     |
| ononit_c        |                             |                    | ► t212b             |
| onont_c         |                             | 2106               | +226h               |
| BERR_c          | _ <b>→</b>  t               | 210b               | + 1236b             |

#### Figure 29: Delayed Single Read — QSpan II as MC68360 Slave



Figure 30: Single Write — QSpan II as MC68360 Slave

QSpan II PCI-to-Motorola Processor Bridge Manual 8091862.MA001.06



Figure 31: Register Read — QSpan II as MC68360 Slave



Figure 32: Register Write — QSpan II as MC68360 Slave

# B.4.2.2 QBus IDMA Cycles — MC68360

## Figure 33: MC68360 DREQ\_ Timing



#### Table 159: Direction<sup>a</sup> of QBus Signals During MC68360 IDMA Cycles

|                      | Single Address          |                    | Dual Address            |                    |
|----------------------|-------------------------|--------------------|-------------------------|--------------------|
| Signal               | Standard<br>Termination | Fast Termination   | Standard<br>Termination | Fast Termination   |
| CSPCI_               | l<br>(negated)          | l<br>(negated)     | l<br>(asserted)         | l<br>(asserted)    |
| AS_                  | I                       | I                  | I                       | I                  |
| D                    | I (write)/O (read)      | I (write)/O (read) | I (write)/O (read)      | I (write)/O (read) |
| DACK_                | I                       | I                  | I                       | I                  |
| DONE_                | I                       | I                  | I                       | I                  |
| DREQ_                | 0                       | 0                  | 0                       | 0                  |
| DSACK0_ <sup>b</sup> | I                       | N/A                | 0                       | N/A                |
| DSACK1_              | I                       | N/A                | 0                       | N/A                |
| BERR_                | I                       | N/A                | N/A                     | N/A                |
| HALT_                | I                       | N/A                | N/A                     | N/A                |

a. I = Input; O = Output; N/A = Not Applicable.

b. DSACK0\_ is not applicable to IDMA transfers when the QBus is a 16-bit port.

## Terminology

*Standard termination* is used in the following figures in contrast to *fast termination*. *Normal termination* as opposed to *abnormal terminations*, such as bus errors and retries. Thus, some standard terminations are abnormal terminations (for example, bus errors with non-fast termination).



Figure 34: MC68360 IDMA Read — Single Address, Standard Terminations

A[31:0] is depicted for completeness. It is not examined by the QSpan II during IDMA transfers; however, it can be used to drive CSPCI\_. If the Port16 bit of IDMA\_CS is disabled, DSACK0\_ is not asserted. CSPCI\_ is negated during single address IDMA cycles.



Figure 35: MC68360 IDMA Write — Single Address, Standard Terminations



Figure 36: MC68360 IDMA Read — Single Address, Fast Termination

During IDMA fast termination cycles the maximum MC68360 QCLK frequency is 30 MHz.



Figure 37: MC68360 IDMA Write — Single Address, Fast Termination



Figure 38: MC68360 IDMA Read — Dual Address, Standard Termination

QSpan II does not issue retries or bus errors during dual address IDMA cycles.



Figure 39: MC68360 IDMA Write — Dual Address, Standard Termination



Figure 40: MC68360 IDMA Read — Dual Address, Fast Termination

During IDMA fast termination cycles the maximum MC68360 QCLK frequency is 30 MHz.



Figure 41: MC68360 IDMA Read — Dual Address, Fast Termination

# B.4.3QBus Interface — MPC860B.4.3.1QBus Master Cycles — MPC860

## Figure 42: QBus Arbitration — MPC860



This figure depicts timing in the case where the QSpan II requests ownership of the QBus while another QBus master currently owns the bus (BB\_/BGACK\_ asserted by the other master). QSpan II obtains ownership of the bus after the other master negates BB\_/BGACK\_.



Figure 43: Single Read — QSpan II as MPC860 Master



Figure 44: Single Write — QSpan II as MPC860 Master







Figure 46: Aligned Burst Write — QSpan II as MPC860 Master

# B.4.3.2 QBus Slave Cycle — MPC860







Figure 48: Single Write — QSpan II as MPC860 Slave



Figure 49: Burst Read — QSpan II as MPC860 Slave



Figure 50: Burst Write — QSpan II as MPC860 Slave

A minimum of one wait state is inserted if starting address is not aligned to a 16-byte boundary.



Figure 51: Register Read — QSpan II as MPC860 Slave



Figure 52: Register Write — QSpan II as MPC860 Slave

Due to internal synchronization, the number of wait states may vary.

# B.4.3.3 QBus IDMA Cycles — MPC860

## Figure 53: MPC860 DREQ\_ Timing



## Table 160: Direction<sup>a</sup> of QBus Signals During MPC860 IDMA Cycles

| Signal             | Single Address         | Dual Address           |
|--------------------|------------------------|------------------------|
| CSPCI_             | l<br>(negated)         | l<br>(asserted)        |
| TC_[3:0]           | N/A                    | I                      |
| TS_                | I                      | I                      |
| D                  | l (write)/<br>O (read) | l (write)/<br>O (read) |
| SDACK_             | I                      | I                      |
| DONE_ <sup>b</sup> | N/A                    | N/A                    |
| DREQ_              | 0                      | 0                      |
| TA_                | I                      | 0                      |
| TEA_               | I                      | N/A                    |
| TRETRY_            | Ι                      | N/A                    |

a. I = Input; O = Output; N/A = Not Applicable.

b. QSpan II ignores DONE\_ during MPC860 IDMA cycles



Figure 54: MPC860 IDMA Read — Single Address

A[31:0] is depicted for completeness. It is not examined by the QSpan II during IDMA transfer; however, it can be used to drive CSPCI\_.



Figure 55: MPC860 IDMA Write — Single Address

A[31:0] is depicted for completeness. It is not examined by the QSpan II during IDMA transfers; however, it can be used to drive CSPCI\_.



## Figure 56: MPC860 IDMA Read — Dual Address

A[31:0] is depicted for completeness. It is not examined by the QSpan II during IDMA transfers; however, it can be used to drive CSPCI\_.



Figure 57: MPC860 IDMA Write — Dual Address

QSpan II does not issue retries or bus errors during dual address IDMA cycles

# B.4.4 QBus Interface — M68040





The timing parameters t405 and t406 are measured between 0.8 and 2 Volts. The timing parameters t405 and t406 can be found in Table B.4

## B.4.4.1 QBus Master Cycles — M68040



This figure depicts timing in the case where the QSpan II requests ownership of the QBus while another QBus master currently owns the bus (BB\_/BGACK\_ asserted by the other master). QSpan II obtains ownership of the bus after the other master negates BB\_/BGACK\_.

#### Figure 59: QBus Arbitration — M68040



Figure 60: Single Read — QSpan II as M68040 Master



## Figure 61: Single Write — QSpan II as M68040 Master

# B.4.4.2 QBus Slave Cycles — M68040



#### Figure 62: Single Read — QSpan II as M68040 Slave



Figure 63: Single Write — QSpan II as M68040 Slave



Figure 64: Delayed Burst Read — QSpan II as M68040 Slave

Wait states are inserted if the starting address is not aligned to 16-byte boundary.



Figure 65: Posted Burst Write — QSpan II as M68040 Slave

Wait states are be inserted if the starting address is not aligned to 16-byte boundary.



Figure 66: Register Reads — QSpan II as M68040 Slave

b. Retry



Figure 67: Register Write — QSpan II as M68040 Slave

### B.4.5 Interrupts and Resets

#### Figure 68: Reset from PCI Interface — RST# related to RESETO\_





### B.4.6 Reset Options

The parameters for the following figure are in Table 158 on page 319.

#### Figure 74: Reset Options



# **Appendix C: Typical Applications**

This appendix describes how to connect the QSpan II to the following Motorola-based buses: MC68360 (QUICC), MPC860 (PowerQUICC), and M68040. Glue logic is not required for any of these applications.

The following topics are discussed:

- "MC68360 Interface" on page 365
- "MPC860 Interface" on page 371
- "M68040 Interface" on page 378



Tundra supports its customers with Reference Design Kits (RDKs) and Software Design Kits (SDKs). Please check our website at www.tundra.com for the latest downloads and information.

### C.1 MC68360 Interface

This section describes how the QSpan II can be connected to the MC68360 communications controller.

#### C.1.1 Hardware Interface

#### C.1.1.1 Clocking

QSpan II must be clocked by the CLKO1 output from the MC68360 processor. All of the AC timing waveforms for the QSpan II/MC68360 interface are based on CLKO1.



#### Figure 75: MC68360 Interface

#### C.1.1.2 Resets

There are three reset situations depending upon the use of the QSpan II in your application: PCI adapter card bridge, PCI Host bridge, or CompactPCI adapter card supporting Hot Swap.

For a PCI adapter card application, use the following reset configuration: connect the QSpan II's reset output (RESETO\_) to the hard reset input (RESETH\_) on the MC68360. This enables the QSpan II to reset the MC68360 when PCI RST# is asserted, or when the software reset bit is asserted (SW\_RST bit in the MISC\_CTL register on Table 127 on page 280). QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor. HS\_HEALTHY\_ should be left open as it has an internal pull-down resistor.

For a PCI Host bridge application, use the following reset configuration: the QSpan II's PCI RST# (global reset for the QSpan II) input is connected to the hardware reset signal (RESETH\_) on the MC68360. QSpan II's reset output (RESETO\_) can be connected to the PCI RST# inputs of the other PCI devices (the QSpan II's RST# input is not connected to the PCI bus RST# signal). Therefore, at power-up the MC68360's power-on-reset circuitry will assert RESETH\_, which fully resets the QSpan II device. QSpan II will assert RESETO\_ to reset the agents on the PCI bus when RST# is active.

The reset example described in the previous paragraph also allows the MC68360 processor to reset all of the PCI agents under software control. The MC68360 can write to the software reset bit in the QSpan II's MISC\_CTL register, which will cause the QSpan II to assert its RESETO\_ signal. QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor (for more information about resets, see Chapter 14: "Reset Options" on page 159). HS\_HEALTHY\_ should be left open as it has an internal pull-down resistor.

For a CompactPCI adapter card that supports Hot Swap, use the following reset configuration: the QSpan II's HS\_HEALTHY\_ input should be connected to the Hot Swap Controller's HEALTHY\_ output. Also, connect the QSpan II's reset output (RESETO\_) to the hard reset input (RESETH\_) on the MC68360. This enables the QSpan II to reset the MC68360 when PCI RST# is asserted, or when the software reset bit is asserted (SW\_RST bit in the MISC\_CTL register on Table 127 on page 280). QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor.

#### C.1.1.3 Memory Controller

QSpan II requires that two chip selects be generated in order to access the registers (CSREG\_) and the PCI bus (CSPCI\_). This is accomplished by using two of the chip select outputs from the memory controller within the MC68360. There are two QBus slave images in the QSpan II which are used to access the PCI bus. The image that is selected when the PCI chip select is asserted depends upon the state of the Image Select signal (IMSEL). If IMSEL is low then QBus slave image 0 is selected; otherwise, QBus slave image 1 is selected. IMSEL is typically generated directly from one of the high-order address lines on the QBus (for example, dependent on the processor's memory map).

An alternative method is to use a spare I/O port pin on the MC68360 processor to control the QSpan II's IMSEL input pin. When the opposite QBus slave image must to be accessed, the MC68360 will first perform a write to change the state of this I/O port pin.

#### C.1.1.4 QBus Direct Connects

All other QBus interface signals can be directly connected to the appropriate MC68360 signal. External pull-up resistors should be connected to all bus control signals — excluding SIZ[1] and BDIP\_ which are reset options and should be pulled to the desired state — to ensure that they are held in the inactive state. See Figure 75 to determine which signals require external pull-ups.

#### C.1.1.5 Interrupts

QSpan II device can pass interrupts between the PCI bus and the QBus. For host bridging applications, the QSpan II can accept INT# as an input and assert QINT\_ as an output. QSpan II's interrupt output (QINT\_) should be connected to one of the seven possible interrupt inputs (IRQ[7:1]) on the MC68360 processor. When the MC68360 is acknowledging a QSpan II interrupt, it must be programmed to generate the cycle termination. QSpan II is an autovector interrupter and does not have the ability to assert AVEC\_ during the interrupt acknowledge cycle.

For PCI adapter card applications, the QSpan II can accept interrupts from the QBus on the QINT\_ pin and pass them through the QSpan II to its PCI INT# output. See Chapter 8: "The Interrupt Channel" on page 119 for more information about interrupts.

#### C.1.1.6 PCI Signals

QSpan II's PCI signals can be directly connected to the appropriate PCI signal on the motherboard or the PCI connector. Pull-up resistors may be required to be added to the PCI bus control signals depending on the application. If you are designing a local PCI bus on a motherboard then pull-up resistors are required (for more information, see the *PCI 2.2 Specification*).

For host bridging applications, possible implementations for the QSpan II's IDSEL signal include the following:

- connect it to a spare AD signal (AD[31:12])
- connect it to ground through a resistor if the host is not required to respond to PCI configuration cycles

The QSpan II supports both 5V and 3.3V I/O signaling environments.



 $V_{\rm H}$  (Highest I/O voltage) must be connected to the highest voltage level the QSpan II I/Os will observe on either the QBus or the PCI bus.

#### C.1.1.7 EEPROM Interface

A serial EEPROM may be required for applications which must support a Plug and Play environment (for more information about EEPROM reset options, see "Reset Options" on page 369). QSpan II also allows that QBus processor to initialize the QSpan II to support a Plug and Play environment (for more information, see "EEPROM Configuration and Plug and Play Compatibility" on page 129).

### C.1.1.8 Reset Options

A number of reset options exist with the QSpan II device. The following signals are sampled on the rising edge of both RST# and RESETI\_, and the falling edge of HS\_HEALTHY\_ to determine the QSpan II's mode of operation:

- The BDIP\_ signal must be pulled low at reset to enable the QSpan II to perform as an MC68360 master. QSpan II responds to MC68360-style slave cycles independent of the state of the SIZ[1] signal at reset (see Chapter 14: "Reset Options" on page 159).
- The SDA and ENID signals should be pulled high if the EEPROM is used. The SDA signal should be pulled low if the serial EEPROM is not used in this design. The ENID signal can be left open if the serial EEPROM is not used as there is an internal weak pull-down resistor.
- The TMODE[1:0] signals can be left open as there are internal pull-down resistors on these pins within the QSpan II. If an in-circuit tester is used during the board manufacturing process then these two signals should be brought out as test points. This allows the in-circuit tester to place the QSpan II in a tri-state/NAND TREE test mode.
- If the BM\_EN/FIFO\_RDY\_ signal is sampled high while RST# is asserted, the QSpan II sets the Bus Master (BM) bit in the PCI\_CS register (see Table 70 on page 207). This enables the QSpan II as a PCI bus master. This pin can be left as a no-connect as there is an internal weak pull-down resistor.
- If the PCI\_ARB\_EN signal is sampled high on the negation of a reset event then the PCI bus arbiter within the QSpan II is enabled. There is an internal pull-down resistor on this pin to maintain backward compatibility.
- If the PCI\_DIS signal is sampled high on the negation of a reset event then the QSpan II's PCI interface is disabled. QSpan II will retry any attempted PCI target accesses until the PCI\_DIS status bit in the MISC\_CTL2 register is cleared (see Table 130 on page 284). There is an internal pull-down resistor on this pin to maintain backward compatibility.

Reset options are described in Chapter 14: "Reset Options" on page 159.

#### C.1.1.9 Unused Inputs Requiring Pull-Ups

The TS\_ and BURST\_/TIP\_ signals are unused inputs when the QSpan II is interfaced with an MC68360, and therefore, must be pulled high.

#### C.1.1.10 No Connects

The BM\_EN/FIFO\_RDY\_ signal can be left as a no-connect as there is an internal weak pull-down resistor. In this case, in order for the QSpan II to become a PCI bus master a write to the PCI\_CS register is required.

#### C.1.1.11 JTAG Signals

QSpan II supports JTAG. QSpan II's JTAG signals should be connected to the JTAG controller or to the JTAG signals of another device if devices are to be chained together. If JTAG will not be supported then the JTAG signals can be left open as the inputs have internal pull-up resistors.

#### C.1.1.12 Address Multiplexing for DRAM

If DRAM is used on the QBus, external address multiplexing is required. This is described in *Motorola's MC68360 User Manual*.

#### C.1.2 Software Issues

When using the MC68360 with the QSpan II there are register bits which must be altered from the MC68360's default reset state. The register bits should be set as follows:

- Set the Bus Synchronous Timing Mode (BSTM) bit to 1 in the MCR register because the QSpan II is a synchronous bus master.
- Set the Arbitration Synchronous Timing Mode (ASTM) bit to 0 in the MCR register because the QSpan II is not able to meet the MC68360's set-up requirements.



Setting the S\_BG and S\_BB bits to 1 was a requirement for the QSpan (CA91C860B, CA91L860B) devices. This setting is not required for the QSpan II. However, setting these bits to a 1 will save one clock cycle. If both these bits are set to 1, the QSpan II will synchronously sample the MC68360's arbitration outputs, and the MC68360 will asynchronously sample the QSpan II's arbitration outputs.

### C.1.3 MC68360 Slave Mode Interface

If the MC68360 operates in Slave mode — its processor core is disabled — an external QBus arbiter must be used to support arbitration between the MC68360 and the QSpan II. QSpan II's arbitration interface does not support the use of the MC68360's internal bus arbiter when the processing core is disabled. If the processing core is disabled, the external arbiter receives bus requests (BR) from both the MC68360 and QSpan II, and then issues bus grants (BG) back to the appropriate device.

If the MC68360 operates in Slave mode, set the MC68360's SYNC bit to 0 in the GMR register.

# C.2 MPC860 Interface

This section describes how the QSpan II can be connected to the MPC860 communications controller (and other MPC8xx devices).

#### Figure 76: MPC860 Interface



### C.2.1 Hardware Interface

### C.2.1.1 Clocking

The QSpan II's QCLK input must be derived from the MPC860's CLKOUT signal. All of the AC timing waveforms for the QSpan II are based on this clock output. It is recommended, however, to buffer the CLKOUT signal to the QSpan II with a low skew PLL-based clock buffer because of the low drive strength of the CLKOUT signal.



If an external PLL clock buffer generates the QSpan II's QCLK input, care must be taken to ensure the QSpan II's set-up and hold times are not violated while the PLL clock buffer is locking.

### Clocking the QSpan's QCLK Input with a PLL Clock Buffer Chip

QSpan II does not tolerate external bus cycles occurring on the QBus when it does not have a stable clock input.

In the MPC860/QSpan II application shown in Figure 77, the QSpan II may not respond to a register or PCI access if MPC860 bus cycles are occurring when the QSpan II does not have a stable clock.

In this example, the XTAL clock input to the MPC860 is only 4 MHz. The MPC860's PLPRCR register can be written to increase the clock's frequency. When the frequency is increased the MPC860 will stop generating a CLKOUT signal for a period of time while the PLL is locking to this higher frequency. The MPC860 will then continue executing instructions once the CLKOUT signal is stable at this higher frequency. However, the QSpan II will not yet have a stable QCLK input due to the PLL locking requirement of the external PLL Clock buffer chip — the PLL locking time is dependent on the selected clock buffer chip but is typically around 1 ms. During this period while the external PLL is locking, the MPC860 must not perform any cycles on the bus or the QSpan II will not respond to the next register or PCI access.

#### Figure 77: MPC860/QSpan II Clocking Scheme Example



This issue can be eliminated by having the MPC860 execute a delay loop from its instruction cache during this time period. This will prevent the MPC860 from asserting the cycle on the external bus (that is, TS\_ will not be asserted). An example of how this code could be implemented is in Figure 78.

#### Figure 78: Example Code for Executing an MPC860 Delay Loop

```
# R4 Contains IMMR value
      bl icache_unlock_all
                                   # ICache Unlock All
      bl icache_invalidate_all # ICache Invalidate All
      bl icache enable
                               # ICache Enable
# prefetch wait_delay subroutine into instruction cache
      li r1, 0x1
                               # set delay counter for wait_delay subroutine
      bl wait_delay
      li r5,0xA0
                               # multiply factor from 4MHZ
      b aligned
.align 4
                               # align address to 16-bytes boundary
aligned:
      sth r5,PLPRCR(r4)
                               # set the PLL register
      isync
# delay allows for QSpan II to receive a stable QCLK before external bus
cycles begin
# the actual delay value required is dependent on the PLL clock buffer
device's locking time
      li r1, 0x7FFF
                              # set delay counter for wait delay subroutine
      bl wait_delay
# Simple delay routine, (R1 delay counter input parameter)
wait delay:
      #
      # execute required delay with R1 parameter
      #
      blr
```

#### C.2.1.2 Resets

There are three reset scenarios depending on the use of the QSpan II in your application: PCI adapter card bridge, PCI Host bridge, or CompactPCI adapter card supporting Hot Swap.

For a PCI adapter card application use the following reset configuration: connect the QSpan II's reset output (RESETO\_) to the hard reset input (RESETH\_) on the MPC860. This enables the QSpan II to reset the MPC860 when PCI RST# is asserted or when the software reset bit is asserted (SW\_RST bit in the MISC\_CTL register on Table 127 on page 280). QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor. HS\_HEALTHY\_ should be left open as it has an internal pull-down resistor.

For a PCI Host bridge application use the following reset configuration: the QSpan II's PCI RST# (global reset for the QSpan II) input is connected to the hardware reset (RESETH\_) on the MPC860. QSpan II's reset output (RESETO\_) can be connected to the PCI RST# inputs of the other PCI devices (the QSpan II's RST# input is not connected to the PCI bus RST# signal). Therefore, at power-up the MPC860's power-on-reset circuitry will assert RESETH\_ which fully resets the QSpan II. QSpan II will, in turn, assert RESETO\_ to reset the agents on the PCI bus when RST# is active.

This reset example also allows the MPC860 processor to reset all of the PCI agents under software control. The MPC860 can write to the software reset bit in the QSpan II's MISC\_CTL register, which will cause the QSpan II to assert its RESETO\_ signal. QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor. Resets are described in Chapter 14: "Reset Options" on page 159. HS\_HEALTHY\_ should be left open as it has an internal pull-down resistor.

For a CompactPCI adapter card that supports Hot Swap, use the following reset configuration: the QSpan II's HS\_HEALTHY\_ input should be connected to the Hot Swap Controller's HEALTHY\_ output. Also, connect the QSpan II's reset output (RESETO\_) to the hard reset input (RESETH\_) on the MPC860. This enables the QSpan II to reset the MPC860 when PCI RST# is asserted, or when the software reset bit is asserted (SW\_RST bit in the MISC\_CTL register on Table 127 on page 280). QSpan II's reset input (RESETI\_) is typically unused and should be pulled high through a resistor.

#### C.2.1.3 Memory Controller

QSpan II requires that two chip selects be generated in order to access the registers (CSREG\_) and the PCI bus (CSPCI\_). This can be accomplished by using two of the chip select outputs from the memory controller within the MPC860. There are two QBus slave images within the QSpan II which are used to access the PCI bus. The image that is selected when the PCI chip select is asserted is dependent on the state of the Image Select signal (IMSEL). If IMSEL is low then QBus slave image 0 is selected; otherwise, QBus slave image 1 is selected. IMSEL is typically generated directly from one of the high order address lines on the QBus (for example, dependent on the processor's memory map).

An alternative method is to use a spare I/O port pin on the MPC860 processor to control the QSpan II's IMSEL input pin. If the opposite QBus slave image is desired to be accessed, the MPC860 first performs a write to change the state of this I/O port pin.

#### C.2.1.4 QBus Direct Connects

The bus interface signals can be directly connected together. External pull-up resistors should be connected to all bus control signals — including SIZ[1] and BDIP\_ which are reset options and should be pulled high to support MPC860 mode — to ensure that they are held in the inactive state (see Figure 76 to determine which signals require external pull-ups).

### C.2.1.5 Interrupts

QSpan II can pass interrupts between the PCI bus and the QBus. For host bridging applications, the QSpan II can accept INT# as an input and assert QINT\_ as an output. QSpan II's interrupt output QINT\_) should be connected to one of the seven possible interrupt inputs (IRQ[7:1]) on the MPC860 processor.

For PCI adapter card applications, the QSpan II can accept interrupts from the QBus on the QINT\_ pin and pass them through the QSpan II to its PCI INT# output. Interrupts are described in Chapter 8: "The Interrupt Channel" on page 119.

### C.2.1.6 PCI Signals

QSpan II's PCI signals can be directly connected to the appropriate PCI signal on the motherboard or the PCI connector. Pull-up resistors may be required to be added to the PCI bus control signals depending on the application. If you are designing a local PCI bus on a motherboard then pull-up resistors will be required (for more information, see the *PCI Specification 2.2*).

For host bridging applications, possible implementations for the QSpan II's IDSEL signal are as follows:

- connect it to a spare AD signal (AD[31:12])
- connect it to ground through a resistor if the host is not required to respond to PCI configuration cycles

The QSpan II supports both 5V and 3.3V I/O signaling environments.



 $V_{\rm H}$  (Highest I/O voltage) must be connected to the highest voltage level the QSpan II I/Os will observe on either the QBus or the PCI bus.

### C.2.1.7 EEPROM Interface

A serial EEPROM may be required for applications which must support a Plug and Play environment (for more information about EEPROM reset options see "Reset Options" on page 369). QSpan II also allows that QBus processor to initialize the QSpan II to support a Plug and Play environment (for more information, see "EEPROM Configuration and Plug and Play Compatibility" on page 129).

#### C.2.1.8 Reset Options

A number of reset options exist with the QSpan II device. The following signals are sampled on the rising edge of both RST# and RESETI\_ and the falling edge of HS\_HEALTHY\_ to determine the QSpan II's mode of operation:

- The BDIP\_ and SIZ[1] signals must be pulled high at reset to enable the QSpan II to perform as an MPC860 master and slave (see Chapter 14: "Reset Options" on page 159).
- The SDA and ENID signals should be pulled high if the EEPROM is used. The SDA signal should be pulled low if the serial EEPROM is not used in this design. The ENID signal can be left open if the serial EEPROM is not used as there is an internal weak pull-down resistor.

- The TMODE[1:0] signals can be left open as there are internal pull-down resistors on these pins within the QSpan II. If an in-circuit tester is used during the board manufacturing process then these two signals should be brought out as test points. This allows the in-circuit tester to place the QSpan II in a tri-state/NAND TREE test mode.
- If the BM\_EN/FIFO\_RDY\_ signal is sampled high while RST# is asserted, the QSpan II sets the Bus Master (BM) bit in the PCI\_CS register (see Table 70 on page 207). This enables the QSpan II as a PCI bus master. This pin can be left as a no-connect as there is an internal weak pull-down resistor.
- If the PCI\_ARB\_EN signal is sampled high on the negation of a reset event then the PCI bus arbiter within the QSpan II is enabled. There is an internal pull-down resistor on this pin to maintain backward compatibility.
- If the PCI\_DIS signal is sampled high on the negation of a reset event then the QSpan II's PCI interface is disabled. QSpan II will retry any attempted PCI target accesses until the PCI\_DIS status bit in the MISC\_CTL2 register is cleared (see Table 130 on page 284). There is an internal pull-down resistor to maintain backward compatibility.

Reset options are described in Chapter 14: "Reset Options" on page 159.

#### C.2.1.9 Unused Inputs Requiring Pull-Ups

The AS\_, DSACK0\_ and DONE\_ signals are unused inputs when the QSpan II is interfaced with an MPC860, and therefore, must be pulled high.

#### C.2.1.10 No Connects

The DS\_ output from the QSpan II should be left as a no connect when the QSpan II is interfaced with an MPC860.

The BM\_EN/FIFO\_RDY\_ can be left as a no-connect as there is an internal weak pull-down resistor. In this case, in order for the QSpan II to become a PCI bus master a write to the PCI\_CS register is required.

#### C.2.1.11 JTAG Signals

QSpan II supports JTAG. QSpan II's JTAG signals should be connected to the JTAG controller or to the JTAG signals of another device if devices are to be chained together. If JTAG will not be supported then the JTAG signals can be left open as the inputs have internal pull-up resistors.

#### C.2.1.12 Bused Signals

This manual adopts the convention that the most significant bit (address, data, size and transaction codes) is always the largest number. When interfacing the MPC860 to the QSpan II, designers must ensure that they connect the signals accordingly (for example, pin A[31] on the QSpan II connects to pin A[0] on the MPC860).

#### C.2.1.13 Address Multiplexing for DRAM

Whenever DRAM is used on the QBus, external address multiplexing is required. This is described in the MPC860 UM/AD (REV1).

#### C.2.1.14 Software Issues

When using the MPC860 with the QSpan II there are a few register bits that must be changed from the MPC860's default reset state. These register bits include the following:

- The MLRC bits in the MPC860's SIUMCR register must be changed to 10 state. This configures the KR/RETRY/IRQ4/SPKROUT pin to function as a RETRY input.
- The SEME bit in the MPC860's SIUMCR register must be set to a 1 because the QSpan II is a synchronous external master.
- The SETA bit in the MPC860's Option register must be set to a 1 for the two QSpan II chip selects (CSREG\_ and CSPCI\_). QSpan II will always provide the cycle termination to the MPC860.
- The BIH bit in the MPC860's Option register must be set to 1 for the QSpan II's register chip select (CSREG\_). QSpan II's PCI chip select (CSPCI\_) pin supports burst accesses when using the MPC860's GPCM. Therefore, the BIH bit can be set to either state. The *MPC860 User's Manual* states that the GPCM machine does not support burst accesses, however, with the QSpan II's architecture it will function correctly for the CSPCI\_ chip select.

## C.3 M68040 Interface

This section describes how the QSpan II can be connected to the M68040.



Figure 79: M68040 Interface

### C.3.1 Hardware Interface



QSpan II is compatible with all M68040 variants in large buffer mode up to 40 MHz. QSpan II is compatible with all M68040 variants in small buffer mode up to 33 MHz.

### C.3.1.1 Clocking

QSpan II's QCLK input and the M68040's BCLK input should be clocked from the same clock source. The AC timing waveforms for the QSpan II are based on this assumption.

### C.3.1.2 Resets

There are three reset scenarios depending on the use of the QSpan II in your application: PCI adapter card bridge, PCI Host bridge, or CompactPCI adapter card supporting Hot Swap.

For a PCI Adapter card application, use the following reset configuration: connect the QSpan II's reset output (RESETO\_) to the external reset logic to the reset input (RSTI\_) on the M68040. This enables the QSpan II to reset the M68040 processor when PCI RST# is asserted, or when the software reset bit is asserted (SW\_RST bit in the MISC\_CTL register on Table 127 on page 280). QSpan II's reset input (RESETI\_) is normally unused and should be pulled high through a resistor.

For a PCI Host bridge application, use the following reset configuration: the QSpan II's PCI RST# (global reset for the QSpan II) input is connected to the reset output (RSTO\_) on the M68040. QSpan II's reset output (RESETO\_) can be connected to the PCI RST# inputs of the other PCI devices (the QSpan II's RST# input is not connected to the PCI bus RST# signal). Therefore, at power-up the M68040's power-on-reset circuitry will assert RSTO\_ which fully resets the QSpan II device. QSpan II will assert RESETO\_ to reset the agents on the PCI bus when RST# is active.

This reset example also allows the M68040 processor to reset all of the PCI agents under software control. The M68040 can write to the software reset bit in the QSpan II's MISC\_CTL register which will cause the QSpan II to assert its RESETO\_ signal. QSpan II's reset input (RESETI\_) is normally unused and should be pulled high through a resistor (for more information about resets, see Chapter 14: "Reset Options" on page 159).

For a CompactPCI adapter card application that supports Hot Swap, the QSpan II's HS\_HEALTHY\_ signal should be connected to the Hot Swap controller's HEALTHY\_ signal.

#### C.3.1.3 Address Decoder

QSpan II requires two chip selects and an image select signal (IMSEL) to be generated in order to access the registers (CSREG\_) and the PCI bus (CSPCI\_). There is no internal memory controller within the M68040 and therefore an external address decoder must be implemented. The IMSEL signal determines which QBus slave image is accessed when CSPCI\_ is asserted to the QSpan II. If IMSEL is low then QBus slave image 0 is selected; otherwise QBus slave image 1 is selected. IMSEL is typically dependent on the processor's memory map and is generated directly from one of the high order address lines.

An alternative method is to use a registered output which resides on the QBus. When the opposite slave image must be accessed, the M68040 would first perform a write to change the state of this registered output.

#### C.3.1.4 QBus Direct Connects

All other bus interface signals can be connected directly together. External pull-up resistors should be connected to all bus control signals — excluding SIZ[1] and BDIP\_ which are power-up options and should be pulled to the desired state — to ensure that they are held in the inactive state (see Figure 79 to determine which signals require external pull-ups).

Depending on the version and speed of the M68040 device selected for a design, an extra wait state may need to be inserted on the transfer start signal (TS\_). This may be required because the external address decoding circuitry may not be able to generate the chip selects to the QSpan II to meet the input setup requirements.

An alternate solution is to use large output buffer mode in the M68040 to eliminate the need for this wait state. The M68040's output propagation delays are much quicker in this mode and therefore there is more timing margin available for interfacing the QSpan II. However, if large output buffer mode is chosen, it must be used in an unterminated method as the QSpan II's output drivers do not have the ability to drive a 50 ohm transmission line terminated at 2.5V.

QSpan II has four transaction code TC[3:0] signals which can be connected to any four of the five following signals on the M68040: TT[1:0] and TM[2:0].

#### C.3.1.5 Interrupts

QSpan II device can pass interrupts between the PCI bus and the QBus. For host bridging applications, the QSpan II can accept INT# as an input and assert QINT\_ as an output. QSpan II's interrupt output (QINT\_) should be connected to the interrupt prioritizing logic which is connected to the IPL[2:0] lines on the M68040 processor. When the M68040 is acknowledging a QSpan II interrupt there must be external logic to terminate the cycle. External logic is required because the QSpan II is an autovector interrupter which does not have the ability to assert AVEC\_ or TA\_ during the interrupt acknowledge cycle.

For PCI adapter card applications, the QSpan II can accept interrupts from the QBus on the QINT\_ pin and pass them through the QSpan II to its PCI INT# output (see Chapter 8: "The Interrupt Channel" on page 119 for more information about interrupts).

- If the PCI\_ARB\_EN signal is sampled high on the negation of a reset event then the PCI bus arbiter within the QSpan II is enabled. There is an internal pull-down resistor on this pin to maintain backward compatibility.
- If the PCI\_DIS signal is sampled high on the negation of a reset event then the QSpan II's PCI interface is disabled. QSpan II will retry any attempted PCI target accesses until the PCI\_DIS status bit in the MISC\_CTL2 register is cleared (see Table 130 on page 284). There is an internal pull-down resistor to maintain backward compatibility.

Reset options are described in Chapter 14: "Reset Options" on page 159.

#### C.3.1.9 Unused Inputs Requiring Pull-Ups

The AS\_, DSACK0\_, HALT\_/TRETRY\_, DONE\_ and DACK\_ signals are unused inputs when the QSpan II is interfaced with a M68040 and therefore must be pulled high.

#### C.3.1.10 No Connects

The DS\_ and DREQ\_ outputs from the QSpan II should be left as no connects when the QSpan II is interfaced with a M68040.

The BM\_EN/FIFO\_RDY\_ can be left as a no-connect as there is an internal weak pull-down resistor. In this case, in order for the QSpan II to become a PCI bus master a write to the PCI\_CS register is required.

#### C.3.1.11 JTAG Signals

QSpan II supports JTAG. QSpan II's JTAG signals should be connected to the JTAG controller or to the JTAG signals of another device if devices are to be chained together. If JTAG will not be supported then the JTAG signals can be left open as the inputs have internal pull-up resistors.

# **Appendix D: Software Initialization**

This appendix explains how to initialize the QSpan II. It describes which registers must be configured before you can initiate a transaction through the QSpan II's channels. This appendix also recommends how to set QSpan II's register bits in order to achieve maximum performance.

This appendix discusses the following topics:

- "Miscellaneous Control Register Configuration" on page 384
- "QBus Slave Channel Initialization" on page 386
- "Register Access from the PCI Bus" on page 387
- "PCI Target Channel Initialization" on page 387
- "Error Logging of Posted Transactions" on page 389
- "IDMA/DMA Channel Initialization" on page 390
- "Interrupt Initialization" on page 390
- "Generation of PCI Configuration and IACK Cycles" on page 391
- "EEPROM and VPD Initialization" on page 392
- "I<sub>2</sub>O Messaging Unit Initialization" on page 392
- "PCI Expansion ROM Implementation" on page 393

# D.1 Miscellaneous Control Register Configuration

QSpan II has two general purpose control registers, MISC\_CTL and MISC\_CTL2, which must be configured for the appropriate application (for example, MPC860 (PowerQUICC), MC68360 (QUICC), and M68040 processors). For more information about the control registers, see Tables 161 and 162.

Table 161: Summary of the QSpan II's Miscellaneous Control Register

| Register | Field       | Description                                                                                                                                                                                                                                                                                                                                                          |   |
|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| MISC_CTL | MSTSLV[1:0] | This field determines the types of cycles the QSpan II Slave<br>Module accepts, and the type of cycles the Master Module<br>generates. Read this field to verify that the QSpan II has powered<br>up in the correct mode of operation.                                                                                                                               | ¢ |
|          | QB_BOC      | This bit determines whether the QSpan II generates Little-endian<br>or Big-endian QBus cycles (see also INVEND bit in PCI target<br>and DMA control registers).                                                                                                                                                                                                      |   |
|          | S_BG        | If using the MPC860's arbiter, use default settings.                                                                                                                                                                                                                                                                                                                 |   |
|          | S_BB        | If using the MC68360's arbiter, then these bits may be altered<br>from their default settings (for example, set to 1). This will<br>improve the performance by saving a clock cycle during<br>arbitration.                                                                                                                                                           |   |
|          | SW_RST      | This bit controls the assertion of RESETO Depending on the hardware design, this output can be used to reset the QBus processor.                                                                                                                                                                                                                                     |   |
|          | MA_BE_D     | This bit controls the QSpan II's response to the QBus processor<br>when a Master-Abort occurs on the PCI bus. Set this bit to 1<br>before the QSpan II performs any PCI Configuration cycles.                                                                                                                                                                        |   |
|          | PRCNT       | This field controls the amount of data that is prefetched when a PCI burst read occurs to the QSpan II's PCI Target Channel.<br>If the PCI Initiators perform burst read cycles then prefetching should be enabled to improve the system's performance. For more information, see the PCI Target Channel's control registers in Appendix A: "Registers" on page 199. |   |

QSpan II's MISC\_CTL2 register bits which affect the device's performance or initialization are shown in Table 162.

| Register  | Field         | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MISC_CTL2 | PCI_DIS       | This bit must be cleared before any PCI Target accesses will complete successfully.                                                                                                                                                                                                                                                                                                       |
|           | PTP_IB        | This field allows the PCI Target Channel Prefetch Count to be<br>Image Based. Enable this feature if the PCI Initiators have<br>different PCI bursting requirements.                                                                                                                                                                                                                      |
|           | KEEP_BB       | This bit allows the QSpan II to hold onto the QBus for<br>back-to-back cycles. Setting this bit will improve the performance<br>through the QSpan II, however, it will sometimes increase the<br>latency for the QBus processor to obtain the QBus.<br><b>Note</b> : Do not set this bit when the QSpan II DMA channel is used<br>with the PowerQUICC memory controller (UPM).            |
|           | MAX_RTRY[1:0] | This field can be set to a non-zero value to allow the QBus processor to detect a cycle which has not completed successfully on the PCI bus.                                                                                                                                                                                                                                              |
|           | PTC_PD        | This bit can be set to 1 to allow the QSpan II to signal a PCI disconnect if TRDY# has been negated for more than eight PCI clocks.                                                                                                                                                                                                                                                       |
|           | TA_BE_EN      | Set this bit to 1 so that the QSpan II will signal a bus error to the QBus processor if a PCI Target-Abort occurs.                                                                                                                                                                                                                                                                        |
|           | BURST_4       | Set this bit to 1 to enable the QSpan II to perform burst cycles in MPC860 applications. For MC68360 and M68040 applications, this bit can be left cleared. Used in conjunction with the BRSTWREN bit in the PBTIx_CTL register (see Table 89 on page 228 and Table 92 on page 232).                                                                                                      |
|           | PR_SING       | Set this bit to 1 if the memory on the QBus does not support<br>burst accesses. This bit is only applicable when the QSpan II is<br>configured as an MPC860 QBus master.                                                                                                                                                                                                                  |
|           | PR_CNT2[5:0]  | This field controls the amount of data that is prefetched when a<br>PCI burst read occurs through PCI Target Channel 1 of the<br>QSpan II. If the PCI Initiators perform burst read cycles then<br>prefetching should be enabled to improve the system's<br>performance. For more information about the PCI Target Channel<br>control registers, see Appendix A: "Registers" on page 199. |
|           | REG_AC        | Set this bit to 1 to improve the system's performance if QSpan II register accesses are occurring from both the QBus and PCI bus.                                                                                                                                                                                                                                                         |
|           | NOTO          | Set this bit to 1 to improve the system's performance by disabling<br>the PCI transaction ordering rules between the QBus Slave and<br>PCI Target Channels (see "Transaction Ordering Disable Option"<br>on page 82).                                                                                                                                                                     |
|           | QSC_PW        | Set this bit to 1 to improve the posted write performance in the QBus Slave Channel.                                                                                                                                                                                                                                                                                                      |

| Table 162: Summa | ry of the QSpan | II's Miscellaneous | Control Register 2 |
|------------------|-----------------|--------------------|--------------------|
|------------------|-----------------|--------------------|--------------------|

The PCI Arbiter Control Register (PCI\_ARB) should be initialized if the QSpan II is the PCI Host and its arbiter was enabled at power-up (see the following table).

**Table 163: PCI Arbiter Control Register Summary** 

| Register | Field        | Description                                                                                                              |
|----------|--------------|--------------------------------------------------------------------------------------------------------------------------|
| PARB_CTL | Mx_PRI       | This bit selects low or high priority for each PCI master.                                                               |
|          | QS_PRI       | This bit selects the QSpan II's priority.                                                                                |
|          | PCI_ARB_EN   | Read this status bit to verify whether the QSpan II has powered<br>up with the correct setting for enabling the arbiter. |
|          | PARK         | This bit allows you to park the PCI bus at different masters.                                                            |
|          | BM_PARK[2:0] | 3-bit encoded field to select the master at which to park the bus (see "Bus Parking" on page 148).                       |

## D.2 QBus Slave Channel Initialization

To support two QBus (processor) slave images you must program QBus slave image 0 and 1 registers. Once these registers are programmed, the QBus processor can read and write data from the PCI bus.

#### Table 164: QBus Slave Channel Programming Summary

| Register                       | Field     | Description                                                                                                                                            |
|--------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| QBSI0_CTL<br>and/or            | PWEN      | Set this bit to 1 to allow write transactions to be posted; this will improve system throughput.                                                       |
| QBSI1_CTL                      | PAS       | Sets the PCI bus address space to either Memory or I/O space.<br>Typically, only Memory Space accesses are implemented                                 |
|                                | PREN      | Enables the QSpan II to perform a burst read on the PCI bus. Set<br>this bit if the QBus processor is often reading from consecutive<br>PCI addresses. |
| QBSI0_AT<br>and/or<br>QBSI1_AT | EN        | This bit enables address translation when set to 1.                                                                                                    |
|                                | BS[3:0]   | Block Size of slave image: affects number of address lines translated, if address translation is enabled                                               |
|                                | TA[31:16] | This field allows for independent memory maps to be created for the PCI bus and QBus (EN bit must be set to 1).                                        |
| PCI_CS                         | BM        | This bit must be set before the QSpan II will initiate any transaction on the PCI bus.                                                                 |

# D.3 Register Access from the PCI Bus

QSpan II's PCI Configuration registers are accessible from the PCI Bus in PCI Configuration or Memory Space. QSpan II device specific registers are only accessible in Memory Space. QSpan II's PCI Configuration Registers are accessible without any software initialization requirements. To access the QSpan II device specific registers in PCI Memory Space, configure the bits listed in the following table.

#### Table 165: Register Access

| Register | Field | Description                                                                                                                                                      |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI_CS   | MS    | Set this bit for the QSpan II to be able to respond to PCI Memory space cycles. (This is a global bit, the PAS bit of each specific image also needs to be set.) |
| PCI_BSM  | BA    | Specifies the base address of the PCI memory image for access registers (size of image is 4K)                                                                    |

# D.4 PCI Target Channel Initialization

There are two possible memory ranges on the PCI bus which can be used to gain access to QBus memory. These two ranges and the associated registers which need to be programmed to access them are referred to as "target images." Each PCI target image can have independent features as described in the following table. To support two PCI target images, you must program both PCI Target Image 0 and Image 1 registers.

#### Table 166: PCI Target Image Programming Summary

| Register | Field | Description                                                                                                                                              |  |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PCI_CS   | MS    | Set this bit to allow the QSpan II to respond to PCI Memory space cycles. This is a global bit, the PAS bit of each specific image also needs to be set. |  |
|          | IOS   | Set this bit to allow the QSpan II to respond to PCI I/O space cycles. This is a global bit, the PAS bit of each specific image also needs to be set.    |  |

| Register                                      | Field      | Description                                                                                                                                                                                       |
|-----------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PBTI0_CTL<br>and/or<br>PBTI1_CTL              | EN         | Set this bit to enable the Target image.                                                                                                                                                          |
|                                               | PWEN       | Set this bit to 1 to allow write transactions to be posted; this improves system throughput.                                                                                                      |
|                                               | PREN       | Set this bit if the PCI Initiator is attempting to perform PCI burst reads. This bit is used in conjunction with the PRCNTx field in the MISC_CTL and MISC_CTL2 registers.                        |
|                                               | BRSTWREN   | Set this bit to enable the QSpan II to perform burst transactions<br>when configured as an MPC860 QBus master. See also the<br>BURST_4 bit in the MISC_CTL2 register on Table 130 on<br>page 284. |
|                                               | INVEND     | This bit Inverts the endian state from the state of the QB_BOC bit.                                                                                                                               |
|                                               | BS[3:0]    | Block Size of Target Image (affects number of address lines translated).                                                                                                                          |
|                                               | PAS        | This bit allows the PCI Target Image to respond to a Memory or I/O cycle. Typically, only Memory Space is implemented.                                                                            |
|                                               | TC[3:0]    | This field determines how the TC[3:0] lines of the QSpan II are driven.                                                                                                                           |
|                                               | DSIZE[1:0] | This field specifies the size of the destination port/memory on the QBus.                                                                                                                         |
| PBTI0_ADD <sup>a</sup><br>and/or<br>PBTI1_ADD | BA[31:16]  | This field specifies the base address of the PCI memory image<br>which the QSpan II monitors (see "Address Translation" on<br>page 68).                                                           |
|                                               | TA[31:16]  | This field specifies part of the value for the translated local address (see "Address Translation" on page 68).                                                                                   |

| Table 166: P0 | CI Target Image | Programming    | Summarv | (Continued) |
|---------------|-----------------|----------------|---------|-------------|
|               | n narget innage | , i rogramming | Cannary |             |

a. See also PCI\_BST0 and PCI\_BST1 registers in Appendix A: "Registers" on page 199.

Once the target images are programmed, PCI masters can read from and write to the QBus address space.

# D.5 Error Logging of Posted Transactions

QSpan II has registers which allow the processor to recover from a failed write cycle from either the Px-FIFO or Qx-FIFO. This section discusses posted writes; delayed reads and delayed writes are treated differently. QSpan II has the ability to log the failed posted write cycle and generate an interrupt back to the PCI master or the QBus processor. See "Terminations of Posted Writes" on page 88 for an explanation of error recording in the PCI Target channel.

| Table 167: QBus Error Logging | Programming Summary |
|-------------------------------|---------------------|
|-------------------------------|---------------------|

| Register | Field        | Description                                          |
|----------|--------------|------------------------------------------------------|
| QB_ERRCS | ES           | Indicates if a failed cycle is currently logged.     |
|          | EN           | Enables error logging.                               |
|          | TC_ERR[3:0]  | Logs the status of the TC[3:0]of the failed cycle.   |
|          | SIZ_ERR[1:0] | Logs the SIZ[1:0] field of the failed cycle.         |
| QB_AERR  | QAERR[31:0]  | Logs the 32-bit address of the failed transaction.   |
| QB_DERR  | QDERR[31:0]  | Logs the 32-bits of data for the failed transaction. |

Similarly, error logging can be enabled for the QBus Slave Channel (see the following table).

Table 168: PCI Bus Error Logging Programming Summary

| Register | Field        | Description                                                                        |
|----------|--------------|------------------------------------------------------------------------------------|
| PB_ERRCS | ES           | Indicates if a failed cycle is currently logged.                                   |
|          | EN           | Enables error logging.                                                             |
|          | UNL_QSC      | Allows the PCI Interface to serve the QBus Slave Channel after an error is logged. |
|          | CMD_ERR[3:0] | Logs the PCI command for the failed cycle.                                         |
|          | BE_ERR[3:0]  | Logs the status of the Byte Enables for the failed cycle.                          |
| PB_AERR  | PAERR[31:0]  | Logs the 32-bit address of the failed transaction.                                 |
| PB_DERR  | PDERR[31:0]  | Logs the 32-bits of data for the failed transaction.                               |

# D.6 IDMA/DMA Channel Initialization

The IDMA/DMA Channel has a single FIFO which can perform burst writes or burst reads on the PCI Bus. During an IDMA cycle, the QSpan II is an IDMA peripheral while either the MC68360 or the MPC860 is the bus master of the cycle. The MC68360 or the MPC860 must program three registers in order to initiate an IDMA transfer. During DMA transfers, the QSpan II is the master on both the QBus and the PCI Bus.

See Chapter 5: "The IDMA Channel" on page 89 and Chapter 6: "The DMA Channel" on page 99 for more information about register programming.

| Register          | Field        | Description                                                                                                  |
|-------------------|--------------|--------------------------------------------------------------------------------------------------------------|
| IDMA/<br>DMA_PADD | ADDR[31:2]   | The starting address of the IDMA/DMA transaction on the PCI bus.                                             |
| IDMA/<br>DMA_CNT  | CNT[23:2]    | This register specifies the number of bytes which will be transferred.                                       |
| IDMA/<br>DMA_CS   | (various)    | Fields in this register should be set according to the transaction requirements (see Table 109 on page 252.) |
| DMA_QADD          | Q_ADDR[31:2] | The starting address of the DMA transaction on the QBus.                                                     |
| DMA_CS            | (various)    | Fields in this register should be set according to the transaction requirements (see Table 113 on page 258). |
| PCI_CS            | BM           | Enables the QSpan II to become the PCI bus master                                                            |

Table 169: IDMA/DMA Channel Programming Summary

Interrupts can be generated based on different IDMA or DMA event types. The status bits in the IDMA\_CS or DMA\_CS register will cause an interrupt if enabled in the INT\_CTL register (see Chapter 8: "The Interrupt Channel" on page 119)

## D.7 Interrupt Initialization

QSpan II has many different interrupting capabilities (See Chapter 8: "The Interrupt Channel" on page 119 for a detailed discussion). These interrupt capabilities include: software doorbells, mailboxes, error conditions, DMA completion, I<sub>2</sub>O, power management, and hardware interrupt sources. There are enable bits for each interrupt source (INT\_CTL register), interrupt direction (QBus or PCI) bits for each source (INT\_DIR register), and interrupt status bits for each source in the INT\_STAT register.

# D.8 Generation of PCI Configuration and IACK Cycles

QSpan II can generate PCI Configuration cycles through a QBus master accessing QSpan II registers. In order to generate a PCI Configuration read or write cycle, two registers must be accessed. First, the Configuration Address register must be programmed. Second, a write to the CON\_DATA register is performed which causes the PCI configuration write cycle to occur on the bus. In order to generate a PCI Configuration read the QBus master should perform a read of the CON\_DATA Register (see "PCI Configuration Cycles Generated from the QBus" on page 114).

In order to generate a PCI IACK Cycle, the QBus processor should perform a read of the IACK Cycle Generator Register (see "IACK\_GEN" on page 265).

| Register | Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CON_ADD  | BUS_NUM[7:0]  | See the <i>PCI 2.2 Specification</i> and the QSpan II register descriptions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          | DEV_NUM[3:0]  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | FUNC_NUM[2:0] |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | REG_NUM[5:0]  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          | TYPE          | Determines whether the Configuration cycle generated is Type 0 or Type 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CON_DATA | CDATA[31:0]   | When this register is written to its contents are driven onto the PCI data bus during a Configuration write cycle. The QBus master is retried until the write completes on the PCI bus (for example, writes are delayed transactions). A read of this register initiates a PCI Configuration read cycle. The value returned from the PCI target is stored temporarily in this register while waiting for the QBus master to perform an additional read to obtain the data (for example, reads are also implemented as delayed transactions). |
| MISC_CTL | MA_BE_D       | This bit should be set to 1 so that when a PCI Master-Abort occurs during a PCI Configuration cycle a normal data acknowledgement is signaled to the QBus processor.                                                                                                                                                                                                                                                                                                                                                                         |
| IACK_GEN | IACK_VEC      | When the register is read, the QSpan II will perform a PCI IACK<br>Cycle. The QBus master is retried until the cycle completes on<br>the PCI Bus. The value from the PCI IACK is stored temporarily<br>in this register while waiting for the QBus master to perform an<br>additional read to obtain the vector.                                                                                                                                                                                                                             |

#### Table 170: PCI Configuration and IACK Cycle Programming Summary

# D.9 EEPROM and VPD Initialization

Many of the QSpan II's operating parameters can be set by a serial EEPROM (see Chapter 9: "The EEPROM Channel" on page 127). It is possible to program the serial EEPROM by accessing a QSpan II register (EEPROM\_CS). It is possible to program Vital Product Data (VPD) information into the serial EEPROM by writing to the PCI\_VPD register. For additional programming details about EEPROM and VPD, see Chapter 9: "The EEPROM Channel" on page 127.

# D.10 I<sub>2</sub>O Messaging Unit Initialization

To initialize the I<sub>2</sub>O Messaging Unit, complete the following steps:

- 1. Start the QSpan II in PCI disable mode by setting the PCI\_DIS bit to 1 in the MISC\_CTL2 register (see Table 130 on page 284).
- 2. Set the PCI\_CLASS register from the EEPROM or the QBus processor (see Table 71 on page 210).
- 3. Set the I2O\_EN bit to 1 in the I2O\_CS register (see Table 100 on page 242).

This bit moves the PCI\_BSM register to offset 018h.

- 4. Clear the I20\_EN bit.
- Enable PCI access by clearing the PCI\_DIS bit in the MISC\_CTL2 register. This allows the PCI Host to create the PCI memory map.
- 6. The QBus processor initializes the  $I_2O$  Messaging Unit.
- 7. Set the I2O\_EN bit to 1.

# D.11 PCI Expansion ROM Implementation

An Expansion ROM can be implemented on the QBus which will contain additional information for the PCI host. In order for the PCI host to be able to read from this ROM, the base address of this image must be programmed. This address can be programmed from an external serial EEPROM.

| Register  | Field      | Description                                                                                           |
|-----------|------------|-------------------------------------------------------------------------------------------------------|
| PCI_CS    | MS         | Set this bit before accessing the ROM.                                                                |
| PCI_BSROM | BA[31:16]  | This field defines the base address for the expansion ROM.                                            |
|           | EN         | Set this bit in order to use the expansion ROM image.                                                 |
| PBROM_CTL | DSIZE[1:0] | This field defines the size of the Expansion ROM (read only field, programmed by serial EEPROM.       |
|           | BS[2:0]    | This field defines the block size of the Expansion ROM image (read only, programmed by serial EEPROM. |
|           | TC[3:0]    | This field defines how the QSpan II drives the TC lines (read only, programmed by serial EEPROM.      |
|           | TA[31:16]  | This field defines the Translation Address field (read only, programmed by serial EEPROM.             |

Table 171: PCI Expansion ROM programming

# Appendix E: Endian Mapping

This appendix explains Endian Mapping for the QSpan II and Motorola processors. The following topics are discussed:

- "Big-Endian System" on page 396
- "Little-Endian System" on page 397
- "Endian Mapping Methods" on page 398

# E.1 Overview

The PCI bus and the Motorola processors have some differences because of their unique evolutionary histories. PCI was born in the Intel world, making it Little-Endian, while the Motorola processors used Big-Endian.

# E.2 Big-Endian System

In a Big-Endian system, the most significant byte is located at the lowest address in memory. When data is moved to the data bus, the least significant byte is moved to the lowest byte lane (Byte 3 in lowest byte lane) and the most significant byte is moved to the highest byte lane (Byte 0 in highest byte lane). The following figure shows a 4-byte operand being moved to the data bus in a Big-Endian system.

#### Figure 80: Big-Endian System



# E.3 Little-Endian System

In a Little-Endian system, the most significant byte is located at the highest address location. When data is moved to the data bus, the least significant byte is moved to the lowest byte lane (Byte 0 in lowest byte lane) and the most significant byte is moved to the highest byte lane (Byte 3 in highest byte lane). It is important that the PCI bridge provides flexibility in how endian systems are mapped across the interface. The following figure shows a 4-byte operand being moved to the data bus in a Little-Endian system.

#### Figure 81: Little-Endian System

| Memory Organization |            |            |                 | By | te Lar | ies             |   |
|---------------------|------------|------------|-----------------|----|--------|-----------------|---|
|                     |            |            |                 | 0C | 31:24  | Byte 3<br>(MSB) |   |
|                     |            |            |                 |    |        | Byte 2          |   |
|                     |            |            |                 | 08 | 23:16  |                 |   |
|                     |            |            |                 |    |        | Byte 1          |   |
|                     |            |            |                 | 04 | 15:08  |                 |   |
| Byte 3<br>(MSB)     | Byte 2     | Byte 1     | Byte 0<br>(LSB) | 00 | 07:00  | Byte 0<br>(LSB) |   |
| B(3)<br>03          | B(2)<br>02 | B(1)<br>01 | B(0)<br>00      |    |        |                 | _ |

Some host bus adapters (for example, SCSI) for the PCI environment expect their descriptor blocks to be stored in main memory in Little-Endian format. This means that a PCI-to-Motorola bridge must provide a flexible endian mapping scheme to allow for PCI adapter control information to be stored in Motorola memory.

# E.4 Endian Mapping Methods

There are two standard approaches to endian mapping in a PCI-to-Motorola bridge: address invariance and data invariance. A third approach involves using a combination of both methods.

#### E.4.1 Address Invariance

With address invariance, the addressing of the bytes in memory is preserved. The following figure shows that by performing byte-lane swapping, the bytes appear in the same address but their relative significance is not preserved. This method works for text information but scrambles operands.



#### Figure 82: Address Invariant Mapping

#### E.4.2 Data Invariance

The second approach is data invariance, which preserves the relative byte significance but translates the byte addressing. The following figure shows that with data invariance, Byte 0 is still the most significant byte in the data structure but is now located at address 03 in memory rather than address 00.

#### Figure 83: Data Invariant Mapping



#### E.4.3 Combined Method

By enforcing certain constraints on the system, it is possible to implement both options in a PCI-to-Motorola bridge. By assuming that all data structures are 32-bit integers, the bridge could be powered up in either of these mapping modes. In address invariant mode, byte lanes would be swapped (independent of the data path width) assuming that the bytes are part of a 32-bit word. In data invariant mode, the byte lanes would be passed straight through assuming that the bytes are again part of a 32-bit word.

# Appendix F: Operating and Storage Conditions

This appendix discusses operating and storage conditions for the QSpan II. The following topics are discussed:

- "Power Dissipation" on page 401
- "Operating Conditions" on page 402
- "Thermal Characteristics" on page 402

# F.1 Power Dissipation

#### Table 172: Power Dissipation

| QCLK <sup>a</sup> | Minimum | Typical | Maximum |
|-------------------|---------|---------|---------|
| 25 MHz            | 0.28W   | 0.50W   | 0.63W   |
| 40 MHz            | 0.33W   | 0.58W   | 0.75W   |
| 50 MHz            | 0.38W   | 0.63W   | 0.90W   |

a. PCI clock always runs at 33 MHz.

# F.2 Operating Conditions

| Symbol           | Parameter           | Rating                     | Units |
|------------------|---------------------|----------------------------|-------|
| V <sub>DD</sub>  | DC Supply Voltage   | -0.5 to 7.0                | V     |
| V <sub>IN</sub>  | DC Input Voltage    | -0.3 to 5.3 <sup>a b</sup> | V     |
| I <sub>IN</sub>  | DC Input Current    | ±10                        | mA    |
| T <sub>STG</sub> | Storage Temperature | -40 to +125                | °C    |

a. Power available on V<sub>IO</sub> without power to V<sub>DD</sub> (V<sub>IN</sub>) can result in reliability impact.

b. QSpan II is 5V tolerant on all pins.

#### Table 174: 3.3 Volt Recommended Operating Conditions

| Symbol          | Parameter              | Rating     | Units |
|-----------------|------------------------|------------|-------|
| V <sub>DD</sub> | DC Supply Voltage      | 3.0 to 3.6 | V     |
| T <sub>c</sub>  | Commercial Temperature | 0 to 70    | °C    |
| T,              | Industrial Temperature | -40 to 85  | °C    |

# F.3 Thermal Characteristics

The maximum ambient temperature of the QSpan II can be calculated as follows: Ta  $\leq$  Tj -  $\theta_{ja}{}^{*}$  P

Where,

 $T_a = Ambient temperature (°C)$ 

 $T_i$  = Maximum QSpan II Junction temperature (°C) = 125°C

 $\theta_{ja}$  = Ambient to Junction Thermal Impedance (°C / Watt) see Table 175.

P = QSpan II power consumption (Watts), see Table 172.

The ambient to junction thermal impedance  $(\theta_{ja})$  is dependent on the air flow in meters per second over the QSpan II.

|                  | Pac   |       |                      |
|------------------|-------|-------|----------------------|
| Wind Speed (m/s) | 27 mm | 17 mm | Unit                 |
| 0                | 35.0  | 26.6  | θ <sub>ja</sub> ∘c/W |
| 1                | 32.4  | 25.1  | θ <sub>ja</sub> ∘c/W |
| 2                | 29.9  | 23.1  | θ <sub>ja</sub> ∘c/W |

#### Table 175: 3.3 Volt Package Thermal Resistance

# **Appendix G: Mechanical Information**

This appendix discusses mechanical (packaging) information for the QSpan II.

# G.1 Mechanical Information

The following mechanical information is discussed:

- QSpan II PBGA: 256-ball configuration, 17 mm package
- QSpan II PBGA: 256-ball configuration, 27 mm package

#### G.1.1 256 PBGA — 17 mm

#### Table 176: 256 PBGA — 17 mm Packaging Features

| Feature             | Description                                          |  |  |
|---------------------|------------------------------------------------------|--|--|
| Package Type        | 2 layer, 256 terminal Plastic Ball Grid Array (PBGA) |  |  |
| Package Body Size   | 17 X 17 mm                                           |  |  |
| JEDEC Specification | MO-151 Variation AAF-1                               |  |  |



#### Figure 84: 256 PBGA, 17 mm — Top and Side Views

#### G.1.1.1 PBGA Notes — 17 mm

- 1. All dimensions conform to ANSI Y14.5-1994. Dim in millimeters (mm).
- 2. Measured at the maximum solder ball diameter parallel to primary datum Z.
- 3. Primary datum Z and seating plane are defined by the spherical crowns of the solder balls.
- 4. A1 Corner is identified by chamfer, ink mark, metallized mark, indentation or other feature of the package body or lid.
- 5. Reference Specification: QSpan II conforms to Jedec Registered Outline drawing MO-151 Variation AAF-1, except for these dimensions.
- 6. Ball pad is 0.4 mm diameter. Tundra recommends customer's PCB pad have same diameter.

Figure 85: 256 PBGA, 17 mm — Bottom View



#### G.1.2 256 PBGA — 27 mm

#### Table 177: 256 PBGA — 27 mm Packaging Features

| Feature             | Description                                                                                           |
|---------------------|-------------------------------------------------------------------------------------------------------|
| Package Type        | <ul><li>256 terminal Plastic Ball Grid Array (PBGA),</li><li>(1) power and (1) ground plane</li></ul> |
| Package Body Size   | 27 X 27 mm                                                                                            |
| JEDEC Specification | MO-151 Variation BAL-2                                                                                |



#### Figure 86: 256 PBGA, 27 mm — Top and Side Views

#### G.1.2.1 PBGA Notes — 27 mm

- 1. All dimensions conform to ANSI Y14.5-1994. Dim in millimeters (mm).
- 2. Measured at the maximum solder ball diameter parallel to primary datum Z.
- 3. Primary datum Z and seating plane are defined by the spherical crowns of the solder balls.
- 4. A1 Ball Corner ID. Marked in ink for plate mold. Indent if Automold.
- 5. A1 Corner is identified by chamfer, ink mark, metallized mark, indentation or other feature of the package body or lid.
- 6. Reference Specification: QSpan II conforms to Jedec Registered Outline drawing MO-151.
- 7. Ball pad is 0.60 mm diameter. Tundra recommend's customer's PCB pad has same diameter.



Figure 87: 256 PBGA, 27 mm — Bottom View

# **Appendix H: Ordering Information**

This appendix discusses ordering information for the QSpan II.

# H.1 Ordering Information

Tundra products are designated by a part number. When ordering, please refer to products by their full part number.

| Part Number    | Frequency <sup>a</sup>        | Voltage <sup>b</sup> | Temperature  | Package    |
|----------------|-------------------------------|----------------------|--------------|------------|
| CA91L862A-40CL | 25MHz MC68360<br>40MHz MPC860 | 3.3V                 | 0° to 70°C   | 17 mm PBGA |
| CA91L862A-50CL | 33MHz MC68360<br>50MHz MPC860 | 3.3V                 | 0° to 70°C   | 17 mm PBGA |
| CA91L862A-50IL | 33MHz MC68360<br>50MHz MPC860 | 3.3V                 | -40° to 85°C | 17 mm PBGA |
| CA91L862A-40CE | 25MHz MC68360<br>40MHz MPC860 | 3.3V                 | 0° to 70°C   | 27 mm PBGA |
| CA91L862A-50CE | 33MHz MC68360<br>50MHz MPC860 | 3.3V                 | 0° to 70°C   | 27 mm PBGA |
| CA91L862A-50IE | 33MHz MC68360<br>50MHz MPC860 | 3.3V                 | -40° to 85°C | 27 mm PBGA |

a. QSpan II is compatible with all M68040 variants in large buffer mode up to 40 MHz. QSpan is compatible with all M68040 variants in small buffer mode up to 33 MHz.

b. QSpan II supports universal PCI (3.3/5 volt tolerant inputs and 3.3/5 volt compliant output signaling).

# Glossary

| CompactPCI   | CompactPCI is an adaptation of the PCI Specification for Industrial and<br>embedded applications requiring a more robust mechanical form factor than<br>desktop PCI. |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cycle        | Cycle refers to a single data beat; a transaction is composed of one or more cycles.                                                                                 |
| DMA          | Direct Memory Access. A process for transferring data from main memory to a device without passing it through the Host processor.                                    |
| Master       | Master (initiator) is the owner of the PCI bus. It is used for both the QBus and the PCI bus.                                                                        |
| QBus         | QBus is a generic term which refers to the interface between the QSpan II and<br>the Host processor bus to which QSpan II is connected.                              |
| Slave        | Slave (target) is the device which is accessed by the bus master. It is reserved for addresses accessed by PCI masters.                                              |
| Slave Image  | Slave image is a memory range which is mapped on the QBus (Host processor bus). Two slave images reside in the QSpan II QBus Slave Channel.                          |
| Target image | Target image is a memory range which is mapped on the PCI bus. Two target images reside in the QSpan II PCI Target Channel.                                          |

# Index

#### **Numerics**

17 x 17 mm package 405 27 x 27 mm package 407

# A

A[31:0] 167, 171, 175, 187 ACT bit EEPROM\_CS Register 283 IDMA/DMA\_CS Register 252 AD[31:0] 178, 187 ADDR field EEPROM\_CS Register 283 IDMA/DMA\_PADD Register 255, 390 Address Phase Configuration Cycle 115, 262 IDMA Channel 91, 93 QBus 43-47 Address Translation PCI Target Channel 68 **OBus Slave Channel 46** APS bit PCI\_PMC Register 223 Arbitration PCI bus 46 QBus 82–84, 168, 171 **Register Channel 109** Arbitration Scheme PCI Bus Arbiter 146 AS\_43, 45, 167, 187, 328 Assigning the Base Address 65, 68 AT[0:3] 171 AVEC\_ 368, 380

## В

BA bit PCI\_BSM Register 387 BA field I2O\_BAR Register 213 PBTI0\_ADD Register 230, 388 PBTI1 ADD Register 234, 388 PCI\_BSM Register 212 PCI\_BSROM Register 219, 393 PCI BST0 Register 214 PCI\_BST1 Register 216 **BASE** field PCI CLASS Register 210 BB\_/BGACK\_84, 85, 167, 171, 175, 187 BDIP\_63, 79, 162, 167, 171, 175, 187, 369, 374 **BE\_ERR** field PB\_ERRCS Register 238, 389 BERR\_/TEA\_ 85, 168, 171, 175, 187 BG\_82, 83, 84, 168, 171, 176, 187 BGACK 167 BISTC bit PCI\_MISC0 Register 211 BM bit PCI CS Register 114, 209, 390 BM\_EN/FIFO\_RDY\_168, 172, 176, 187, 369 BM\_PARK field PARB\_CTL Register 287, 386 Boundary scan support 29 BR\_ 82, 83, 84, 168, 172, 176, 187 **BRSTEN** bit DMA\_CS Register 259 **BRSTWEN** bit PBTI0\_CTL Register 388 PBTI1\_CTL Register 388 **BRSTWREN** bit Bursting on the QBus 79 PBTI0\_CTL Register 228 PBTI1 CTL Register 232 BS field PBROM\_CTL Register 236, 393 PBTI0 CTL Register 228, 388

PBTI1 CTL Register 232, 388 QBSI0\_AT Register 291, 386 QBSI1\_AT Register 295, 386 **Burst Transfer** PCI Target Channel 78–82 target-disconnect 86, 87 QBus Slave Channel 45, 57, 290, 293, 294 translation 50 write 53 BURST\_/TIP\_ 172, 176, 187 BURST 4 bit DMA\_CS Register 259 MISC\_CTL2 Register 285, 385 **Bus Error 38** burst 290, 294 IDMA 95, 95-97, 252, 266 INT CTL register 269 INT\_DIR register 272 INT\_STAT register 266 logging (PCI Target Channel) 88 logging (QBus Slave Channel) 60 PB\_DERR register 241 PB ERRCS register 238 PCI Master Module 59 **OB ERRCS register 297** QBus Master Module 85 QBus Slave Module 57, 290, 294 burst 53, 54 signaling 58 QBus Slave Module (signaling) 58 translation (PCI Target Channel) 88 Bus Parking 46, 148 PCI Bus Arbiter 148 Bus Request 187 PCI bus 46, 180, 189 OBus 82, 168, 171 BUS\_NUM field CON\_ADD Register 262, 391 Byte Lane (EEPROM) 133

# С

C/BE#[3:0] 49, 178, 187 C/BE[1] 187 C/BE[2] 187 C/BE[3] 187 Cacheline 78, 87 CAP\_ID field

CPCI HS Register 225 PCI\_PMC Register 223 PCI\_VPD Register 226 CAP L bit PCI\_CS Register 208 CAP\_PT field PCI\_CP Register 221 Capacitors 164 CCODE field PCI\_MISC0 Register 211 CDATA field CON DATA Register 264, 391 CHAIN bit IDMA/DMA\_CS Register 253 Chip Select 168, 172, 176, 179 CLINE field PCI\_MISC0 Register 211 CLKO1 365 Clocking M68040 379 PowerQUICC 372 **QUICC 365** CMD bit IDMA/DMA\_CS Register 252 CMD\_ERR field PB\_ERRCS Register 238, 389 CNT field IDMA/DMA\_CNT Register 256, 390 CompactPCI Hot Swap Card Extraction 153 Card Insertion 151 CompactPCI Hot Swap Friendly 149 CON\_ADD Register 262 DEV\_NUM field 115 FUNC\_NUM field 115 REG NUM field 115 TYPE bit 115 CON\_DATA Register 264 CDATA field 115 **Configuration Space** from PCI bus 68 from PCI bus (how to access) 391 from QBus 36, 43, 49, 53 from QBus (how to access) 114-116 **IDMA Channel 90** PCI Target Channel 111 **Register Channel 109** CP LOC bit

DMA\_CS Register 259 CPCI\_HS Register 225 CPP field DMA\_CPP 261 CSPCI\_ 168, 172, 176, 187 CSREG\_ 113, 168, 172, 176, 187 Customer Support Information 33 Cycle Termination PCI Target Channel 84 QBus Slave Channel 57, 60

#### D

D[31:0] 168, 172, 176, 187 D PE bit PCI\_CS Register 207 D1\_SP bit PCI PMC Register 223 D2\_SP bit PCI\_PMC Register 223 DACK /SDACK 168, 172, 187 DATA field EEPROM\_CS Register 283 Data Packing/Unpacking 74 IDMA Channel 92, 93, 97 PCI Target Channel 74, 78 **QBus Slave Channel 53** Data packing/unpacking IDMA Channel 98 Data Parity Error (see Parity) Data Phase PCI Configuration Cycle 116 PCI Interface and PAR 56 PCI Target Channel burst 78 DC Characteristics 183 Decoupling Capacitors 164 Delayed Transfer Configuration Cycles 38 PCI Target Channel 88 PCI Transaction Ordering 81 PWEN bit 78 single write 78, 79 write 87 QBus Slave Channel 36, 58 burst read 54 delayed write 57 PCI Transaction Ordering 55

single write 57 DEV\_NUM field CON\_ADD Register 262, 391 DEV66 bit PCI\_CS Register 208 **DEVSEL** field PCI\_CS Register 207 DEVSEL# 50, 68, 87, 178, 187 DID field PCI\_ID Register 206 DIR bit DMA CS Register 258 IDMA/DMA\_CS Register 253 Direct Mode DMA Channel 100 discard timer 54 DMA Channel 37 Burst Cycles 102 description 99 Direct Mode 100, 103 DMA Cycles on QBus 103 Linked-List Mode 100, 104 Registers 101 DMA Registers 101 DMA\_CPP Register 261 DMA\_CS Register 258 DMA\_QADD Register 257 **Document Conventions** Bit Ordering 31 Document Status 32 Numeric Conventions 31 Signals 31 Symbols 32 **Typograhic Conventions 31** DONE bit IDMA/DMA\_CS Register 252 DONE 169, 172, 188 DONE\_DIR bit INT\_DIR Register 272 DONE EN bit INT\_CTL Register 269 DONE IS bit INT\_STAT Register 266 DP\_D bit PCI\_CS Register 122 DPNE\_DIR bit **INT\_DIR** Register 273 DREQ 92, 169, 172, 188

DS\_ 169, 188 DSACK0\_ 169, 188 DSACK1\_/TA\_ 169, 173, 176, 188 DSI bit PCI\_PMC Register 223 DSIZE bit PBTI0\_CTL Register 228 DSIZE field DMA\_CS Register 258 PBROM\_CTL Register 236, 393 PBTI0\_CTL Register 388 PBTI1\_CTL Register 232, 388 Dual Address Cycle 91, 93, 328, 347 termination mode 254 timing 253, 332, 334

# E

**EEPROM** channel description 127-134 Control and Status Register 204 PCI\_BST0 register enabled 214 PCI\_BST1 register enabled 216 programming 133 SCL signal 181 SDA signal 181 **EEPROM CS Register 283** ADDR field 134 EIM bit CPCI HS Register 225 EN bit PB ERRCS Register 238, 389 PBTI0 CTL Register 228, 388 PBTI1\_CTL Register 232, 388 PCI\_BSROM Register 219, 393 QB\_ERRCS Register 297, 389 QBSI0\_AT Register 291, 386 QBSI1\_AT Register 295, 386 **Endian Issues** PCI Target Channel 72–77, 232, 258 QBus Slave Channel 50–51 Register Channel 114 Endian Mapping 395 ENID 181, 182, 188 ENUM# 180, 188 ES bit PB\_ERRCS Register 238, 389 **OB ERRCS Register 297, 389** Expansion ROM 219, 220, 236

EXT bit CPCI\_HS Register 225 EXT\_GNT# 188 EXT\_GNT#[6:1] 178 EXT\_REQ# 188 EXT\_REQ#[6:1] 179

# F

FIFO SIZE field I2O\_CS Register 243 FRAME# 68, 179, 188, 193 Frequency PCLK 179 **QCLK** M68040 177, 316 PowerQUICC 173, 312 QUICC 170, 307 IDMA fast termination 312, 331, 334 **QUICC IDMA** fast termination 170 FUNC\_NUM field CON\_ADD Register 262, 391 **Functional Diagram** QSpan II 36

# G

GNT# 179, 188 GO bit IDMA/DMA\_CS Register 252

# Η

HALT\_/TRETRY\_ 169, 173, 188 Hot Swap Friendly 149 HS\_HEALTHY\_ 180, 188 HS\_LED 180, 188 HS\_SWITCH 180, 188

# I

I/O Read 49, 50, 68 I/O Space IDMA Channel 90 PCI Target Channel burst 86 image programming 66, 68 QBus Slave Channel 36, 44 burst 53, 54, 57 image programming 44 I/O Write 49, 50, 68  $I_2O$ 

Inbound Messaging 138 Interrupts 143 Operation 140 Outbound Messaging 139 I<sub>2</sub>O Messaging Unit 137 I2O\_BAR Register 213 I2O\_CS Register 242 I2O\_INQ Register 302 I2O\_OPIM Register 301 I2O\_OPIS Register 300 I2O OUTQ Register 303 IACK\_GEN Register 265 IACK\_VEC field 125 IACK VEC bit IACK\_GEN Register 391 IACK\_VEC field IACK\_GEN Register 265 **IDMA** Channel Endian issues 97–98 error (see Bus Error/IDMA) interrupt (see Interrupt/IDMA) port size 91, 92, 93, 253 reset 95, 252, 254 status 95 IDMA signals (direction) 328, 347 IDMA/DMA\_CNT Register 256 IDMA/DMA\_CS Register 252 IDMA/DMA\_PADD Register 255 IDMA\_ADD Register ADDR field 91, 93 IDMA\_CNT Register IDMA\_CNT field 92, 93, 94 IDMA\_CS Register ACT bit 95 DIR bit 91, 93 DONE bit 92, 93, 94, 95, 96, 122 GO bit 92, 93 IMODE bit 91 IPE bit 92, 93, 95, 96, 97, 122 IQE bit 95, 96, 97, 122 IRST bit 92, 93, 95, 96, 97, 121, 122 IRST\_REQ bit 92, 94, 97 PORT16 bit 91, 93 QTERM bit 91, 93 STERM bit 91, 93 IDSEL 111, 179, 188 IF BP field

IIF\_BP Register 245 IF\_E bit I2O\_CS Register 242 IF F bit I2O\_CS Register 242 IF\_TP field IIF\_TP Register 244 IFE\_DIR bit INT DIR Register 273 IFE\_EN bit INT\_CTL Register 271 IFE S bit INT\_STAT Register 267 I-FIFO Watermark 93 IIF BP Register 245 IIF\_TP Register 244 IIP\_BP Register 247 **IIP TP Register 246** IMODE bit IDMA/DMA\_CS Register 253 IMSEL 169, 173, 176, 188, 380 IN\_Q field I2O\_INQ Register 302 INS bit CPCI\_HS Register 225 INT# 121, 179, 188 INT CTL Register 269 DONE\_EN bit 95, 96, 122 DPD\_EN bit 56, 122 IPE EN bit 96, 122 IQE\_EN bit 95, 96, 122 IRST\_EN bit 95, 96, 122 PEL\_EN bit 60 QEL\_EN bit 88, 122 SI0 bit 124 SI1 bit 124 INT\_CTL2 Register 275 INT\_DIR bit INT\_DIR Register 272 INT\_DIR Register 272 DPD\_DIR bit 122 IPE\_DIR bit 96, 122 IQE\_DIR bit 96, 122 IRST\_DIR bit 96, 122 PEL DIR bit 60 QEL\_DIR bit 88, 122 SI0\_DIR bit 124 SI1 DIR bit 124

INT EN bit INT\_CTL Register 270 INT IS bit INT\_STAT Register 266 INT\_LINE field PCI\_MISC1 Register 222 INT\_PIN field PCI\_MISC1 Register 222 **INT\_STAT** Register 266 DONE\_IS bit 96, 122 DPD\_IS bit 122 IPE IS bit 96, 122 IOE IS bit 96, 122 IRST\_IS bit 96, 122 QEL IS bit 122 SI0\_IS bit 124 SI1\_IS bit 124 Interrupt Acknowledge Cycle 49, 125 Interrupt Channel 38 address parity 81 description 119 IDMA Channel 95 interrupt enabling 122 interrupt mapping 122 interrupt sources 122 PCI Target Module posted writes 88 QBus slave module posted writes 60 INVEND bit DMA\_CS Register 258 PBTI0\_CTL Register 228, 388 PBTI1\_CTL Register 232, 388 **IOF\_BP** Register 249 **IOF\_TP** Register 248 **IOP\_BP** Register 251 IOP\_TP Register 250 IOS bit PCI\_CS Register 209, 387 IP\_BP field IIP\_BP Register 247 IP\_E bit I2O\_CS Register 242 IP F bit I2O\_CS Register 242 IP\_TP field **IIF TP Register 246** IPE bit IDMA/DMA\_CS Register 252 IPE DIR bit

INT\_DIR Register 272 IPE\_EN bit INT\_CTL Register 269 IPE IS bit INT\_STAT Register 266 IPF\_DIR bit INT\_DIR Register 273 IPF\_EN bit INT CTL Register 271 IPF\_S bit INT\_STAT Register 267 IPL[2:0] 380 IPN DIR bit INT\_DIR Register 273 IPN EN bit INT\_CTL Register 271 IPN\_IS bit INT\_STAT Register 267 IQE bit IDMA/DMA\_CS Register 252 IQE DIR bit INT\_DIR Register 272 IQE\_EN bit INT\_CTL Register 269 IQE\_IS bit INT\_STAT Register 266 IRDY# 179, 188 IRQ[7:1] 368, 375 **IRST** bit IDMA/DMA\_CS Register 252 IRST DIR bit INT\_DIR Register 272 IRST\_EN bit INT\_CTL Register 269 IRST\_IS bit INT\_STAT Register 266 IRST\_REQ bit IDMA/DMA\_CS Register 252 IWM field DMA\_CS Register 258 IDMA/DMA\_CS Register 253

# J

JTAG 29

#### Κ

KEEP\_BB bit 79 MISC\_CTL2 Register 284, 385

#### L

LAYOUT field PCI\_MISC0 Register 211 Linear address incrementing 78 Linked-List Mode DMA Channel 100 LOCK 62 LOO bit CPCI\_HS Register 225 LTIMER field PCI\_MISC0 Register 211

#### Μ

M68040 35, 162 bus arbitration 84 Compatibility of QSpan with variants of 379, 411 cycle termination 85 Interface 378 master and slave modes 162 signals 175 MA\_BE\_D bit MISC\_CTL Register 280, 384, 391 Mailbox Registers 118 Master-Abort 50, 57, 59, 60, 81 Master-Completion 57, 88 MAX\_LAT field PCI\_MISC1 Register 222 MAX\_RTRY field MISC\_CTL2 Register 284, 385 MB\_DATA field MBOX0 Register 276 MBOX1 Register 277 MBOX2 Register 278 MBOX3 Register 279 MB0\_DIR bit INT DIR Register 273 MB0\_EN bit INT\_CTL Register 270 MB0 IS bit INT\_STAT Register 267 MB1\_DIR bit INT\_DIR Register 273 MB1\_EN bit INT\_CTL Register 270 MB1\_IS bit INT\_STAT Register 267 MB2\_DIR bit

INT\_DIR Register 273 MB2\_EN bit INT\_CTL Register 270 MB2 IS bit INT\_STAT Register 267 MB3\_DIR bit INT\_DIR Register 273 MB3\_EN bit INT\_CTL Register 270 MB3\_IS bit INT\_STAT Register 267 MBOX0 Register 276 MBOX1 Register 277 MBOX2 Register 278 MBOX3 Register 279 MC68302 28 MD\_PED bit PCI\_CS Register 208 MDBS bit DMA\_CS Register 259 MDPED DIR bit INT\_DIR Register 272 MDPED EN **INT CTL 269** MDPED\_IS bit INT\_STAT Register 266 Mechanical Information 405 Memory Controller M68040 380 PowerQUICC 374 **QUICC 367** Memory Read 68 Memory Read Line 49, 68 Memory Read Multiple 49, 68 Memory Space IDMA Channel 90 PCI Target Channel image programming 66 **QBus Slave Channel** burst 53, 54 image programming 44 Memory Write 49, 50, 68 Memory Write and Invalidate 49, 68 MFBBC bit PCI\_CS Register 208 MFUNCT bit PCI\_MISC0 Register 211 MIN GNT field

PCI MISC1 Register 222 MISC\_CTL Register 41, 280 MSTSLV field 41, 63, 162 QB\_BOC bit 50, 72, 97 S\_BB bit 83, 84 S\_BG bit 83, 84 SW\_RST bit 160 MISC\_CTL register QB BOC bit 67 MISC\_CTL2 Register 284 MS bit PCI CS Register 209, 387, 393 MSTSLV field MISC\_CTL Register 281, 384 MWI EN bit PCI\_CS Register 209 Mx\_PRI bit PARB\_CTL Register 287, 386

# Ν

NOTO bit MISC\_CTL2 Register 385 NXT\_IP field CPCI\_HS Register 225 PCI\_PMC Register 223 PCI\_VPD Register 226

# 0

OF\_BP field IOF\_BP Register 249 OF\_E bit I2O\_CS Register 242 OF\_F bit I2O\_CS Register 242 OF\_TP field IOF\_TP Register 248 OFE DIR bit INT\_DIR Register 273 OFE\_EN bit INT\_CTL Register 271 OFE\_S bit INT\_STAT Register 267 OFF\_DIR bit INT\_DIR Register 274 OFF\_EN bit INT\_CTL Register 271 OFF S bit INT\_STAT Register 268 OP BP field **IOP\_BP** Register 251 OP E bit I2O\_CS Register 242 OP\_F bit I2O\_CS Register 243 OP\_IM bit I2O\_OPIM Register 301 OP ISR bit I2O\_OPIS Register 300 **OP\_TP** field **IOP TP Register 250** Open Drain Output 188, 189 OPNE bit INT STAT Register 267 OPNE\_EN bit INT\_CTL Register 270 Ordering Information 411 OUT\_Q field I2O\_OUTQ Register 303

# Ρ

P2P BSE field PCI\_PMCS Register 224 PAERR field PB\_AERR Register 240, 389 PAR 56, 81, 179, 188 PARB\_CTL Register 287 Parity PCI Master Module address parity 56 data parity 56 PCI Target Module address parity 68, 81 data parity 81 register bits 56, 81, 207, 208, 272 summary 122 PARK bit PARB\_CTL Register 287, 386 PAS bit PBTI0\_CTL Register 228, 388 PBTI1\_CTL Register 232, 388 PCI\_BSIO Register 214 PCI\_BST1 Register 216 QBSI0\_CTL Register 289, 386 QBSI1\_CTL Register 293, 386 PB AERR Register 240 PAERR field 60

PB DERR 60 PB\_DERR Register 241 PB ERRCS 60 PB\_ERRCS Register 238 **BE\_ERR** field 60 CMDERR field 60 EN bit 59, 60 ES bit 60 PBROM CTL Register 236 PBTI0\_ADD Register 230 PBTI0\_CTL Register 228 PBTI1 ADD Register 234 PBTI1\_CTL Register 232 PBTIx\_ADD BA field 65 TA field 66 PBTIx\_CTL Register BS field 65 DSIZE field 63, 66, 72 EN bit 66 PAS bit 66 PWEN bit 66 TC field 66, 70 PCI Bus Arbiter 145 Arbitration Scheme 146 **Bus Parking** 148 PCI Interface 35 cycle types 49 PCI Master Module defined 42 PCI Power Management Support 157 PME# 157 PCI Target Image base address 65 block size 65 enabling 66 PCI address space 66 port size 66 posted write enabling 66 registers 230-235 transaction code 66 translation address 66 PCI Target Image 68 PCI Target Module 62 PCI Target Prefetch Disconnect 86 PCI\_ARB\_EN 181, 189 Reset Options 162 PCI\_ARB\_EN bit

PARB\_CTL Register 287, 386 PCI\_BSM Register 212 BA field 112 PCI\_BSROM Register 219 PCI\_BST0 Register 214 PCI\_BST1 Register 216 PCI\_BSTx Register BA field 71, 72 PAS bit 71–72 PCI\_CLASS Register 210 PCI\_CP Register 221 PCI CS Register 207 BM bit 114, 161, 168, 172, 176, 386 D\_PE bit 56 **DEVSEL** field 68 DP D bit 56, 122 MS bit 112 PERESP bit 56, 81 S\_SERR bit 81 SERR\_EN bit 81 PCI DIS 181, 189 Reset Options 162 PCI DIS bit MISC\_CTL2 Register 284, 385 PCI\_ID Register 206 PCI MISC0 Register 211 CLINE field 87, 91, 93, 96 PCI\_MISC1 Register 222 PCI\_PMC Register 223 PCI\_PMCS Register 224 PCI\_SID Register 218 SID field 131 SVID field 131 PCI\_VPD Register 226, 227 PCLK 179, 189 PCSR\_DIR bit INT\_DIR Register 272 PCSR\_EN bit INT\_CTL Register 269 PCSR\_IS bit INT\_STAT Register 266 PDERR field PB\_DERR Register 241, 389 PEL\_DIR bit INT DIR Register 272 PEL\_EN bit INT\_CTL Register 269 PEL IS Register

INT\_STAT Register 266 PERESP bit PCI\_CS Register 208 PERR# 56, 179, 189 PERR\_DIR bit INT\_DIR Register 273 PERR\_EN bit INT\_CTL Register 270 PERR IS bit INT\_STAT Register 267 P-FIFO 63 Pin-Out 17x17 mm Package 196, 197 Plug and Play 29 PM VER field PCI\_PMC Register 223 PME# 157, 181, 189 PME CLK bit PCI\_PMC Register 223 PME\_EN bit PCI\_PMCS Register 224 PME\_SP field PCI\_PMC Register 223 PME ST bit PCI\_PMCS Register 224 Port Size IDMA Channel 91, 92, 93 IDMA\_CS register 91, 253 PBROM\_CTL register 236 PBTI0\_CTL register 228 PBTI1\_CTL register 232, 258 PCI Target Image 66 PORT16 bit IDMA/DMA\_CS Register 253 Posted Write error 60.88 PCI Target Channel 78 enabling 66, 78 error logging 88 PCI transaction ordering 55–56 QBus Slave Channel 52–53 enabling 44 PCI transaction ordering 55 transaction ordering 56 Posted Write Termination **QBus Slave Channel** error logging 59 Power Dissipation 401

PowerOUICC 28, 35 **Bus Arbitration 83 Connection Caution 47** cycle termination 58, 85 DONE signal 92 master and slave modes 162 signals 171 PowerQUICC Interface 371 Power-Up Options 159, 163 PR\_CNT2 bit MISC\_CTL2 Register 385 PR CNT2 field MISC\_CTL2 Register 285 PR\_SING bit MISC CTL2 Register 67, 285, 385 PRCNT bit MISC\_CTL Register 384 PRCNT field MISC\_CTL Register 281 PREF bit PCI\_BSIO Register 214 PCI\_BST1 Register 216 PREN bit PBTI0\_CTL Register 228, 388 PBTI1\_CTL Register 232, 388 OBSI0 CTL Register 289, 386 QBSI1\_CTL Register 293, 386 PROG field PCI\_CLASS Register 210 PSC DIR bit INT\_DIR Register 273 PSC\_EN bit INT\_CTL Register 270 PSC IS bit INT\_STAT Register 267 PSC\_QRST bit MISC\_CTL2 Register 286 PTC\_PD bit MISC\_CTL2 Register 284, 385 PTP IB bit MISC\_CTL2 Register 284, 385 Pull-Downs 163 Pull-Up M68040 signals 380, 382 PowerQUICC signals 374 QUICC signals 58, 368, 369, 376 Pull-Ups 166 PWEN bit

PBTI0\_CTL Register 228, 388 PBTI1\_CTL Register 232, 388 QBSI0\_CTL Register 289, 386 QBSI1\_CTL Register 293, 386 PWR\_ST field PCI\_PMCS Register 224

### Q

O ADDR field DMA\_CS Register 390 DMA\_QADD Register 257 O OFF bit DMA\_CS Register 259 **QAERR** field QB\_AERR Register 298, 389 QB\_AERR Register 298 **QAERR** field 88 QB\_BOC bit MISC\_CTL Register 264, 265, 280, 384 **QB DERR Register 299 QDERR** field 88 QB\_ERRCS Register 297 EN bit 88 ES bit 88 SIZ\_ERR field 88 TC ERR field 88 QBSI0\_AT Register 291 QBSI0\_CTL Register 289 QBSI1\_AT Register 295 QBSI1\_CTL Register 293 QBSIx\_AT Register BS field 44, 46, 48, 65, 132 EN bit 44, 46 TA field 44, 46, 131 QBSIx\_CTL Register PAS bit 44, 49, 50, 53, 131 PWEN bit 44, 52, 53, 131 QBus Bursting on the QBus 79 QBus (defined) 35 QBus Data Parity 41, 64 **OBus Master Mode 63** QBus Master Module 63 QBus Slave Image 43–44 enable address translation 44 PCI address space 44 posted write enabling 44 registers 295

OBus Slave Mode 41, 63 QBus Slave Module 41 QCLK 170, 173, 177, 189 **ODERR** field QB\_DERR Register 299, 389 QDPE\_DIR bit INT\_DIR Register 273 QDPE\_EN bit INT\_CTL Register 270 QDPE\_S bit INT\_STAT Register 267 QEL DIR bit INT\_DIR Register 272 QEL\_EN bit INT\_CTL Register 269 QEL\_IS bit INT\_STAT Register 266 QIBA field I2O\_CS Register 242 IIF\_BP Register 245 IIF\_TP Register 244 IIP\_BP Register 247 IIP\_TP Register 246 IOF\_BP Register 249 **IOF\_TP** Register 248 **IOP\_BP** Register 251 IOP TP Register 250 QINT\_121, 170, 173, 177, 189, 368, 380 QINT\_DIR bit INT\_DIR Register 273 QINT\_EN bit INT\_CTL Register 270 QINT\_IS bit INT\_STAT Register 267 QINT\_PME bit MISC\_CTL2 Register 286 QS\_PRI bit PARB\_CTL Register 287, 386 QSC PW bit MISC CTL2 Register 385 **QSpan II Device Specific Registers** 199 **QTERM** bit IDMA/DMA\_CS Register 253 QUICC bus arbitration 82 cycle termination 84 master and slave modes 162 signals 167

QUICC Interface 365

#### R

R/W\_170, 173, 177, 189 R MA bit PCI\_CS Register 207 R\_TA bit PCI\_CS Register 207 **READ** bit EEPROM\_CS Register 283 Read Transactions 80 REG\_AC bit MISC\_CTL2 Register 285, 385 REG NUM field CON\_ADD Register 262, 391 Register Channel 37, 109–116 from PCI bus 111 from OBus 113–116 Register Map 201, 205 **Related Documentation 32** REQ# 46, 180, 189 Reset EEPROM 127 from PCI bus 180 options 159 QBus 170, 173 QSpan from QBus 173, 177 QSpan II from PCI bus 159 **QSpan II from QBus 170** QSpan II through sofware 160 timing parameters 319 RESETH 379 RESETI\_ 159, 170, 173, 177, 189 RESETO\_ 159, 170, 173, 177, 189 Resets 159 **IDMA Channel 95** RESETS\_373 RID field PCI\_CLASS Register 210 RR\_BP bit I2O\_CS Register 243 RST# 159, 180, 189 **RSTI\_379** 

## S

S\_BB bit MISC\_CTL Register 280, 384 S\_BG bit

MISC\_CTL Register 280, 384 S\_SERR bit PCI\_CS Register 207 S TA bit PCI\_CS Register 207 SBIST bit PCI\_MISC0 Register 211 SBO# 62 SC bit PCI\_CS Register 209 SCL 129, 163, 181, 189 SDA 129, 181, 189 SDACK 189 SDONE 62 SERR# 81, 180, 189 SERR\_DIR bit **INT\_DIR** Register 273 SERR EN bit INT\_CTL Register 270 PCI\_CS Register 208 SERR IS bit INT\_STAT Register 267 SI0 bit INT\_CTL Register 271 SI0\_DIR bit INT\_DIR Register 274 SI0 IS bit INT\_STAT Register 268 SI1 bit INT\_CTL Register 271 SI1\_DIR bit INT\_DIR Register 274 SI1\_IS bit INT\_STAT Register 268 SI2 bit INT\_CTL2 Register 275 SI2 DIR bit INT\_DIR Register 274 SI2 IS bit INT\_STAT Register 268 SI3 bit INT CTL2 Register 275 SI3 DIR bit **INT\_DIR** Register 274 SI3 IS bit INT\_STAT Register 268 SID field PCI SID Register 218

SIZ[1:0] 98, 125, 170, 174, 177, 189 size encoding (M68040) 178 size encoding (QUICC and PowerQUICC) 175 SIZ[1] 189 SIZ[3:0] 368 SIZ\_ERR field QB\_ERRCS Register 297, 389 Software Initialization 383 EEPROM and VPD 392 Error Logging of Posted Transactions 389 Generation of PCI Configuration and IACK Cycles 391 I2O Messaging Unit 392 IDMA/DMA Channel 390 Interrupt Initialization 390 Miscellaneous Control Register Configuration 384 PCI Expansion ROM Implementation 393 PCI Target Channel 387 **QBus Slave Channel 386** Register Access from the PCI Bus 387 SPACE bit I2O\_BAR Register 213 PCI\_BSM Register 212 Special Cycle 49 STERM bit IDMA/DMA\_CS Register 253 STOP bit DMA\_CS Register 259 STOP# 86, 87, 180, 189 STOP\_STAT bit DMA\_CS Register 259 SUB field PCI\_CLASS Register 210 Support Information Designer's Resource Center 33 Email Support 33 Phone Support 33 Sales Support 33 Web Page 33 SVID field PCI\_SID Register 218 SW\_RST bit MISC CTL Register 280, 384

# Т

TA bit

PBTI1\_ADD Register 388 TA field PBROM\_CTL Register 236, 393 PBTI0\_ADD Register 230, 388 PBTI1\_ADD Register 234 QBSI0\_AT Register 291, 386 QBSI1\_AT Register 295, 386 TA\_174, 177, 189, 347 TA BE EN bit MISC\_CTL2 Register 285, 385 Target-Abort 57, 59, 86, 87, 88 defined 87 Target-Disconnect 57, 78, 86 defined 86 Target-Retry 57, 86 defined 87 TC field DMA CS Register 258 IDMA/DMA\_CS Register 253 PBROM\_CTL Register 236, 393 PBTI0 CTL Register 228, 388 PBTI1\_CTL Register 232, 388 TC[1] 189 TC[2] 189 TC[3:0] 170, 174, 177, 189 TC[3] 189 TC EN bit IDMA/DMA\_CS Register 253 TC ERR field QB\_ERRCS Register 297, 389 TCK 182, 190 TDI 182, 190 TDO 182, 190 TEA\_174, 178 Termination Mode (IDMA) 91, 93, 253 TEST1 181, 190 TEST2 181, 190 TEST3 181, 190 Test-Mode Operation 163 **TFBBC** bit PCI\_CS Register 208 TIP 178, 190 TM[2:0] 380 TMODE[0] 190 TMODE[1:0] 163, 181 TMODE[1] 190 TMS 190 Transaction Decoding

PCI Target Module 65, 72 QBus Slave Module 43 Transaction Ordering 55–56, 81–82 TRDY# 86, 87, 180, 190 TRETRY\_ 174 TRST\_ 182, 190 TS\_ 43, 45, 174, 190 TT[1:0] 380 TYPE bit CON\_ADD Register 262, 391 Typical Applications 365

## U

UNL\_QSC bit PB\_ERRCS Register 238

## V

VGAPS bit PCI\_CS Register 209 VH 181 VID field PCI\_ID Register 206 Vital Product Data 134 VPD Reading VPD Data 135 Writing VPD Data 135 VPD\_ADDR field PCI\_VPD Register 226 VPD\_DATA field PCI\_VPD Register 227 VPD\_F bit PCI\_VPD Register 226

## W

WAIT bit PCI\_CS Register 208