# **DatasheetArchive.**com

#### **Request For Quotation**

Order the parts you need from our real-time inventory database. Simply complete a request for quotation form with your part information and a sales representative will respond to you with price and availability.

**Request For Quotation** 

Your free datasheet starts on the next page.

More datasheets and data books are available from our homepage: http://www.datasheetarchive.com



## PowerSpan II<sup>™</sup> PowerPC-to-PCI Bus Switch User Manual

Document Number: 80A1010\_MA001\_06 Document Status: Final Release Date: December 2002

This document discusses the features, capabilities, and configuration requirements of the PowerSpan II. It is intended for hardware and software engineers who are designing system interconnect applications with the PowerSpan II.



Tundra Semiconductor Corporation

#### Trademarks

TUNDRA is a registered trademark of Tundra Semiconductor Corporation (Canada, U.S., and U.K.). TUNDRA, the Tundra logo, PowerSpan II, and Silicon Behind the Network, are trademarks of Tundra Semiconductor Corporation. All other registered and unregistered marks (including trademarks, service marks and logos) are the property of their respective owners. The absence of a mark identifier is not a representation that a particular product name is not a mark.

#### Copyright

Copyright © December 2002 Tundra Semiconductor Corporation. All rights reserved. Published in Canada

This document contains information which is proprietary to Tundra and may be used for non-commercial purposes within your organization in support of Tundra products. No other use or transmission of all or any part of this document is permitted without written permission from Tundra, and must include all copyright and other proprietary notices. Use or transmission of all or any part of this document in violation of any applicable Canadian or other legislation is hereby expressly prohibited.

User obtains no rights in the information or in any product, process, technology or trademark which it includes or describes, and is expressly prohibited from modifying the information or creating derivative works without the express written consent of Tundra.

#### Disclaimer

Tundra assumes no responsibility for the accuracy or completeness of the information presented which is subject to change without notice. In no event will Tundra be liable for any direct, indirect, special, incidental or consequential damages, including lost profits, lost business or lost data, resulting from the use of or reliance upon the information, whether or not Tundra has been advised of the possibility of such damages.

Mention of non-Tundra products or services is for information purposes only and constitutes neither an endorsement nor a recommendation.



## **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, 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



# **Contact Information**

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

### Webpages

| Product information        | www.tundra.com/PowerSpan II describes<br>PowerSpan II's features, benefits, typical<br>applications, and block diagram. This webpage<br>also provides links to other product-related<br>information located on the Tundra website.                                                                                                                                                                                                             |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Design Support Tools (DST) | www.tundra.com/dst contains an extensive<br>collection of technical documents that explain<br>PowerSpan II's features and how to implement<br>them. Some of the DST resources include the<br>device manual, manual addenda, application<br>notes, design notes, and device errata.<br>Once you register for access to the Design<br>Support Tools webpage you can opt to receive<br>email notification when a resource is added or<br>changed. |
| FAQ database               | www.tundra.com/faq is a support database that<br>contains answers to common technical questions<br>fielded by our knowledgeable Technical<br>Support team.                                                                                                                                                                                                                                                                                     |
| Sales support              | www.tundra.com/sales contains information<br>that will help you locate a Tundra sales<br>representative nearest you.                                                                                                                                                                                                                                                                                                                           |

### Email

| Technical support   | Use support@tundra.com to send technical<br>questions and feedback to our Technical Support<br>team. Please include PowerSpan II in the subject<br>header of your message. |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Document feedback   | Use docfeedback@tundra.com to provide<br>feedback on the <i>PowerSpan II Bus Switch User</i><br><i>Manual</i> .                                                            |
| Document ordering   | Use docs@tundra.com to order printed copies of<br>Tundra product manuals (Final status only).<br>Please include PowerSpan II in the subject<br>header of your message.     |
| Phone/Fax           |                                                                                                                                                                            |
| Phone               | 613-592-0714 or 1-800-267-7231                                                                                                                                             |
| Fax                 | 613-592-1320                                                                                                                                                               |
| Mail                |                                                                                                                                                                            |
| Tundra headquarters | Tundra Semiconductor Corporation<br>603 March Road<br>Kanata, ON<br>K2K 2M5                                                                                                |



# Contents

| Со | Corporate Profile   |                         |                                                |    |
|----|---------------------|-------------------------|------------------------------------------------|----|
| Co | Contact Information |                         |                                                |    |
| Ab | About this Document |                         |                                                |    |
| 1. | Fund                | ctiona                  | Il Overview2                                   | 29 |
|    |                     | 1.1.1                   | PowerSpan II Features                          | 31 |
|    |                     | 1.1.2                   | PowerSpan II Benefits                          | 32 |
|    |                     | 1.1.3                   | Typical Applications                           | 32 |
|    |                     | 1.1.4                   | PowerSpan II and PowerSpan Differences Summary | 34 |
|    | 1.2                 | PCI Int                 | terface                                        | 35 |
|    |                     | 1.2.1                   | PCI-to-PCI Bridge                              |    |
|    |                     | 1.2.2                   | Primary PCI Interface                          | 36 |
|    |                     | 1.2.3                   | PCI Host Bridge                                | 37 |
|    |                     | 1.2.4                   | PCI Bus Arbitration                            | 37 |
|    | 1.3                 | Processor Bus Interface |                                                |    |
|    |                     | 1.3.1                   | Address Decoding                               | 37 |
|    |                     | 1.3.2                   | Processor Bus Arbitration                      | 38 |
|    | 1.4                 | DMA (                   | Controller                                     | 38 |
|    | 1.5                 | I2C / E                 | EPROM                                          | 38 |
|    |                     | 1.5.1                   | EEPROM                                         | 38 |
|    |                     | 1.5.2                   | I2C                                            | 38 |
|    | 1.6                 | Concur                  | rrent Reads                                    | 38 |
|    |                     | 1.6.1                   | PowerSpan II's Concurrent Read Solution        | 39 |
|    |                     | 1.6.2                   | PowerSpan II's Concurrent Read Applications    | 41 |

| 2. | PCI | Interfa | ace                                               | 43 |
|----|-----|---------|---------------------------------------------------|----|
|    |     | 2.1.1   | Primary PCI                                       | 44 |
|    |     | 2.1.2   | PCI Data Width                                    | 45 |
|    |     | 2.1.3   | PCI Interface Descriptions                        | 47 |
|    |     | 2.1.4   | Transaction Ordering                              | 47 |
|    | 2.2 | PCI Ta  | arget Interface                                   | 50 |
|    |     | 2.2.1   | PowerSpan II as PCI Target                        | 50 |
|    |     | 2.2.2   | Address Phase                                     | 50 |
|    |     | 2.2.3   | Data Phase                                        | 55 |
|    |     | 2.2.4   | Termination Phase                                 | 58 |
|    | 2.3 | PCI M   | aster Interface                                   | 60 |
|    |     | 2.3.1   | PowerSpan II as PCI Master                        | 60 |
|    |     | 2.3.2   | Arbitration for PCI Bus                           | 61 |
|    |     | 2.3.3   | Address Phase                                     | 62 |
|    |     | 2.3.4   | Data Phase                                        | 63 |
|    |     | 2.3.5   | Termination Phase                                 | 66 |
|    | 2.4 | Compa   | actPCI Hot Swap Silicon Support                   | 67 |
|    |     | 2.4.1   | LED Support                                       | 67 |
|    |     | 2.4.2   | ES Input                                          | 67 |
|    |     | 2.4.3   | HEALTHY# Signal                                   | 68 |
|    |     | 2.4.4   | CompactPCI Hot Swap Card Insertion and Extraction | 68 |
|    |     | 2.4.5   | Hot Swap Insertion Process                        | 70 |
|    |     | 2.4.6   | Hot Swap Extraction Process                       | 72 |
|    | 2.5 | Vital P | Product Data                                      | 75 |
|    |     | 2.5.1   | VPD Access                                        | 75 |
|    |     | 2.5.2   | Reading VPD Data                                  | 76 |
|    |     | 2.5.3   | Writing VPD Data                                  | 76 |
|    | 2.6 | I2O Sh  | nell Interface                                    | 77 |
|    |     | 2.6.1   | I2O Target Image                                  | 77 |
|    |     | 2.6.2   | IOP Functionality                                 | 78 |
|    |     | 2.6.3   | Messaging Interface                               | 79 |
|    |     | 2.6.4   | Inbound Messages                                  | 84 |
|    |     | 2.6.5   | Outbound Messages                                 | 85 |
|    |     | 2.6.6   | Pull Capability                                   | 86 |
|    |     | 2.6.7   | Outbound Option                                   | 90 |

|    |                                                           | 2.6.8                                                                                                   | I2O Standard Registers                                                                                                                                                                                                                                                                                            |
|----|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3. | Proc                                                      | cesso                                                                                                   | r Bus Interface101                                                                                                                                                                                                                                                                                                |
|    | 3.2                                                       | Interfa                                                                                                 | ce Support                                                                                                                                                                                                                                                                                                        |
|    |                                                           | 3.2.1                                                                                                   | Terminology 103                                                                                                                                                                                                                                                                                                   |
|    |                                                           | 3.2.2                                                                                                   | PB Bus Interface Descriptions                                                                                                                                                                                                                                                                                     |
|    | 3.3                                                       | PB Sla                                                                                                  | ve Interface                                                                                                                                                                                                                                                                                                      |
|    |                                                           | 3.3.1                                                                                                   | PowerSpan II as PB Slave 103                                                                                                                                                                                                                                                                                      |
|    |                                                           | 3.3.2                                                                                                   | Address Phase                                                                                                                                                                                                                                                                                                     |
|    |                                                           | 3.3.3                                                                                                   | Data Phase                                                                                                                                                                                                                                                                                                        |
|    |                                                           | 3.3.4                                                                                                   | Terminations 121                                                                                                                                                                                                                                                                                                  |
|    | 3.4                                                       | PB Ma                                                                                                   | ster Interface                                                                                                                                                                                                                                                                                                    |
|    |                                                           | 3.4.1                                                                                                   | PowerSpan II as PB Master 123                                                                                                                                                                                                                                                                                     |
|    |                                                           | 3.4.2                                                                                                   | Address Phase                                                                                                                                                                                                                                                                                                     |
|    |                                                           | 3.4.3                                                                                                   | Data Phase                                                                                                                                                                                                                                                                                                        |
|    |                                                           | 3.4.4                                                                                                   | Terminations 134                                                                                                                                                                                                                                                                                                  |
| 4. | DM/                                                       | ۰                                                                                                       |                                                                                                                                                                                                                                                                                                                   |
|    | 4.2                                                       |                                                                                                         | Operation 120                                                                                                                                                                                                                                                                                                     |
|    | 4.2                                                       | DMA                                                                                                     | Operation                                                                                                                                                                                                                                                                                                         |
|    | 4.2                                                       | 4.2.1                                                                                                   | DMA Register Description                                                                                                                                                                                                                                                                                          |
|    | 4.2                                                       | 4.2.1                                                                                                   |                                                                                                                                                                                                                                                                                                                   |
|    |                                                           | 4.2.1                                                                                                   | DMA Register Description 138                                                                                                                                                                                                                                                                                      |
|    |                                                           | 4.2.1<br>Direct<br>4.3.1                                                                                | DMA Register Description    138      Mode DMA Operation    142                                                                                                                                                                                                                                                    |
|    | 4.3                                                       | 4.2.1<br>Direct<br>4.3.1                                                                                | DMA Register Description       138         Mode DMA Operation       142         Initializing a Direct Mode Operation       142                                                                                                                                                                                    |
|    | 4.3                                                       | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1                                                             | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145                                                                                                                                                                                               |
|    | 4.3<br>4.4                                                | 4.2.1<br>Direct<br>4.3.1<br>Linkec<br>4.4.1<br>DMA                                                      | DMA Register Description       138         Mode DMA Operation       142         Initializing a Direct Mode Operation       142         I-List Mode DMA Operation       145         Initializing a Linked-List Mode Transfer       147                                                                             |
|    | <ul><li>4.3</li><li>4.4</li><li>4.5</li></ul>             | 4.2.1<br>Direct<br>4.3.1<br>Linkec<br>4.4.1<br>DMA                                                      | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149                                                                                                                                       |
|    | <ul><li>4.3</li><li>4.4</li><li>4.5</li></ul>             | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA                                                      | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150                                                                                                                      |
|    | <ul><li>4.3</li><li>4.4</li><li>4.5</li></ul>             | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1                                             | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150                                                                                                     |
|    | <ul><li>4.3</li><li>4.4</li><li>4.5</li></ul>             | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1<br>4.6.1<br>4.6.2                           | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150Processor Bus Error Bit150                                                                           |
|    | <ul><li>4.3</li><li>4.4</li><li>4.5</li></ul>             | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1<br>4.6.2<br>4.6.3                           | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150Processor Bus Error Bit150Source Port Errors150                                                      |
| 5. | <ul><li>4.3</li><li>4.4</li><li>4.5</li><li>4.6</li></ul> | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1<br>4.6.2<br>4.6.3<br>4.6.4<br>4.6.5         | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150Processor Bus Error Bit150Source Port Errors150Destination Port Errors151                            |
| 5. | <ul><li>4.3</li><li>4.4</li><li>4.5</li><li>4.6</li></ul> | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1<br>4.6.2<br>4.6.3<br>4.6.4<br>4.6.5<br>EEPR | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150Processor Bus Error Bit150Source Port Errors150Destination Port Errors151Command Port Errors151      |
| 5. | 4.3<br>4.4<br>4.5<br>4.6                                  | 4.2.1<br>Direct<br>4.3.1<br>Linked<br>4.4.1<br>DMA<br>4.6.1<br>4.6.2<br>4.6.3<br>4.6.4<br>4.6.5<br>EEPR | DMA Register Description138Mode DMA Operation142Initializing a Direct Mode Operation142I-List Mode DMA Operation145Initializing a Linked-List Mode Transfer147Interrupts149Error Handling150PCI Error Bits150Processor Bus Error Bit150Source Port Errors150Destination Port Errors151Command Port Errors151OM153 |

|    | 5.4  | PCI Vital Product Data (VPD)                 | 161   |
|----|------|----------------------------------------------|-------|
| 6. | Arbi | itration                                     | . 163 |
|    | 6.2  | PCI Interface Arbitration                    | 163   |
|    |      | 6.2.1 Arbitration Levels                     | 165   |
|    |      | 6.2.2 Bus Parking                            | 168   |
|    | 6.3  | Processor Bus Arbitration                    | 168   |
|    |      | 6.3.1 Address Bus Arbitration                | 169   |
|    |      | 6.3.2 Data Bus Arbitration                   | 170   |
|    |      | 6.3.3 Address Only Cycles                    | 171   |
|    |      | 6.3.4 PowerSpan II Arbiter and System Boot   | 171   |
| 7. | Inte | errupt Handling                              | . 173 |
|    | 7.2  | Interrupt Sources                            | 173   |
|    |      | 7.2.1 Interrupts from Normal Operations      | 174   |
|    |      | 7.2.2 Interrupts from Transaction Exceptions | 174   |
|    | 7.3  | Interrupt Registers.                         | 175   |
|    |      | 7.3.1 Interrupt Status                       | 177   |
|    |      | 7.3.2 Interrupt Enable                       | 179   |
|    |      | 7.3.3 Interrupt Mapping                      | 181   |
|    | 7.4  | Interrupt Pins                               | 183   |
|    | 7.5  | DMA Interrupts                               | 184   |
|    |      | 7.5.1 DMA Interrupt Servicing                | 184   |
|    | 7.6  | Mailboxes                                    | 185   |
|    | 7.7  | Doorbells                                    | 185   |
| 8. | Erro | or Handling                                  | . 187 |
|    | 8.2  | PB Interface Errors                          | 188   |
|    | 8.3  | PCI Interface Errors                         | 192   |
|    | 8.4  | DMA Errors                                   | 198   |
| 9. | Res  | sets, Clocks and Power-up Options            | . 201 |
|    | 9.1  | Reset                                        | 201   |
|    |      | 9.1.1 Reset Pins                             | 201   |
|    | 9.2  | Clocks                                       | 205   |
|    | 9.3  | Power-Up Options                             | 205   |
|    |      | 9.3.1 Multiplexed System Pin Mode.           | 208   |

|          | 9.3.2   | MPC8260 Configuration Slave Mode 209        |
|----------|---------|---------------------------------------------|
|          | 9.3.3   | Assertion of P1_REQ64# 211                  |
| 10. End  | lian M  | apping                                      |
| 10.2     | Conve   | ntions                                      |
| 10.3     | Proces  | sor Bus and PowerSpan II Register Transfers |
| 10.4     | Proces  | sor Bus and PCI Transfers                   |
|          | 10.4.1  | Big-endian Mode 219                         |
|          | 10.4.2  | Little-endian Mode 221                      |
|          | 10.4.3  | PowerPC Little-endian Mode 223              |
|          | 10.4.4  | True Little-endian Mode 224                 |
| 11. Sig  | nals a  | nd Pinout                                   |
| 11.1     | Signal  | Description                                 |
|          | 11.1.1  | Signal Types 228                            |
|          | 11.1.2  | Processor Bus Signals 229                   |
|          | 11.1.3  | PCI-1 Signals                               |
|          | 11.1.4  | PCI-2 Signals                               |
|          | 11.1.5  | Miscellaneous Signals 242                   |
|          | 11.1.6  | Test Signals                                |
| 11.2     | Dual P  | CI PowerSpan II Pinout                      |
|          | 11.2.1  | Dual PCI PowerSpan II 480 HSBGA246          |
|          | 11.2.2  | 480 HSBGA Pin Information                   |
|          | 11.2.3  | Dual PCI PowerSpan II 504 HSBGA254          |
|          | 11.2.4  | 504 HSBGA Pin Information 256               |
| 11.3     | Single  | PCI PowerSpan II Pin Information            |
|          | 11.3.1  | Single PCI PowerSpan II 420 HSBGA           |
|          | 11.3.2  | 420 HSBGA Pin Information                   |
|          | 11.3.3  | Single PCI PowerSpan II 484 HSBGA 269       |
| 12. Elec | ctrical | and Signal Characteristics                  |
| 12.1     | Electri | cal Characteristics                         |
|          | 12.1.1  | PCI Electrical Characteristics              |
|          | 12.1.2  | Non-PCI Electrical Characteristics          |
| 12.2     | Power   | Dissipation                                 |
| 12.3     | Operat  | ing Conditions                              |

|                  |             | 12.3.1                                                  | Recommended Operating Conditions                                                                                                                                         |
|------------------|-------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |             | 12.3.2                                                  | Handling and Storage Specifications                                                                                                                                      |
|                  |             | 12.3.3                                                  | Absolute Maximum Ratings                                                                                                                                                 |
| 13.              | Reg         | ister I                                                 | Descriptions 283                                                                                                                                                         |
|                  | 13.1        | Registe                                                 | er Access                                                                                                                                                                |
|                  |             | 13.1.1                                                  | Register Map                                                                                                                                                             |
|                  |             | 13.1.2                                                  | Access from PCI                                                                                                                                                          |
|                  |             | 13.1.3                                                  | Access from the Processor Bus                                                                                                                                            |
|                  |             | 13.1.4                                                  | Access from Multiple Interfaces                                                                                                                                          |
|                  | 13.2        | Registe                                                 | er Reset                                                                                                                                                                 |
|                  | 13.3        | Config                                                  | uration and IACK Cycle Generation                                                                                                                                        |
|                  |             | 13.3.1                                                  | From PCI-to-PCI                                                                                                                                                          |
|                  |             | 13.3.2                                                  | From the Processor Bus to PCI                                                                                                                                            |
|                  | 13.4        | Bit Ord                                                 | lering and Endian Ordering 297                                                                                                                                           |
| -                | 13.5        | Registe                                                 | er Descriptions                                                                                                                                                          |
|                  |             | 13.5.1                                                  | PCI-1 ID Register                                                                                                                                                        |
| <b>A.</b> I      | Pack        | age I                                                   | nformation 443                                                                                                                                                           |
| 1                | A.1         | Packag                                                  | e Characteristics                                                                                                                                                        |
|                  |             | A.1.1                                                   | Single PCI PowerSpan II 420 HSBGA                                                                                                                                        |
|                  |             | A.1.2                                                   | Single PCI PowerSpan II 484 HSBGA                                                                                                                                        |
|                  |             | A.1.3                                                   | Dual PCI PowerSpan II 480 HSBGA                                                                                                                                          |
|                  |             | A.1.4                                                   | Dual PCI PowerSpan II 504 HSBGA448                                                                                                                                       |
| 1                | A.2         | Therma                                                  | al Characteristics                                                                                                                                                       |
|                  |             | A.2.1                                                   | Single PCI 420 HSBGA Package                                                                                                                                             |
|                  |             |                                                         |                                                                                                                                                                          |
|                  |             | A.2.2                                                   | Single PCI 484 PBGA Package                                                                                                                                              |
|                  |             | A.2.2<br>A.2.3                                          | Single PCI 484 PBGA Package452Dual PCI 480 HSBGA Package453                                                                                                              |
|                  |             |                                                         |                                                                                                                                                                          |
| В. (             | Orde        | A.2.3<br>A.2.4                                          | Dual PCI 480 HSBGA Package                                                                                                                                               |
|                  | Orde<br>B.1 | A.2.3<br>A.2.4<br>ering l                               | Dual PCI 480 HSBGA Package.453Dual PCI 504 HSBGA Package.454                                                                                                             |
| ]                | B.1         | A.2.3<br>A.2.4<br>ering l<br>Orderin                    | Dual PCI 480 HSBGA Package.453Dual PCI 504 HSBGA Package.454Information.455                                                                                              |
| )<br><b>C.</b> / | B.1         | A.2.3<br>A.2.4<br>ering l<br>Orderin                    | Dual PCI 480 HSBGA Package.  453    Dual PCI 504 HSBGA Package.  454    Information.  455    ng Information  455                                                         |
| )<br>C. /        | B.1<br>AC 1 | A.2.3<br>A.2.4<br>ering l<br>Orderin<br>iming<br>Overvi | Dual PCI 480 HSBGA Package.       453         Dual PCI 504 HSBGA Package.       454         Information.       455         ng Information       455         Q.       457 |

|     | C.4   | Timing Diagrams                                                                    |
|-----|-------|------------------------------------------------------------------------------------|
| D.  | Hare  | dware Implementation477                                                            |
|     | D.2   | Recommended Bootstrap Diode                                                        |
|     | D.3   | PLL External Decoupling                                                            |
|     |       | D.3.1 Backwards Compatible PLL Decoupling for Migrating PowerSpan II<br>Designs478 |
|     |       | D.3.2 PowerSpan II External PLL Decoupling for New Designs 479                     |
| Ε.  | Тур   | ical Applications                                                                  |
|     | E.1   | Overview                                                                           |
|     | E.2   | PowerSpan II and the Processor Bus                                                 |
|     | E.3   | CompactPCI Adapter Card                                                            |
|     | E.4   | CompactPCI Host Card                                                               |
| Gl  | ossa  | ry                                                                                 |
| Inc | dex . |                                                                                    |



# **List of Figures**

| Figure 1:  | PowerSpan II Block Diagram 30                                 |
|------------|---------------------------------------------------------------|
| Figure 2:  | Typical PowerSpan II Application                              |
| Figure 3:  | Non-transparent PCI-to-PCI in CompactPCI Application          |
| Figure 4:  | Concurrent Read Process with PowerSpan II 39                  |
| Figure 5:  | Reads with Conventional FIFO-Based Bridges 40                 |
| Figure 6:  | Concurrent Read Waveform 55                                   |
| Figure 7:  | PowerSpan II in a CompactPCI Adapter Card 69                  |
| Figure 8:  | Hot Swap Insertion                                            |
| Figure 9:  | Hot Swap Extraction                                           |
| Figure 10: | PowerSpan II I2O Message Passing                              |
| Figure 11: | PowerSpan II I2O Pull Capability                              |
| Figure 12: | PowerSpan II I2O Outbound Capability                          |
| Figure 13: | PB Master Interface Burst Read 128                            |
| Figure 14: | PB Master Interface Burst Write                               |
| Figure 15: | PB Master Interface Single Cycle Read 129                     |
| Figure 16: | PB Master Interface Single Cycle Write 130                    |
| Figure 17: | Direct Mode DMA Transfers 144                                 |
| Figure 18: | DMA Command Packet Linked-List                                |
| Figure 19: | Sequence of Operations in a Linked-List Transfer              |
| Figure 20: | Assignment of Additional Bus Requesters with PCI Arbiters 164 |
| Figure 21: | Arbitration Algorithm                                         |
| Figure 22: | PowerSpan II Power-up Waveform                                |
| Figure 23: | PowerSpan II Configuration Slave Timing 210                   |
| Figure 24: | 480 HSBGA                                                     |
| Figure 25: | 504 HSBGA 255                                                 |
| Figure 26: | 420 HSBGA                                                     |

| Figure 27: | 484 PBGA                                               |
|------------|--------------------------------------------------------|
| Figure 28: | 420 HSBGA                                              |
| Figure 29: | 484 PBGA                                               |
| Figure 30: | 480 HSBGA                                              |
| Figure 31: | 504 HSBGA                                              |
| Figure 32: | Power-up Reset: Compact PCI Adapter Scenario           |
| Figure 33: | Power-up Options: Multiplexed System Pin Approach      |
| Figure 34: | Power-up Options: MPC8260 Configuration Slave Approach |
| Figure 35: | Clocking                                               |
| Figure 36: | PCI Timing                                             |
| Figure 37: | PCI Miscellaneous Timing; Compact PCI Adapter Scenario |
| Figure 38: | P1_REQ64_ Assertion Timing                             |
| Figure 39: | Processor Bus Timing                                   |
| Figure 40: | Interrupt Timing                                       |
| Figure 41: | I2C Timing                                             |
| Figure 42: | Bootstrap Diodes for Power-up Sequencing               |
| Figure 43: | PLL Power Filter                                       |
| Figure 44: | PLL Decoupling                                         |
| Figure 45: | PowerSpan II in Multi-processor 60x system             |
| Figure 46: | PowerSpan II in CompactPCI Peripheral Slot             |
| Figure 47: | PowerSpan II in CompactPCI System Slot                 |



# **List of Tables**

| Table 1:  | PowerSpan II Applications                                             |
|-----------|-----------------------------------------------------------------------|
| Table 2:  | PowerSpan II Functional Enhancements 34                               |
| Table 3:  | Signals Involved in PCI Data Width Determination 46                   |
| Table 4:  | Command Encoding for Transaction Type—PowerSpan II as PCI Target 51   |
| Table 5:  | Programming Model for PCI Target Image Control Register 52            |
| Table 6:  | PowerSpan II PCI Target Read Watermarks 57                            |
| Table 7:  | Command Encoding for Transaction Type (PowerSpan II as PCI Master) 62 |
| Table 8:  | PB Writes and Their Corresponding PCI Writes                          |
| Table 9:  | PowerSpan II PCI Master Read Commands 64                              |
| Table 10: | PowerSpan II I20 Target Image Map                                     |
| Table 11: | I2O Outbound Post List Interrupt Status Register                      |
| Table 12: | I2O Outbound Post List Interrupt Mask Register                        |
| Table 13: | I2O Inbound Queue                                                     |
| Table 14: | I2O Outbound Queue                                                    |
| Table 15: | I2O Host Outbound Index Register                                      |
| Table 16: | Programming Model for PB Slave Image Control Register 106             |
| Table 17: | Recommended Memory/Cache Attribute Settings                           |
| Table 18: | PowerSpan II PB Slave Transfer Types 108                              |
| Table 19: | Translation Address Mapping 111                                       |
| Table 20: | PowerSpan II PB Address Parity Assignments 112                        |
| Table 21: | PowerSpan II PB Transfer Sizes 114                                    |
| Table 22: | PowerSpan II Processor Bus Single Beat Data Transfers 115             |
| Table 23: | Read Amount settings 119                                              |
| Table 24: | PowerSpan II PB Data Parity Assignments 120                           |
| Table 25: | Default PowerSpan II PB Master Transfer Type 126                      |
| Table 26: | PowerSpan II PB Address Parity Assignments                            |

| Table 27: | PowerSpan II PB Transfer Sizes                                    |
|-----------|-------------------------------------------------------------------|
| Table 28: | 64-bit PB Data Bus Byte Lane Definitions                          |
| Table 29: | PowerSpan II Processor Bus Single Beat Data Transfers             |
| Table 30: | PowerSpan II PB Data Parity Assignments                           |
| Table 31: | DMA Register Description                                          |
| Table 32: | Programming Model for DMA General Control and Status Register 140 |
| Table 33: | Default PowerSpan II PB Master Transfer Type142                   |
| Table 34: | Programming Model for the Command Packet Contents146              |
| Table 35: | DMA Channel Interrupt Sources and Enables                         |
| Table 36: | Power-up EEPROM Load Sequence                                     |
| Table 37: | Mx_EN Default State                                               |
| Table 38: | Interrupt Register Description                                    |
| Table 39: | Register Description for Interrupt Status Register 0177           |
| Table 40: | Register Description for Interrupt Status Register 1178           |
| Table 41: | Register Description for Interrupt Enable Register 0180           |
| Table 42: | Register Description for Interrupt Enable Register 1              |
| Table 43: | Mapping Definition                                                |
| Table 44: | DMA Channel Interrupt Sources and Enables                         |
| Table 45: | PB Interface Errors                                               |
| Table 46: | PCI Interface Errors                                              |
| Table 47: | PowerSpan II Reset Pins                                           |
| Table 48: | Reset Direction Control Pins                                      |
| Table 49: | PowerSpan II Reset Response                                       |
| Table 50: | PowerSpan II Power-up Options                                     |
| Table 51: | PCI Byte Lane Definitions                                         |
| Table 52: | 64-bit PB Data Bus Byte Lane Definitions                          |
| Table 53: | PowerSpan II Big-Endian PB Register Accesses                      |
| Table 54: | Processor Bus Address Munging 217                                 |
| Table 55: | PowerSpan II PowerPC Little-Endian PB Register Accesses           |
| Table 56: | PowerSpan II Big-endian Mode Byte Lane Mapping                    |
| Table 57: | PowerSpan II Little-endian Mode Byte Lane Mapping 222             |
| Table 58: | PowerSpan II True Little-Endian Byte Lane Mappings                |
| Table 59: | Signal Type Definitions                                           |
| Table 60: | Processor Bus Signals                                             |
| Table 61: | PCI-1 Signals                                                     |

| Table 62: | PCI-2 Signals                                               |
|-----------|-------------------------------------------------------------|
| Table 63: | Miscellaneous Signals                                       |
| Table 64: | Test Signals                                                |
| Table 65: | Package Characteristics                                     |
| Table 66: | Package Characteristics                                     |
| Table 67: | Package Characteristics                                     |
| Table 68: | Package Characteristics                                     |
| Table 69: | HBGA Electrical Characteristics (non-PCI)                   |
| Table 70: | Single PCI PowerSpan II Power Dissipation                   |
| Table 71: | Dual PCI PowerSpan II Power Dissipation279                  |
| Table 72: | Operating and Storage Conditions                            |
| Table 73: | Absolute Maximum Ratings                                    |
| Table 74: | PowerSpan II Register Map 284                               |
| Table 75: | Abbreviations used in Register Descriptions                 |
| Table 76: | PCI 1 ID Register                                           |
| Table 77: | PCI 1 Control and Status Register 301                       |
| Table 78: | PCI 1 Class Register                                        |
| Table 79: | PCI 1 Miscellaneous 0 Register 307                          |
| Table 80: | Read Amount Versus Read Command                             |
| Table 81: | PCI 1 I2O Target Image Base Address Register 309            |
| Table 82: | PCI 1 Register Image Base Address Register                  |
| Table 83: | PCI 1 Target Image X Base Address Register 312              |
| Table 84: | PCI 1 Subsystem ID Register                                 |
| Table 85: | PCI 1 Capability Pointer Register                           |
| Table 86: | PCI 1 Miscellaneous 1 Register                              |
| Table 87: | PCI 1 Compact PCI Hot Swap Control and Status Register 317  |
| Table 88: | PCI 1 Vital Product Data Capability Register                |
| Table 89: | PCI 1 Vital Product Data Register                           |
| Table 90: | PCI 1 Target Image x Control Register 322                   |
| Table 91: | Block Size                                                  |
| Table 92: | Setting for MODE and MEM_IO Bits                            |
| Table 93: | Read Amount                                                 |
| Table 94: | PCI 1 Target Image x Translation Address Register           |
| Table 95: | Arbitration Pin Mapping 329                                 |
| Table 96: | PCI 1 to PCI-2 Configuration Cycle Information Register 330 |

| Table 97:       PCI-2 AD[31:11] lines asserted during Configuration Type 0 cycles       |
|-----------------------------------------------------------------------------------------|
| Table 98:    PCI 1 to PCI-2 Configuration Cycle Data Register                           |
| Table 99:         PCI 1 to PCI-2 Interrupt Acknowledge Cycle Generation Register334     |
| Table 100: PCI 1 Bus Error Control and Status Register    335                           |
| Table 101: PCI 1 Address Error Log Register    336                                      |
| Table 102: PCI 1 Miscellaneous Control and Status Register    337                       |
| Table 103: PCI 1 Bus Arbiter Control Register    339                                    |
| Table 104: Parked PCI Master    341                                                     |
| Table 105: Processor Bus Slave Image x Control Register    342                          |
| Table 106: Block Size                                                                   |
| Table 107: Setting for MODE and MEM_IO Bits    346                                      |
| Table 108: Read Amount         347                                                      |
| Table 109: Processor Bus Slave Image x Translation Address Register    348              |
| Table 110: Translation Address Mapping.    349                                          |
| Table 111: Processor Bus Slave Image x Base Address Register.    350                    |
| Table 112: Processor Bus Register Image Base Address Register                           |
| Table 113: Processor Bus PCI Configuration Cycle Information Register                   |
| Table 114: PCI AD[31:11] lines asserted during Configuration Type 0 cycles 353          |
| Table 115: Processor Bus Configuration Cycle Data Register.    355                      |
| Table 116: Processor Bus to PCI-1 Interrupt Acknowledge Cycle Generation Register . 356 |
| Table 117: Processor Bus to PCI-2 Interrupt Acknowledge Cycle Generation Register . 357 |
| Table 118: Processor Bus Error Control and Status Register    359                       |
| Table 119: Processor Bus Address Error Log.    360                                      |
| Table 120: Processor Bus Miscellaneous Control and Status Register    361               |
| Table 121: Processor Bus Arbiter Control Register    364                                |
| Table 122: Mx_EN Default State    365                                                   |
| Table 123: Parked Processor Bus Master    366                                           |
| Table 124: DMA x Source Address Register    367                                         |
| Table 125: DMA x Destination Address Register    368                                    |
| Table 126: DMA x Transfer Control Register    369                                       |
| Table 127: DMA x Command Packet Pointer Register    371                                 |
| Table 128: DMA x General Control and Status Register    372                             |
| Table 129: DMA x Attributes Register.    376                                            |

| Table 130: Miscellaneous Control and Status Register                | 378 |
|---------------------------------------------------------------------|-----|
| Table 131: Arbitration Pin Mappings.                                | 380 |
| Table 132: Clock Control Register                                   | 381 |
| Table 133:         I2C/EEPROM Interface Control and Status Register | 383 |
| Table 134:    Reset Control and Status Register                     | 385 |
| Table 135: Interrupt Status Register 0                              | 388 |
| Table 136: Interrupt Status Register 1                              | 390 |
| Table 137: Interrupt Enable Register 0                              | 393 |
| Table 138: Interrupt Enable Register 1                              | 395 |
| Table 139: Interrupt Map Register Mail Box                          | 398 |
| Table 140: Mapping Definition                                       | 399 |
| Table 141: Interrupt Map Register Doorbell                          | 400 |
| Table 142: Interrupt Map Register DMA                               | 401 |
| Table 143: Interrupt Map Register Hardware                          | 402 |
| Table 144: Interrupt Map Register PCI 1                             | 404 |
| Table 145: Interrupt Map Register PCI-2.                            | 405 |
| Table 146: Interrupt Map Register Processor Bus                     | 406 |
| Table 147: Interrupt Map Register Two Processor Bus                 | 408 |
| Table 148: Interrupt Map Register Miscellaneous                     | 409 |
| Table 149: Interrupt Direction Register                             | 410 |
| Table 150: Mailbox x Register                                       | 412 |
| Table 151: Semaphore 0 Register.                                    | 413 |
| Table 152: Semaphore 1 Register.                                    | 414 |
| Table 153: PCI I2O Target Image Control Register                    | 415 |
| Table 154: Block Size                                               | 417 |
| Table 155: Read Amount                                              | 418 |
| Table 156: PCI I2O Target Image Translation Address Register        | 420 |
| Table 157: I2O Control and Status Register.                         | 421 |
| Table 158: Host Outbound Post List Size                             | 422 |
| Table 159: I2O Queue Base Address Register                          | 423 |
| Table 160: I2O FIFO Sizes.                                          | 424 |
| Table 161: I2O Inbound Free List Bottom Pointer Register            | 425 |
| Table 162: I2O Inbound Free List Top Pointer Register               | 426 |
| Table 163: I2O Inbound Free List Top Pointer Increment Register     | 427 |
| Table 164: I2O Inbound Post List Bottom Pointer Register            | 428 |
|                                                                     |     |

| Table 165: I2O Inbound Post List Bottom Pointer Increment Register    429      |
|--------------------------------------------------------------------------------|
| Table 166: I2O Inbound Post List Top Pointer Register    430                   |
| Table 167: I2O Outbound Free List Bottom Pointer Register    431               |
| Table 168: I2O Outbound Free List Bottom Pointer Increment Register.       432 |
| Table 169: I2O Outbound Free List Top Pointer Register    433                  |
| Table 170: I2O Outbound Post List Bottom Pointer Register    434               |
| Table 171: I2O Outbound Post List Top Pointer Register    435                  |
| Table 172: I2O Outbound Post List Top Pointer Increment Register.    436       |
| Table 173: I2O Host Outbound Index Offset Register    437                      |
| Table 174: I2O Host Outbound Index Alias Register.    438                      |
| Table 175: I2O IOP Outbound Index Register    439                              |
| Table 176: I2O IOP Outbound Index Increment Register    440                    |
| Table 177: PCI-2 Configuration Registers    441                                |
| Table 178: PCI-2 Target Image Control and Status Registers442                  |
| Table 179: Package Characteristics    443                                      |
| Table 180: Package Characteristics                                             |
| Table 181: Package Characteristics                                             |
| Table 182: Package Characteristics    448                                      |
| Table 183: Thermal Estimate Parameters    451                                  |
| Table 184: 420 HSBGA Package Performance    451                                |
| Table 185: Thermal Estimate Parameters    452                                  |
| Table 186: 484 PBGA Package Performance    452                                 |
| Table 187: Thermal Estimate Parameters    453                                  |
| Table 188: 480 PBGA Package Performance    453                                 |
| Table 189: Thermal Estimate Parameters    454                                  |
| Table 190: 504 PBGA Package Performance    454                                 |
| Table 191: Standard Ordering Information.    455                               |
| Table 192: Reset, and Clock Timing Parameters    458                           |
| Table 193: PCI 33 MHz Timing Parameters    460                                 |
| Table 194: PCI 66 MHz Timing Parameters    461                                 |
| Table 195: PB Timing Parameters    462                                         |
| Table 196: Miscellaneous Timing Parameters    463                              |
| Table 197: Reset, and Clock Timing Parameters    464                           |
| Table 198: PCI 33 MHz Timing Parameters    466                                 |
| Table 199: PCI 66 MHz Timing Parameters    467                                 |

| Table 200: PB Timing Parameters            | . 468 |
|--------------------------------------------|-------|
| Table 201: Miscellaneous Timing Parameters | . 469 |



# **About this Document**

This chapter discusses general document information about the PowerSpan II *User Manual*. The following topics are described:

- "Revision History" on page 25
- "Document Conventions" on page 26
- "Related Documents" on page 28

## Revision History 80A1010\_MA001\_05, Final, November 2002

The Single PCI PowerSpan II has reached production status. This manual represents the production information for the Single PCI PowerSpan II.

80A1010\_MA001\_04, Preliminary, April 2002 80A1010\_MA001\_03, Advance, July 2001 80A1010\_MA001\_02, Advance, May 2001 80A1010\_MA001\_01, Advance, May 2001

## **Document Conventions**

This section explains the document conventions used in this manual.

### **Signal Notation**

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.

For voltage levels, the use of 0 indicates a low voltage while a 1 indicates a high voltage. For voltage levels, the use of 0 indicates a low voltage while a 1 indicates a high voltage.

Each signal that assumes a logic low state when asserted is followed by an underscore sign, "\_". For example, SIGNAL\_ is asserted low to indicate an active low signal. Signals that are not followed by an underscore are asserted when they assume the logic high state. For example, SIGNAL is asserted high to indicate an active high signal.

## **Bit Ordering Notation**

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. However, this device enables endian conversion and endian-ness is a programmable feature.

## **Object Size Notation**

The following object size conventions are used:

- A *byte* is an 8-bit object.
- A word is a 16-bit (2 byte) object.
- A *doubleword* is a 32-bit (4 byte) object.
- A quadword is a 64-bit (8 byte) object.
- A *Kword* is 1024 16-bit words.

### **Numeric Notation**

The following numeric conventions are used:

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

## **Typographic Notation**

The following typographic conventions are used in this manual:

- *Italic* type is used for the following purposes:
  - Book titles: For example, PCI Local Bus Specification.
  - 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 four channels 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 load.exe by typing it at a command prompt."

## Symbols Used

The following symbols are used in this manual.



This symbol indicates a basic design concept or information considered helpful.



This symbol indicates important configuration information or suggestions.



This symbol indicates procedures or operating levels that may result in misuse or damage to the device.

## **Document Status Information**

Tundra technical documentation is classified as either Advance, Preliminary, or Final:

- Advance: The Advance manual contains information that is subject to change and exists until prototypes are available. This type of manual can be downloaded from our website at www.tundra.com.
- Preliminary: The Preliminary manual contains information about a product that is near production-ready, and is revised as required. The Preliminary manual exists until the product is released to production. This type of manual can be downloaded from our website at www.tundra.com.
- Final: The Final manual contains information about a final, customer-ready product. This type of manual can be downloaded from our website. It can also be ordered in print format by calling 613-592-0714 or 1-800-267-7231 (please ask for customer service), or by email at docs@tundra.com.

## **Related Documents**

The following documents are useful for reference purposes when using this manual.

| PCI Local Bus Specification<br>(Revision 2.2)                         | This specification defines the PCI hardware<br>environment including the protocol, electrical,<br>mechanical and configuration specification for<br>the PCI local bus components and expansion<br>boards. For more information, see<br>www.pcisig.com.                                                                            |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI-to-PCI Bridge Architecture<br>Specification (Revision 1.1)        | This specification establishes the minimum<br>behavioral requirements that PCI-to-PCI<br>bridges must meet to be compliant to the PCI<br>Local Bus Specification. Recommendations and<br>guidance on optional PCI-to PCI bridge features<br>are also provided by this specification. For more<br>information, see www.pcisig.com. |
| PCI Bus Power Management<br>Interface Specification<br>(Revision 1.1) | This specification defines power management<br>capabilities that enhance the base PCI<br>architecture. For more information, see<br>www.pcisig.com.                                                                                                                                                                               |
| CompactPCI Hot Swap<br>Specification (Revision 2.0)                   | This specification defines a process for<br>installing and removing CompactPCI boards<br>without adversely effecting a running system.<br>For more information, see www.picmg.com.                                                                                                                                                |
| I <sup>2</sup> C Specification                                        | This specification defines the standard I2C bus<br>interface, including specifications for all the<br>enhancements. For more information, see<br>www-eu2.semiconductors.com/i2c.                                                                                                                                                  |



## **1. Functional Overview**

This chapter describes the PowerSpan II's architecture. The following topics are discussed:

- "PCI Interface" on page 35
- "Processor Bus Interface" on page 37
- "DMA Controller" on page 38
- "I2C / EEPROM" on page 38
- "Concurrent Reads" on page 38

## 1.1 Overview

The Tundra PowerSpan II is a PowerPC-to-PCI Bus Switch that bridges PCI to the PowerQUICC II (MPC8260, and MPC8260A), MPC7400, MPC7410, PowerPC 7400, PowerPC 750, PowerPC 740, and PowerPC 603e processors. PowerSpan II is available in either single PCI or dual PCI variants. PowerSpan II defines a new level of PCI bus switch flexibility.

The integrated, non-transparent PCI-to-PCI bridge in the Dual PCI PowerSpan II provides a significant opportunity for designers to reduce component count and increase overall system performance.

PowerSpan II offers a flexible package design. The design is available in both the original PowerSpan II package dimensions and newly designed, smaller packages.

The high level of performance and flexibility of PowerSpan II is made possible through *Switched PCI* - unique to PowerSpan II. Switched PCI uses a switching fabric to enable data streams to pass from port-to-port across the multi-ported PowerSpan II without collision. This improves the burst performance and decreases latency on the PCI and processor busses — a key element of I/O processor performance.

PowerSpan II is also part of a chipset offering with the Tundra PowerPC Memory Controller — PowerPro. When PowerSpan II is in a application with both PowerPro and the MPC8260, PowerPro can be configured to implement ECC protection in the system. Please refer to the *PowerPro PowerPC Memory Controller Manual* for more information



#### Figure 1: PowerSpan II Block Diagram

### 1.1.1 PowerSpan II Features

PowerSpan II has the following features:

#### 1.1.1.1 Processor Support

- Direct connect interface for embedded PowerPC processors MPC8260, MPC8260A, MPC74xx, PowerPC 7400, PowerPC 740, and PowerPC 750
- 25 MHz-to-100 MHz bus frequency
- Programmable endian conversion
- MPC8260 Configuration Slave support for power-up options
- Eight programmable memory maps to PCI from the processor
- Processor bus arbiter with support for three requesters

### 1.1.1.2 PCI Support

- Dual PCI PowerSpan II:
  - One 32-bit or 64-bit PCI interface
  - One 32-bit interface
  - 66 MHz operation
- Single PCI PowerSpan II:
  - One 32-bit or 64-bit PCI interface
  - 66 MHz operation
- Integrated, non-transparent PCI-to-PCI bridge in the Dual PCI PowerSpan II
- PCI arbiters on each PCI interface
- CompactPCI Hot Swap Friendly
- PCI 2.2 Specification compliant

### 1.1.1.3 Packaging options

- Single PCI PowerSpan II (CA91L8260B)
  - 64-bit/66MHz
  - 420 HSBGA: 1.27mm ball pitch, 35mm body size
  - 484 PBGA: 1.0mm ball pitch, 23mm body size
- Dual PCI PowerSpan II (CA91L8200B)
  - 32-bit/66MHz and 64-bit/66MHz

- 480 HSBGA: 1.27mm ball pitch, 37.5mm body size
- 504 HSBGA: 1.0mm ball pitch, 27mm body size

### 1.1.2 PowerSpan II Benefits

PowerSpan II offers the following benefits to designers:

- Smaller packages reduce board area required for system design.
- Integrated PCI bus, processor bus arbiters decrease individual component count on boards.
- Flexible PCI interfaces enable PowerSpan II to meet many different application requirements.
- Integrated, non-transparent PCI-to-PCI bridge connects traffic between the two PCI interfaces. This decreases individual component count and simplifies conventional CompactPCI board architecture.
- Supports reads from multiple I/O devices in parallel, non-blocking streams which decreases bus latency.
- The Tundra PowerQUICC II and PowerPC architecture expertise is passed to customers with the Design Support Tools. Tundra offers a complete package of Design Support Tools including software, schematics, and evaluation board. For more information refer to www.tundra.com.
- Detailed design documentation including device manuals, and application notes.

## 1.1.3 Typical Applications

Tundra understands vendors' needs to increase performance throughout today's communications networks. From premise equipment to local carrier gear to highend switches, designer's need to deliver ever-faster traffic through the same or smaller footprint at a reduced cost. Tundra System Interconnect helps in that effort by providing features and benefits across all areas of the network. PowerSpan II helps designers working on infrastructure equipment in the following areas:

#### Table 1: PowerSpan II Applications

| LAN/WAN                                 | Remote/Local Access | Wireless                               |
|-----------------------------------------|---------------------|----------------------------------------|
| Exchange Carrier Switching<br>Equipment | ADSL Concentrators  | Third Generation (3G) Base<br>Stations |
| Ethernet Switches                       | VoIP Gateways       |                                        |
| MPEG 2 Encoders                         | VPN Equipment       |                                        |

PowerSpan II is a very flexible device. The following diagram shows a typical PowerPC system architecture using PowerQUICC II and the Dual PCI PowerSpan II.

### Figure 2: Typical PowerSpan II Application



## 1.1.4 PowerSpan II and PowerSpan Differences Summary

The following table summarizes the main PowerSpan II programmable features that were unavailable in the PowerSpan device. All functional enhancements are programmable in order to make sure that all original PowerSpan functionality can be exercised. For detaill information, please refer to the PowerSpan II *and PowerSpan Differences Summary* available on the Tundra website at www.tundra.com..

### Table 2: PowerSpan II Functional Enhancements

| Functional Enhancement Descriptions                                                                                                                                                                                                                                                                                                                                                       | See                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Packaging Change<br>Packaging has been changed from HPBGA packages to HSBGA packages. Four<br>variants are available for PowerSpan II: two variants for the Single PCI<br>PowerSpan II and two variants for the Dual PCI PowerSpan II. Both the Single and<br>Dual PCI PowerSpan II have packages, signals, and pins that are backwards<br>compatible with the original PowerSpan device. | "Electrical and<br>Signal<br>Characteristics" on<br>page 277 and<br>"Package<br>Information" on<br>page 443                     |
| New Revision ID<br>PowerSpan II has a new ID.                                                                                                                                                                                                                                                                                                                                             | "Register<br>Descriptions" on<br>page 283                                                                                       |
| Read implementation<br>PowerSpan II supports 4 byte transactions.                                                                                                                                                                                                                                                                                                                         | "PCI Interface" on<br>page 43,<br>"Processor Bus<br>Interface" on<br>page 101, and<br>"Register<br>Descriptions" on<br>page 283 |
| True Little-endian Mode<br>A new endian mode was developed for PowerSpan II                                                                                                                                                                                                                                                                                                               | "Endian Mapping"<br>on page 213, and<br>"Register<br>Descriptions" on<br>page 283                                               |
| Base Address Implementation<br>PowerSpan II supports a PCI base address of 0x00000.                                                                                                                                                                                                                                                                                                       | "Register<br>Descriptions" on<br>page 283                                                                                       |
| Maximum Retry Counter Modification<br>The maximum retry counter is programmable in PowerSpan II                                                                                                                                                                                                                                                                                           | "Register<br>Descriptions" on<br>page 283                                                                                       |

| Functional Enhancement Descriptions                                                                                                                                          | See                                                                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Arbitration Timing for Masters<br>PowerSpan II measures the length of time it takes a master to respond to the GNT#<br>signal.                                               | "Arbitration" on<br>page 163 and<br>"Register<br>Descriptions" on<br>page 283                |
| PowerPC 7400 Transaction Support<br>PowerSpan II has been designed to support specific PowerPC 7400 misaligned<br>transactions.                                              | "Processor Bus<br>Interface" on<br>page 101 and<br>"Register<br>Descriptions" on<br>page 283 |
| Delay Sampling of Transaction Start Signal<br>The PowerSpan II PB arbiter can be programmed to sample requests two clocks<br>after the PB_TS_ signal is asserted.            | "Arbitration" on<br>page 163 and<br>"Register<br>Descriptions" on<br>page 283                |
| Programmable DMA Block Size<br>PowerSpan II enables programmable DMA block sizes.                                                                                            | "DMA" on page 137<br>and "Register<br>Descriptions" on<br>page 283                           |
| PB Arbiter Qualifies Bus Grants<br>The PowerSpan II PB Arbiter can be programmed to qualify data bus grants before<br>issuing data bus grants.                               | "Arbitration" on<br>page 163 and<br>"Register<br>Descriptions" on<br>page 283                |
| Target Fast Back to Back Capable (TFBBC)<br>The default setting of this bit was changed to 0 in PowerSpan II; the device does<br>not support fast back-to-back transactions. | "Register<br>Descriptions" on<br>page 283                                                    |

### **Table 2: PowerSpan II Functional Enhancements**

## 1.2 PCI Interface

PowerSpan II is available as a Single PCI PowerSpan II or Dual PCI PowerSpan II. A 64-bit PCI Interface is available on both variants; the Dual PCI PowerSpan II has a 32-bit PCI Interface in addition to the 64-bit PCI Interface. In both cases, the PCI Interfaces on the PowerSpan II support 66MHz operation and are asynchronous to the other interfaces on the device.

The PCI interfaces are PCI 2.2 Specification compliant.

# 1.2.1 PCI-to-PCI Bridge

The Dual PCI PowerSpan II is a PCI-to-PCI bridge. It connects traffic between the two PCI interfaces. This PCI-to-PCI bridging function is "non-transparent". In a non-transparent bridge one PCI bus is hidden from system BIOS running in the other PCI domain. Memory and I/O transfers pass freely between the PCI interfaces, but Configuration accesses are filtered.

The application is shown in Figure 3.



#### Figure 3: Non-transparent PCI-to-PCI in CompactPCI Application

One or More Local I/O Controllers (for example, gigabit ethernet, IEEE 1394)

Because of the non-transparent PCI-to-PCI bridging, the MPC8260 on the CompactPCI adapter card acts as local host without the local PCI devices being configured by the CompactPCI system host.

# 1.2.2 Primary PCI Interface

The PowerSpan II provides extra functionality for one of the PCI interfaces. The PCI Interface assigned extra functionality must be specified as Primary PCI Interface through a power-up option.

The Primary PCI Interface functions are:

CompactPCI Hot Swap Friendly support

- *I*<sub>2</sub>*O* 2.0 *Specification* compliant messaging
- Vital Product Data support.



This extra functionality is available for the Single PCI PowerSpan II and the Dual PCI PowerSpan II.

# 1.2.3 PCI Host Bridge

PowerSpan II is designed for host bridge applications. The PowerPC processor generates configuration cycles on the PCI bus in the same way as that found in conventional PCI host bridges. In addition, with concurrent reads and low device latency, the PCI Target Interface on PowerSpan II is specifically designed to allow low latency access to host packet memory for I/O controllers on either of the PCI buses.

#### 1.2.4 PCI Bus Arbitration

Each PCI Interface has an integrated PCI bus arbiter. Each arbiter supports four external bus requesters. An additional three bus requesters can be assigned between the two PCI arbiters.

The PCI arbiters implement a fairness algorithm, two round robin priority levels and flexible bus parking options.

# 1.3 **Processor Bus Interface**

The PowerSpan II provides a direct-connect 64-bit interface for the PowerQUICC II (MPC8260, and MPC8260A), MPC7400, MPC7410, PowerPC 7400, PowerPC 750, PowerPC 740, and PowerPC 603e processors. The direct-connect support for these interfaces has been extensively verified during product development with processor functional models as well as with a hardware emulation methodology. This verification ensures any potential interface issues are identified and resolved by Tundra Semiconductor before PowerSpan II customers begin to design their own systems.

PowerSpan II supports MPC8260 extended cycles on the Processor Bus Interface. Extended cycle support on the MPC8260 means more flexible bursting and more efficient use of the processor bandwidth.

# 1.3.1 Address Decoding

Instead of consuming chip selects from the MPC8260, PowerSpan II performs its own address decoding for up to eight memory (slave) images to the PCI bus from the processor bus. This allows a flexible mapping of processor transactions to PCI cycle types.

# 1.3.2 Processor Bus Arbitration

The Processor Bus Interface has an integrated bus arbiter. The Processor Bus Interface supports three external bus masters for applications involving multiple processors. The processor bus arbiter implements two levels of priority, where devices programmed into a specific priority level operate in a round robin fashion in that level.

# 1.4 DMA Controller

PowerSpan II provides four independent, bidirectional DMA channels. Each DMA channel is capable of Linked-List or Direct mode transfers.

Each DMA channel transfers data from any-port to any-port. For example, from PCI-1 to PCI-2, Processor Bus to PCI-1, or Processor Bus and Processor Bus. High throughput data transfer is coupled by flexible endian mapping and a range of status bits mappable to external interrupts.

# 1.5 I<sup>2</sup>C / EEPROM

# 1.5.1 EEPROM

PowerSpan II registers can be programmed by data in an EEPROM at system reset. This enables board designers to set unique identifiers for their cards on the PCI bus at reset, and set various image parameters and addresses. Configuring PowerSpan II with the EEPROM allows PowerSpan II to boot-up as a Plug and Play compatible device. PowerSpan II supports reads from, and writes to, the EEPROM.

# 1.5.2 I<sup>2</sup>C

PowerSpan II has a master only  $I^2C$  bus compatible interface which supports up to eight  $I^2C$  slave devices. This interface is used by PowerSpan II for the initialization of registers and for reading and writing PCI Vital Product Data (VPD).

PowerSpan II also provides a mechanism to perform master read and write operations to EEPROMs or other I<sup>2</sup>C compatible slave devices.

# 1.6 Concurrent Reads

PowerSpan II's Switched PCI architecture enables concurrent reads through a single channel. This ability greatly reduces read latency, which is often the limiting factor in PCI performance.

## 1.6.1 PowerSpan II's Concurrent Read Solution

With PowerSpan II's concurrent reads, read requests are accepted even while the current read is in progress. Figure 4 illustrates the concurrent read process with the PowerSpan II.



#### Figure 4: Concurrent Read Process with PowerSpan II

When Master 2 makes its first read request in Step 2, it is retried but information about the read request is latched and initiates a read on the other bus. This occurs even though a read is in progress for Master 1.

PowerSpan II can simultaneously support two reads to the Processor Bus and two reads to the PCI bus.

#### 1.6.1.1 Conventional Reads and Retries

In conventional FIFO-based bridge architectures, bus masters must take turns for read opportunities and incur multiple retries while waiting. Figure illustrates the read process for subsequent reads where retries are incurred while a pending read is completed.





When Master 2 is retried in Step 2, no information is latched about the read request. When Master 2 returns for a subsequent read request in Step 4, it is treated by the bridge as the first read request.

# 1.6.2 PowerSpan II's Concurrent Read Applications

#### 1.6.2.1 PCI Host Bridge

In a PCI host bridge application, all of the PCI masters — for example, I/O controllers — potentially receive only one retry before receiving read data. Even with another read pending, when the PCI Target Interface of the PCI host device receives a read request, it latches the information and begins another burst read prefetch on the processor bus. The PCI host bridge latches the addresses and delivers the data to each master using separate, dedicated buffering. This approach greatly reduces the overall system latency and allows for a more scalable I/O subsystem.

#### 1.6.2.2 Adapter Card

In an adapter card application, the read latency problem is a mirror image of a PCI host bridge application. In an adapter card, the MPC8260 serial ports (FCCs) may be expected to transfer bit streams through the MPC8260/PCI to host memory across the PCI bus. In this case, there can be eight separate FCCs potentially contending for the processor slave interface in the PCI bridge — assuming there are two MPC8260s on the local bus. This architecture adds considerable latencies to read transactions because of FCCs attempting reads to host memory across the PCI bus. Ideally, each FCC would have a dedicated channel to the PCI bus so they do not have to share resources.

PowerSpan II supports this ideal situation through its concurrent reads in a flexible switching architecture. The PCI bridge latches information about the local read as it receives the read request even with reads pending. The FCCs can now receive transmit data from system host memory with far lower latencies.

#### 1. Functional Overview



# 2. PCI Interface

Peripheral Component Interconnect (PCI) is a bus protocol that defines how devices communicate on a peripheral bus and with a host processor. If a device is referred to as PCI compliant it must be compliant with the *PCI Local Bus Specification* (*Revision 2.2*). A PCI bus supports frequencies up to 66 MHz, and 32-bit or 64-bit transfers.

This chapter describes the PCI Interface of the Dual PCI PowerSpan II. The following topics are discussed:

- "Overview" on page 43
- "PCI Target Interface" on page 50
- "PCI Master Interface" on page 60
- "CompactPCI Hot Swap Silicon Support" on page 67
- "Vital Product Data" on page 75
- "I2O Shell Interface" on page 77

# 2.1 Overview

This chapter describes the functionality of the Dual PCI PowerSpan II. The Single PCI PowerSpan II is identified when its functionality or settings differ from the Dual PCI PowerSpan II.

The Single PCI PowerSpan II and the Dual PCI PowerSpan II have different characteristics. The features of each device are shown in the following list.

- Dual PCI PowerSpan II:
  - One 32-bit or 64-bit PCI interface

- One 32-bit interface
- 66 MHz operation
- Single PCI PowerSpan II:
  - One 32-bit or 64-bit PCI interface
  - 66 MHz operation

#### 2.1.1 Primary PCI

The Dual PCI PowerSpan II has two PCI interfaces: the PCI-1 Interface and the PCI-2 Interface. PCI-1 interface is 32-bit or 64-bit capable, while the PCI-2 Interface is 32-bit. Both PCI interfaces have 66 MHz capability.

There are two settings available for the Dual PCI PowerSpan II: Primary PCI Interface and Secondary PCI Interface. The Primary PCI Interface adds extra functionality to the PCI Interface that is designated as the Primary PCI Interface. The Secondary PCI Interface has no extra functionality.

The following features are associated with the Primary PCI Interface:

- CompactPCI Hot Swap Support (see "CompactPCI Hot Swap Silicon Support" on page 67)
- Vital Product Data (see "Vital Product Data" on page 75)
- I<sub>2</sub>O Shell Interface (see "I2O Shell Interface" on page 77)



The Primary PCI Bus (PRI\_PCI) bit in the "Reset Control and Status Register" on page 385 is always 0 in the Single PCI PowerSpan II.

Either the PCI-1 Interface (64-bit) or the PCI-2 Interface (32-bit) can be configured as the Primary Interface. The selected PCI interface is assigned as the Primary PCI Interface through the Primary PCI Select (PWRUP\_PRI\_PCI) power-up option (see "Resets, Clocks and Power-up Options" on page 201 for more information). Primary PCI functionality is shown in the value of the Primary PCI Bus (PRI\_PCI) bit in the "Reset Control and Status Register" on page 385. The PRI\_PCI is a status bit and only shows which bus is primary. It does not enable a bus as the Primary PCI Interface. The Primary PCI interface is enabled with a power-up option (see 9. "Resets, Clocks and Power-up Options" on page 201).

#### 2.1.1.1 Clock Frequencies

Each of the PCI interfaces, PCI-1 and PCI-2, run at frequencies from 25 MHz to 66 MHz. The DEV66 bit in the "PCI 1 Control and Status Register" on page 301 indicates that PowerSpan II is a 66 MHz-capable device.

The speed of these buses is determined through a power-up option (see "Clocks" on page 205 and "Power-Up Options" on page 205) using the corresponding P1\_M66EN pins.

Both PCI interfaces run asynchronously to one another, and asynchronously to the Processor Bus Interface.

# 2.1.2 PCI Data Width

The PCI-1 Interface is a 64-bit data interface that supports 32-bit addressing. The PCI-2 Interface is a 32-bit data interface that supports 32-bit addressing.

#### 2.1.2.1 PowerSpan II in non-Hot Swap and PCI Host Applications

The PCI-1 Interface can be programmed to assert P1\_REQ64# to indicate the data width of the PCI-1 bus at reset. This feature is controlled by the PWRUP\_P1\_R64\_EN power-up option (see "Power-Up Options" on page 205) and minimizes required external logic. A logic low applied to P1\_64EN# enables this feature. PowerSpan II drives P1\_REQ64# when PWRUP\_P1\_R64\_EN is selected and P1\_64EN# is set to 0.

When P1\_64EN# is at a logic low, and PWRUP\_P1\_R64\_EN is selected, P1\_REQ64# is asserted low during reset. The status of PWRUP\_P1\_R64\_EN is reflected in the P1\_R64\_EN bit in the "Reset Control and Status Register" on page 385.



This feature must only be used in systems where PowerSpan II controls both P1\_REQ64# and P1\_RST#. In this scenario, PowerSpan II is the Central Resource in the system and can ensure that timing parameters are satisfied.

#### 2.1.2.2 PowerSpan II in non-Hot Swap and PCI Peripheral Applications

The PCI-1 Interface supports the following mechanisms for determining the width of the PCI-1 datapath:

- sampling P1\_REQ64# at the negation of P1\_RST#
- logic level on P1\_64EN#

In non-Hot Swap applications, the P1\_64EN# signal must be pulled high in order to enable sampling of P1\_REQ64# to determine the width of the data path. The result of the sampling of P1\_REQ64# is or'd with the logic level on P1\_64EN# to determine data path width (see Table 3).

| Signal    |          |            |
|-----------|----------|------------|
| P1_REQ64# | P1_64EN# | Result     |
| 0         | 0        | 64-bit bus |
| 1         | 0        | 64-bit bus |
| 0         | 1        | 64-bit bus |
| 1         | 1        | 32-bit bus |

 Table 3: Signals Involved in PCI Data Width Determination

#### 2.1.2.3 PowerSpan II in Hot Swap Applications

In Hot Swap applications the P1\_64EN# signal is the only signal sampled to indicate the PCI data width. The following scenarios can be used for determining the proper implementation of the P1\_REQ64# and P1\_64EN# signals:

- PCI bus is currently a 32-bit slot and the Hot Swap board is 64-bit capable. In this case, P1\_REQ64# is pulled up in the slot and P1\_64EN# is OPEN and the card will initialize in 32-bit mode.
- PCI bus is currently a 32-bit slot and the Hot Swap board is 32-bit capable. In this case, P1\_REQ64# is not sampled and P1\_64EN# does not exist on the board so initialization would be 32-bit mode.
- PCI bus is currently a 64-bit slot and the Hot Swap board is 64-bit capable. In this case, P1\_REQ64# could be anything but P1\_64EN# is GND and the card will initialize in 64-bit mode.
- PCI bus is currently a 64-bit slot and the Hot Swap board is 32-bit capable. In this case, P1\_REQ64# is not sampled and P1\_64EN# does not exist on the board so initialization would be 32-bit mode.

#### 2.1.2.4 PowerSpan II Drives PCI 64-bit Extension Signal in 32-bit Environment

When PowerSpan II's 64-bit PCI interface is programmed to operate in 32-bit mode, the 64-bit extension PCI bus signals can be left open. PowerSpan II actively drives the following the input signals:

- Driven Low
  - P1\_AD[63:32]

- P1\_CBE[7:4]
- P1\_REQ64#
- P1\_ACK64#
- P1\_PAR64
- P1\_AD[63:32]
- P1\_CBE[7:4]
- P1\_PAR64
- Driven High
  - P1\_REQ64#
  - P1\_ACK64#

This insures the signals do not oscillate and that there is not a significant power drain through the input buffer.

# 2.1.3 PCI Interface Descriptions

The PowerSpan II PCI interfaces are described in terms of its PCI master and PCI target functions. This description is largely independent of PCI-1 versus PCI-2, or the assignment of the Primary PCI Interface functions. Exceptions to these rules are noted as required.



Cross-references to PCI registers are shown as PCI-1 whenever the cross-references apply equally to PCI-1 or PCI-2 registers.

# 2.1.4 Transaction Ordering

PowerSpan II implements a set of ordering rules for transactions initiated by master(s) connected to PCI Interface Px, that are destined for targets and/or slaves connected to PCI Interface Py.



Transactions initiated by master(s) connected to PCI Interface Px, but with different PowerSpan II destination interfaces, are independent from an ordering perspective. Transactions initiated by PowerSpan II DMA and PowerSpan II generated interrupt events have no ordering relationship to externally initiated transactions processed by PowerSpan II.

#### 2.1.4.1 Transactions Between Px and Py

PowerSpan II implements the following transaction ordering rules for transactions flowing between PCI Interface Px and PCI Interface Py:

- The order in which delayed read requests are latched on the source bus, and posted memory write transactions are presented on the source bus, is the order in which they appear on the destination bus.
- Writes flowing from Px to Py have no ordering relationship to writes flowing from Py to Px.
- The acceptance of a posted write as a target or slave is not contingent on the completion of a transaction by the master of the same interface. PowerSpan II master and target/slave modules are independent.

#### 2.1.4.2 Transactions Between the PB Interface and the PCI Interfaces

When there are transactions to the PB Interface from both PCI-1 and PCI-2, there is a possibility that a transaction from PCI-2 can be queued ahead of a transaction from

PCI-. This is caused by the fact there is no transaction ordering between the two independent PCI interfaces. For example, if transactions to the PB Interface arrive in the following order from PCI-1 and PCI-2:

- PCI-1 Write 1
- PCI-2 Write 1
- PCI-2 Write 2
- PCI-1 Write 2

The transactions can be completed to the PB Interface in the following order even though PCI-2 Write 2 entered PowerSpan II before PCI-1 Write 2:

- PCI-1 Write 1
- PCI-2 Write 1
- PCI-1 Write 2
- PCI-2 Write 2

This is caused by the fact that PCI-1 to PB Interface transactions and PCI-2 to PB Interface transactions arbitrate in a round robin fashion. When a PowerSpan II decision is required on whether to service a transaction from PCI-1 or PCI-2, writes are available at both even though at one point a write is only available from PCI-2.

#### 2.1.4.3 DMA Transactions

DMA transactions and regular write/read transactions arbitrate for the use of a master interface in a round robin scheme. There are no special priorities for DMA transactions and regular write/read transactions.

Writes and reads from one source are queued and arbitrated for the use of the master interface with DMA in a round robin design. A DMA transaction can be given a lower priority by programming the DMA Channel Off Counter (OFF) bit in the DMA Control and Status register (see page 372). The OFF bit provides programmable control over the amount of source bus traffic generated by the DMA channel. The channel interleaves source bus transfers with a period of idle processor bus clocks where no source bus requests are generated. When source and destination interfaces are different, 256 bytes of source bus traffic occurs before the idle period. If source and destination interfaces are the same, 64 bytes of source bus traffic occur before the idle period. This helps prevent PowerSpan II from interfering with processor bus instruction fetches.

All transactions (writes/reads/DMA) from two source interfaces arbitrate in a round robin scheme on a per interface basis. Refer to "Transactions Between the PB Interface and the PCI Interfaces" on page 48 for more information.

#### 2.1.4.4 PCI Transaction Ordering Rules

The *PCI 2.2 Specification* outlines transaction ordering rules for PCI transactions. PowerSpan II does not comply with the following PCI transaction ordering rules:

- PowerSpan II only completes the writes that are destined for the same bus as the initiated read when it is processing a read request. It does not complete writes in both directions before processing a read request. PowerSpan II does not prioritize writes over reads.
- PowerSpan II does not allow posted memory writes to pass delayed read requests. This implies that deadlock conditions may occur when the customer uses bridges that do not support delayed transactions. Deadlock conditions are broken by the PowerSpan II maximum retry counter.

# 2.2 PCI Target Interface 2.2.1 PowerSpan II as PCI Target

PowerSpan II participates in a transaction as a PCI target when a PCI master initiates one of the following actions:

- attempts to access the alternate PCI Interface
- attempts to access processor bus memory
- accesses PowerSpan II registers

This chapter describes only the first two conditions listed above. Transactions targeted for the PowerSpan II's 4 Kbytes of device control and status registers are discussed in "Register Access" on page 283.

The operation of the PCI Target is described by dividing the PCI transaction into the following phases:

- Address Phase: This section discusses the decoding of PCI accesses.
- **Data Transfer**: This section describes control of burst length and byte lane management.
- **Terminations**: This section describes the terminations supported by the PowerSpan II, how they are mapped from the destination port to the PCI Target, and exception handling.

# 2.2.2 Address Phase

#### 2.2.2.1 Transaction Decoding

Transaction decoding on the PCI Target operates in both normal decode mode and Master-based decode mode. Only memory and configuration cycles are decoded. I/ O cycles are not decoded.

During normal decode mode, a PCI device monitors the Px\_AD and Px\_C/BE# lines to decode an access to some programmed PCI physical address range — through positive decoding.

A PCI target image is defined as the range of PCI physical address space to decode a PCI transaction. A PCI target image location and size is controlled using a Base Address field in the "PCI 1 Target Image X Base Address Register" on page 312, and a Block Size field in the "PCI 1 Target Image x Control Register" on page 322.



Normal address decoding only applies to memory cycles.

Table 4 illustrates the command encoding for PowerSpan II as PCI target.

| Px_C/BE#[3:0] | Transaction Type            | PowerSpan II Capable    |
|---------------|-----------------------------|-------------------------|
| 0000          | Interrupt Acknowledge       | No                      |
| 0001          | Special Cycle               | No                      |
| 0010          | I/O Read                    | No                      |
| 0011          | I/O Write                   | No                      |
| 0100          | Reserved                    | N/A                     |
| 0101          | Reserved                    | N/A                     |
| 0110          | Memory Read                 | Yes                     |
| 0111          | Memory Write                | Yes                     |
| 1000          | Reserved                    | N/A                     |
| 1001          | Reserved                    | N/A                     |
| 1010          | Configuration Read          | Yes (Type 0 only)       |
| 1011          | Configuration Write         | Yes (Type 0 only)       |
| 1100          | Memory Read Multiple        | Yes                     |
| 1101          | Dual Address Cycle          | No                      |
| 1110          | Memory Read Line            | Yes                     |
| 1111          | Memory Write and Invalidate | Aliased to Memory Write |

# Table 4: Command Encoding for Transaction Type—PowerSpan II as PCITarget

The PCI target image decodes and claims PCI transactions and controls how these incoming PCI transactions are mapped to the destination port on PowerSpan II.

Table 5 describes the programming model for a PCI Target Image Control register.

Table 5: Programming Model for PCI Target Image Control Register

| Bits     | Туре | Description                                                                                                                                                                                                                                                                                                        | Default Setting                                                                                       |
|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| IMG_EN   | R/W  | Enables the PCI target image to decode in the specified physical address range of memory space.                                                                                                                                                                                                                    | Disabled                                                                                              |
| TA_EN    | R/W  | Enables address translation (see "PCI 1 Target<br>Image x Translation Address Register" on<br>page 328).                                                                                                                                                                                                           | Disabled                                                                                              |
| BAR_EN   | R/W  | Enables the PCI Base Address register. When<br>this bit is set, the Px_BSTx Register is R/W and<br>visible to Processor Bus access and PCI<br>memory cycles. When this bit is cleared, the<br>Px_BSTx register returns only zeros on a read.<br>Writes will have no effect on Px_BSTx when this<br>bit is cleared. | Enabled or configurable<br>through EEPROM                                                             |
| BS[3:0]  | R/W  | Sets the block size of the PCI target image. The size of the image is 64Kbyte * 2 <sup>BS</sup> .                                                                                                                                                                                                                  | Default value is 0, can be<br>programmed through any<br>port after reset or loaded<br>through EEPROM. |
| MODE     | R/W  | Maps the incoming PCI transaction to either memory or I/O space on the alternate PCI bus.                                                                                                                                                                                                                          | Default value is 0 (Memory command generation)                                                        |
| DEST     | R/W  | Directs the incoming PCI transaction to either the processor bus or the alternate PCI interface.                                                                                                                                                                                                                   | Defaults to processor bus                                                                             |
| MEM_IO   | R/W  | Commands to the corresponding image<br>generates Memory Read commands on the<br>destination PCI bus (Py) with the same byte<br>enables latched from the source bus transaction<br>PowerSpan II is capable of performing 1,2,3, or 4<br>byte memory transfers on the PCI bus(es).                                   | Default value is 0 (Regular<br>I/O mode)                                                              |
| RTT[4:0] | R/W  | A 5-bit value, defined in the processor bus<br>protocol, is generated on the PB_TT lines during<br>a read on the processor bus.                                                                                                                                                                                    | Defaults to Read                                                                                      |
| GBL      | R/W  | Controls the assertion of the PB_GBL_ cache control signal.                                                                                                                                                                                                                                                        | Asserts PB_GBL_                                                                                       |
| CI_      | R/W  | Controls the assertion of the PB_CI_ cache control signal.                                                                                                                                                                                                                                                         | Asserts PB_CI_                                                                                        |

| Bits        | Туре | Description                                                                                                                                                                                                                   | Default Setting                             |
|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| WTT[4:0]    | R/W  | A 5-bit value, defined in the processor bus protocol, is generated on the PB_TT lines during a write on the processor bus.                                                                                                    | Defaults to Write with Flush                |
| PRKEEP      | R/W  | Enables PowerSpan II to keep prefetch read data over subsequent transactions (see "Reads" on page 55).                                                                                                                        | Disabled                                    |
| END[1:0]    | R/W  | Sets endian mapping to little-endian, PowerPC<br>little-endian, or big-endian (see "Endian<br>Mapping" on page 213).                                                                                                          | Big-endian is the default mode.             |
| MRA         | R/W  | Aliases a Memory Read Command to Memory<br>Read Multiple Command. This causes<br>PowerSpan II to prefetch read data on the<br>destination bus (processor bus or PCI) up to the<br>amount programmed in the RD_AMT[2:0] field. | Disabled                                    |
| RD_AMT[2:0] | R/W  | Controls the prefetch read amount for a Memory<br>Read when MRA is enabled. Memory Read<br>Multiple always causes prefetch up to the value<br>in RD_AMT[2:0]. This can be programmed up to<br>a maximum of 128 bytes.         | 8 bytes is the default prefetch read amount |

#### Table 5: Programming Model for PCI Target Image Control Register

#### Master-based Decode

The PCI Target supports Master-based decode when the PowerSpan II PCI arbiter is enabled (see "Arbitration" on page 163). With Master-based decode enabled, a PCI target image only claims a transaction decoded for its specified physical address space if it originates from a specific PCI master.

External bus masters are selected for a specific target image by setting the corresponding bits in the "PCI 1 Target Image x Translation Address Register" on page 328.



PowerSpan II behavior is undefined if more than one overlapping target image claims a transaction. For example, if two target image have the same base address and size, then they must have unique master bits set in the "PCI 1 Target Image x Translation Address Register" on page 328.

#### 2.2.2.2 Address Translation

The address generated on the destination port is dependent on the use of address translation in the source target image. For more information, see the Translation Address Enable (TA\_EN) bit in the "PCI 1 Target Image x Control Register" on page 322. When address translation is enabled — by setting the TA\_EN bit— the address generated on the destination bus is derived from the following three inputs:

- incoming address on the PCI Target
- block size of the target image
   BS[3:0] in the "PCI 1 Target Image x Control Register" on page 322
- translation address TADDR in the "PCI 1 Target Image x Translation Address Register" on page 328

When address translation is disabled the address on the destination bus is the same as the address on the source bus.

#### 2.2.2.3 Transaction Type Mapping

#### Mapping to the Processor Bus Interface

The PCI Target Image controls the transaction type on the processor bus through the use of the PB Read Transfer Type (RTT[4:0]) and PB Write Transfer Type (WTT[4:0]) bits in the "PCI 1 Target Image x Control Register" on page 322. By default, these bit fields assign reads as read operations on the processor bus, and assign incoming writes as Write with Flush on the Processor Bus.

#### Mapping to a PCI Interface

The PCI target image determines the address space on the destination PCI bus through the use of the Image Mode (MODE) bit in the "PCI 1 Target Image x Control Register" on page 322. By default, incoming PCI transactions are mapped to Memory Space on the alternate PCI Interface. Setting the MODE bit maps incoming PCI transactions to I/O Space on the alternate PCI Interface.

#### 2.2.2.4 Address Parity

The PCI target image monitors parity during the address phase of decoded transactions. Address parity errors are reported on Px\_SERR# when both the Parity Error Response (PERESP) and SERR Enable (SERR\_EN) bits are set in the "PCI 1 Control and Status Register" on page 301. Assertion of the Px\_SERR# signal can be disabled by clearing the SERR\_EN bit.

PowerSpan II records an error condition in the event of an address parity error (see "Error Handling" on page 187). PowerSpan II claims the errored transaction and forwards the transaction to the destination bus.

# 2.2.3 Data Phase

#### 2.2.3.1 Writes

PowerSpan II accepts single beat or burst transactions in memory space. I/O accesses are not decoded. All writes to the PCI Target are posted writes.

Burst writes are linear bursts. A Target-Disconnect is issued if a buffer fills while a burst write is in progress (see "Termination Phase" on page 58). PowerSpan II can manage arbitrary PCI byte enable combinations during PCI burst writes.



PowerSpan II does not support delayed write transactions as described in the *PCI 2.2 Specification*.

#### 2.2.3.2 Reads

PowerSpan II supports up to four concurrent reads from external PCI masters. All four reads are treated equally and have the same prefetch capacity, but have individually programmable values.

An example of PowerSpan II's concurrent read capability is illustrated in Figure 6. The concurrent reads in the figure are represented by Read A and Read B. In the figure, both Read A and Read B are retried. Once Read A is completed on the processor bus, Read B is initiated on the processor bus while the contents of Read A are returned to the PCI master. Because Read B is completed on the processor bus while Read A data is returned to the PCI bus, read latency is significantly reduced with concurrent reads.

#### Figure 6: Concurrent Read Waveform



See "Concurrent Reads" on page 38 for a general discussion of read pipelining in PowerSpan II.

#### **Concurrent Read Phases**

The delayed, concurrent reads on the PCI Target consist of the following phases:

1. Delayed Read Request

- The PCI Target latches the transaction parameters and issues a retry.
- 2. Delayed Read
  - The PCI Target obtains the requested data. The destination bus master retries requested data.
- 3. Delayed Read Completion
  - The master repeats the transaction with the same parameters used for the initial request and data is provided by PowerSpan II.

Read line buffers are allocated on a first come, first serve basis. When an external master makes the initial memory request, the PowerSpan II PCI Target captures the PCI address in an available delayed read request latch. This initiates a read on the destination bus specified by the Destination Bus (DEST) bit in the "PCI 1 Target Image x Control Register" on page 322.

#### **Prefetch Reads**

All PowerSpan II PCI target memory reads are considered prefetchable to 8-byte boundaries by default. Setting the MEM\_IO bit in the "PCI 1 Target Image x Control Register" on page 322 enables 1,2,3, or 4 byte memory reads on the PCI bus and 4 byte reads on the processor bus. When PowerSpan II is programmed to support 4 byte transactions, only 4 byte transactions are supported. Burst transactions are not supported while the MEM\_IO bit is set to 1.

In order to program PowerSpan II to complete 4 byte reads on the PCI bus, both the MEM\_IO bit and the MODE bit must be set to 1 in the PCI *x* Target Image *x* Control register.

In order to perform a 4-byte read from the PCI bus to the processor (60x) bus, the following bits must be programmed:

- MEM\_IO bit set to 1
- MODE bit set to 1 or 0
- END bit, in the "PCI 1 Target Image x Control Register" on page 322, must not be set to little-endian mode (00). It can be set to PowerPC little-endian (01), or big-endian (10).



When the Target Image Control register is programmed for 4 byte read transactions, requesting 8 byte reads causes undefined results in the system.

PowerSpan II prefetch behavior on the destination bus when claiming Memory reads on the originating bus is controlled by the PCI Memory Read Alias (MRA) bit and the Prefetch Size (RD\_AMT[2:0]) field in the "PCI 1 Target Image x Control Register" on page 322. If the MRA bit is set when PowerSpan II claims a memory read, PowerSpan II prefetches the amount programmed into the RD\_AMT[2:0] field — up to 128 bytes.

The Memory Read Line command results in a prefetch of the value programmed into Cache Line (CLINE) bit. When the MRA bit is cleared, the target image prefetches 8 bytes when a PCI Memory Read command is decoded.

The Memory Read Multiple command results in a prefetch read of a minimum of 32 bytes or the value programmed into the RD\_AMT[2:0] field— independent of the MRA bit setting.

The PowerSpan II PCI target read watermarks are defined in Table 6.

| PCI Command          | Prefetch Amount                                                                                                                                    |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory Read          | 8 bytes (default) or 1,2,3, or 4 bytes<br>Depending in the setting in the MEM_IO<br>bit in the PCI Target Image Control<br>Register (see page 322) |
| Memory Read Line     | Minimum of CLINE in the Px_MISC0 register                                                                                                          |
| Memory Read Multiple | Minimum of 32 bytes or RD_AMT.                                                                                                                     |

Table 6: PowerSpan II PCI Target Read Watermarks

PowerSpan II never prefetches data beyond a 4-Kbyte address boundary regardless of the value programmed in the RD\_AMT field. This boundary corresponds to the processor bus memory management page size.

The PowerSpan II PCI Target can be configured to keep prefetch data over multiple read accesses for any master that provides the correct address — by setting the PRKEEP bit in the "PCI 1 Target Image x Control Register" on page 322. PowerSpan II increments its latched address for the read transaction based on the amount of data removed by the PCI master during the read transaction. If the PCI master returns with an address that matches the incremented address held by PowerSpan II, then PowerSpan II provides data already held in the prefetch line buffer.



Writes do not invalidate read buffer contents.

#### 2.2.3.3 Data Parity

PowerSpan II monitors Px\_PAR#/Px\_PAR64# when it accepts data as a PCI target during a write. PowerSpan II drives Px\_PAR#/Px\_PAR64# when it provides data as a PCI target during a read. In both cases, the Px\_PAR#/Px\_PAR64# signal provides even parity for Px\_C/BE#[3:0] and Px\_AD[31:0] — or Px\_C/BE#[7:4] and Px\_AD[63:32] for the PCI-1 Interface in 64-bit mode.

The PERESP bit in the "PCI 1 Control and Status Register" on page 301 determines whether or not PowerSpan II responds to parity errors as a PCI target. Data parity errors are reported through the assertion of Px\_PERR# when the PERESP bit is set. The Detected Parity Error (D\_PE) bit in the "PCI 1 Control and Status Register" on page 301 is set when PowerSpan II encounters a parity error as a PCI target on any transaction. PowerSpan II records an error condition when a parity error occurs (see "Error Handling" on page 187).

# 2.2.4 Termination Phase

#### 2.2.4.1 PCI Target Terminations

The PCI Target Interface generates the following terminations:

1. Target-Disconnect (with data): A termination is requested by the PCI target — by asserting Px\_STOP# and Px\_TRDY# — when it requires a new address phase. Target-Disconnect means the transaction is terminated after one or more valid data transfers.

The PCI target requests a Target-Disconnect in the following cases:

- PowerSpan II is unable to buffer an incoming write or provide data from a read buffer during a read.
- PowerSpan II reaches the 4-Kbyte address boundary on reads and writes to the processor bus.
- One data phase for PowerSpan II register accesses
- One data phase for I<sub>2</sub>O shell accesses
- Detection of a transaction with non-linear addressing

- 2. Target-Retry: A termination is requested by asserting Px\_STOP# and Px\_DEVSEL# while Px\_TRDY# is high by the PCI Target because it cannot currently process the transaction. Retry means the transaction is terminated after the address phase without any data transfer. PowerSpan II retries read requests while it fetches data from the destination bus. Any attempt by a PCI master to complete the memory read transaction is retried by the PCI target until at least an 8-byte quantity is available in the line buffer. If a PCI master does not retry the transaction within 2<sup>15</sup> clocks after a read request has been latched, the delayed read request latch and line buffer are de-allocated. This prevents deadlock conditions.
- 3. Target-Abort: The PCI target requests a termination of a transaction by negating Px\_DEVSEL# and Px\_TRDY# and asserting Px\_STOP# on the same clock edge when it cannot respond to the transaction, or during a fatal error. A fatal error occurs when: a bus error is experienced on the processor bus, the maximum retry count is exceeded, a Target-Abort occurs on the alternate PCI bus during a read, or a Master-Abort occurs on the alternate PCI bus during a read.

Although there may be a fatal error for the initiating application, the transaction completes gracefully, ensuring normal PCI operation for other PCI resources. PowerSpan II sets the signaled Target-Abort (S\_TA) bit in the "PCI 1 Control and Status Register" on page 301, and records an error condition in the event of a Target-Abort (see "Error Handling" on page 187)

#### Error Logging and Interrupts

The PowerSpan II PCI Target records errors under the following conditions:

- address parity error
- data parity error on writes
- Target-Abort

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.

# 2.3 PCI Master Interface2.3.1 PowerSpan II as PCI Master

In order for PowerSpan II to be a PCI master in a transaction the Bus Master (BM) bit, in the "PCI 1 Control and Status Register" on page 301, must be set. With this bit set, PowerSpan II is PCI Master in a transaction in the following instances:

- Servicing a request by:
  - the processor bus: PowerSpan II is accessed as a PB slave
  - the alternate PCI Interface: PowerSpan II is accessed as a PCI target
- processing a transfer by one of the four PowerSpan II DMA channels
- generating a configuration or IACK cycle because of a PowerSpan II register access

This section discusses only the first three conditions listed above. Configuration and IACK cycles are discussed in "Configuration and IACK Cycle Generation" on page 295.

The operation of the PCI Master is described by dividing the PCI master transaction into the following phases:

- **Arbitration Phase**: This section describes how PowerSpan II requests the PCI bus and its response to bus parking.
- Address Phase: This section discusses the generation of the PCI address and command encoding.
- Data Transfer: This section describes control of burst length.
- **Terminations**: This section explains the terminations supported by PowerSpan II, how they are mapped to the source port (Processor Bus Interface or the alternate PCI Interface), and exception handling.



PowerSpan II cannot be both master and target on a PCI bus at the same time.

# 2.3.2 Arbitration for PCI Bus

PowerSpan II issues a bus request on the PCI bus when it requires access to the PCI bus. When the PowerSpan II PCI arbiter is active, this request is internal. When it is not enabled the request appears externally (see "PCI Interface Arbitration" on page 163 for more information).

The internal PowerSpan II PCI arbiter parks the bus on a PCI master by asserting Px\_GNT# to the PCI master. Bus parking improves the performance of the PowerSpan II PCI Master by reducing arbitration latency.

# 2.3.3 Address Phase

### 2.3.3.1 Command Encoding

The encoding on the Px\_C/BE# lines indicate the transaction type on the PCI bus. The PCI command encoding supported by PowerSpan II, and their corresponding transaction types, are shown in Table 7.

| Px_C/BE# [3:0] | Transaction Type                                                                                                                  | PowerSpan II Capable                                                  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| 0000           | Interrupt Acknowledge                                                                                                             | Yes (see "Configuration<br>and IACK Cycle<br>Generation" on page 295) |
| 0001           | Special Cycle                                                                                                                     | No                                                                    |
| 0010           | I/O Read                                                                                                                          | Yes                                                                   |
| 0011           | I/O Write                                                                                                                         | Yes                                                                   |
| 0100           | Reserved                                                                                                                          | N/A                                                                   |
| 0101           | Reserved                                                                                                                          | N/A                                                                   |
| 0110           | Memory Read                                                                                                                       | Yes                                                                   |
| 0111           | Memory Write                                                                                                                      | Yes                                                                   |
| 1000           | Reserved                                                                                                                          | N/A                                                                   |
| 1001           | Reserved                                                                                                                          | N/A                                                                   |
| 1010           | Configuration Read                                                                                                                | Yes (see "Configuration<br>and IACK Cycle<br>Generation" on page 295) |
| 1011           | Configuration Write                                                                                                               | Yes (see "Configuration<br>and IACK Cycle<br>Generation" on page 295) |
| 1100           | Memory Read Multiple                                                                                                              | Yes                                                                   |
| 1101           | Dual Address Cycle                                                                                                                | No                                                                    |
| 1110           | Memory Read Line                                                                                                                  | Yes                                                                   |
| 1111           | Memory Write and Invalidate<br>(The MWI_EN bit is hard-wired to "0"<br>in the "PCI 1 Control and Status<br>Register" on page 301) | No                                                                    |

Table 7: Command Encoding for Transaction Type (PowerSpan II as PCIMaster)

A new request for access to the bus is generated by the PowerSpan II PCI Master when it requires access to the PCI bus to service a request from the Processor Bus Interface or the other PCI interface (Py). After the request is generated by PowerSpan II, it successfully arbitrates for access to the PCI bus when it receives GNT\_ from the arbiter. PowerSpan II then asserts Px\_FRAME# to indicate the beginning of a transaction.

#### 2.3.3.2 Address Translation

The address generated by the PCI Master is dependent on the use of address translation in the source target image (see "PCI 1 Target Image x Control Register" on page 322) or slave image (see "Processor Bus Slave Image x Control Register" on page 342). When address translation is enabled — by setting the TA\_EN bit in PCI Target or PB Slave Image Control Register — PowerSpan II produces the PCI address using the following inputs:

- the incoming address from the source bus
- the block size of the slave or target image
- the translation offset

For address translation going from the processor bus to PCI, see "Processor Bus Interface" on page 101. For an example of address translation control going from PCI to PCI, see "PCI 1 Target Image x Translation Address Register" on page 328.

When address translation is disabled, the address generated by the PCI Master is the same as the address on the source bus.

# 2.3.4 Data Phase

#### 2.3.4.1 Writes

#### Non-DMA Writes

For non-DMA writes, the length of the PCI write transaction is dependent on the length of the transaction delivered from the source bus. Writes originating from the processor bus can be either single cycle writes or burst writes. Burst writes from the processor bus are always 32 bytes in length. This burst is converted to an 8 byte burst on a 32-bit PCI bus. Either PCI-1 or PCI-2 can be configured as 32-bit. Single cycle writes from the 64-bit processor bus are translated into two 8 byte burst writes on the 32-bit PCI bus. This information is summarized in Table 8

| PB Write            | 64-bit PCI Write           | 32-bit PCI Write           |
|---------------------|----------------------------|----------------------------|
| 32-byte Line Write  | 4-beat 32-byte Burst Write | 8-beat 32-byte Burst Write |
| 8-byte Single Write | Single Beat 8-byte Write   | 2-beat 8-byte Burst Write  |

The PB Master can also generate MPC8260 extended cycles. Extended cycles are either 16 byte or 24 byte transactions. These cycles are enabled by setting the Extended Cycle (EXTCYC) bit to 1 in the Processor Bus Miscellaneous control Register (see page 361).

Incoming PCI writes are executed as similar writes on the alternate PCI Interface. For example, a 64-byte burst write to memory space is executed as a 64-byte burst write to the memory space on the alternate bus, provided the target does not disconnect.



Write transactions intended for I/O space on the alternate PCI bus must be single beat writes. Bursting is not supported for a target image programmed to generate an I/O access on the alternate PCI bus. A burst write directed at such a target image results in a Target-Disconnect after every data beat.

#### **DMA Writes**

The PowerSpan II DMA channels always attempt to perform the longest possible burst — up to 128-bytes — on the PCI bus.

#### 2.3.4.2 Reads

The minimum memory read prefetch quantity is 8 bytes (default). Setting the MEM\_IO bit in the "PCI 1 Target Image x Control Register" on page 322 enables 1,2,3, or 4 byte memory reads on the PCI bus.

The PowerSpan II PCI Master generates a Memory Read command selection according to the rules in Table 9.

| Internal Request of Transaction Length | PCI Memory Read Command |
|----------------------------------------|-------------------------|
| <= 8 bytes                             | Memory Read             |
| <= CLINE[7:0] in Px_MISC0              | Memory Read Line        |
| > CLINE[7:0] in Px_MISC0               | Memory Read Multiple    |

#### Table 9: PowerSpan II PCI Master Read Commands

The read amount presented to the PCI Master determines the command used. A Memory Read Line command uses the burst length programmed into the CLINE[7:0] field in the "PCI 1 Miscellaneous 0 Register" on page 307. It is programmable to 16-, 32-, 64-, or 128 bytes.



If the PCI Master does not complete the burst read transaction before a target termination, it completes the read with subsequent PCI read transactions at the appropriate address.

#### 2.3.4.3 Parity Monitoring and Generation

PowerSpan II monitors Px\_PAR#/Px\_PAR64# when it accepts data as a PCI master during a read, and drives Px\_PAR#/Px\_PAR64# when it provides data as a PCI master during a write. PowerSpan II also drives Px\_PAR#/Px\_PAR64# during the address phase of a transaction when it is a PCI master. In both address and data phases, the Px\_PAR#/Px\_PAR64# signal provides even parity for Px\_C/BE#[3:0] and Px\_AD[31:0]. Even parity is enabled Px\_C/BE#[7:4] and Px\_AD[63:32] for PCI-1 in 64-bit mode.

PowerSpan II parity response is enabled through the Parity Error Response (PERESP) bit in the "PCI 1 Control and Status Register" on page 301. Data parity errors are reported through the assertion of Px\_PERR# when the PERESP bit is set. The Detected Parity Error (D\_PE) bit in the "PCI 1 Control and Status Register" on page 301 is set when PowerSpan II encounters a parity error as a PCI master on any transaction. PowerSpan II records an error condition in the event of a parity error (see "Error Handling" on page 187).

The Master Data Parity Detected (MDP\_D) bit in the "PCI 1 Control and Status Register" on page 301 is set if the PERESP bit is enabled and either PowerSpan II is the master of the transaction where it asserts PERR#, or the addressed target asserts PERR#. If the transfer originated from the Processor Bus Interface, then PowerSpan II sets the MDP\_D bit and the Px\_PB\_ERR\_EN bit in the "Interrupt Enable Register 1" on page 395. PowerSpan II then asserts an interrupt (see "Interrupt Handling" on page 173).



PowerSpan II continues with the transaction independent of any parity errors reported during the transaction.

#### 2.3.5 Termination Phase

#### 2.3.5.1 PCI Master Terminations

The PCI Master supports all four types of PCI terminations:

- 1. Master-Abort: The PCI Master negates Px\_FRAME# and then negates Px\_IRDY# on the following clock edge when no target responds with Px\_DEVSEL# asserted on the fifth positive edge of clock after Px\_FRAME# is asserted. PowerSpan II sets R\_MA in Px\_CSR and records an error condition in the event of a Master-Abort (see "Error Handling" on page 187)
- Target-Disconnect (with data): A termination is requested by the target by asserting Px\_STOP, Px\_DEVSEL# and Px\_TRDY# — because it is unable to respond within the latency requirements of the *PCI 2.2 Specification* or it requires a new address phase. Target-Disconnect means the transaction is terminated after data is transferred. PowerSpan II negates Px\_REQ# for at least two clock cycles if it receives Px\_STOP# from the PCI target.
- 3. Target-Retry: Termination is requested by asserting Px\_STOP# and Px\_DEVSEL# while Px\_TRDY# is high by the target because it cannot currently process the transaction. Retry means the transaction is terminated after the address phase without data transfer. PowerSpan II has a Maximum Retry Counter (MAX\_RETRY) in the "PCI 1 Miscellaneous Control and Status Register" on page 337 which is used to record an error condition if the number of retries exceed the programmed amount (see "Error Handling" on page 187).
- 4. Target-Abort: The target requests a termination of a transaction by negating Px\_DEVSEL# and asserting Px\_STOP# on the same clock edge when it cannot respond to the transaction, or during a fatal error. Although there may be a fatal error for the initiating application, the transaction completes gracefully, ensuring normal PCI operation for other PCI resources. PowerSpan II sets R\_TA in Px\_CSR and records an error condition in the event of a Target-abort (see "Error Handling" on page 187).

#### 2.3.5.2 Error Logging and Interrupts

The PowerSpan II PCI Master records errors under the following conditions:

- Data Parity on reads (when the PERSP bit, in the "PCI 1 Control and Status Register" on page 301, is set)
- Master-Abort
- Target-Abort
- Expiration of Maximum Retry Counter (when the MAX\_RETRY field, in the "PCI 1 Miscellaneous Control and Status Register" on page 337, is set.

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.

# 2.4 CompactPCI Hot Swap Silicon Support

*CompactPCI's Hot Swap Specification* defines the process for installing and removing adapter boards without adversely affecting a running system. It provides a programmatic access to Hot Swap services. This enables system re-configuration and fault recovery to take place with no system down time and minimum operator interaction.

PowerSpan II is compliant with the *CompactPCI's Hot Swap Specification*, *Revision 2.0* and is a Hot Swap Silicon device. Hot Swap Silicon support includes the following:

- Open drain output pin ENUM# is used to indicate Hot Swap insertion and extraction events.
- 5V tolerant input pin ES for sensing the state of the ejector switch used to insert or extract a CompactPCI board.
- 5V tolerant open drain output pin LED# for controlling the blue Light Emitting (LED) required to indicate status of the software connection process.

For the different levels of Hot Swap support, refer to the *CompactPCI Hot Swap Specification*.

To simplify the design of CompactPCI Hot Swap adapter cards, PowerSpan II has additional support. This support includes:

- A 5V tolerant input pin HEALTHY# for sensing the status of the Back End power on the card.
- An input pin P1\_64EN# that enables Hot Swap adapter cards to sense the presence of a 64-bit PCI backplane.

# 2.4.1 LED Support

The LED can be controlled by hardware and software. PowerSpan II drives the LED# signal low to turn on the LED during the Physical and Hardware Connection process (when HEALTHY# is negated). A blue LED with an internal resistor can be directly connected between the 5V rail and the LED# signal. Software controls the LED by setting the LED On/Off (LOO) bit in the "PCI 1 Compact PCI Hot Swap Control and Status Register" on page 317.

# 2.4.2 ES Input

The *CompactPCI Hot Swap Specification* defines a switch located in the ejector handle that indicates to PowerSpan II if the ejector handle is open or closed. A low value on ES input indicates that the ejector latch is open. A high value on ES indicates that the ejector latch is closed and is in operation mode.

# 2.4.3 HEALTHY# Signal

PowerSpan II manages the electrical board level issues involved in the Hot Swap process with the HEALTHY# signal. The negation of HEALTHY# indicates only some of the components on the Hot Swap card are powered. To operate in this environment and minimize long term reliability issues, the HEALTHY# signal controls the electrical behavior of PowerSpan II I/O buffers.

During the negation of HEALTHY#, PowerSpan II disables its output and bidirectional pins (except for LED#) to avoid applying power to non-powered components on the card. The signals connected between PowerSpan II and these non-powered components result in floating pins on PowerSpan II. PowerSpan II uses HEALTHY# to inhibit the input receivers. An inhibited receiver has no static current path between supply and ground that could be activated by a voltage level near the switching point.

See "Resets, Clocks and Power-up Options" on page 201 for more details on HEALTHY# and PowerSpan II reset.

## 2.4.4 CompactPCI Hot Swap Card Insertion and Extraction

A CompactPCI board has a staggered pin arrangement (long/medium/short) to allow power and ground, signal and a Board Inserted Indicator (BD\_SEL#) to be connected and disconnected in stages. A limited number of power and ground pins are long. The rest of the power, ground, and signal pins are of medium length. BD\_SEL# is a short pin. When BD\_SEL# connects, the physical connection process is complete.

#### 2.4.4.1 CompactPCI Hot Swap Process

A CompactPCI Hot Swap board is divided into two power regions: Early Power and Back End Power. Early Power is provided by the long pins on the CompactPCI connector. Back End Power is controlled by a sequencer on the card. The sequencer begins to power the Back End of the card when the short CompactPCI signal BD\_SEL# engages on insertion, or when host software enables the process as in a High Availability system.

In Figure 7, PowerSpan II is designed into a CompactPCI adapter card.



Figure 7 assumes the CompactPCI backplane is not in reset during the insertion and extraction process. For example, PowerSpan II's P1\_RST# is negated.



Figure 7: PowerSpan II in a CompactPCI Adapter Card



Ensure that PB\_CLK and P2\_CLK are within specification before the release of Back End power-up reset.

#### 2.4.5 Hot Swap Insertion Process

Use the application illustrated in Figure 7 as a point of reference in the Hot Swap insertion process outlined below.

- 1. Long pins contact for Early Power:
  - HEALTHY# negated
    - PowerSpan II resources are in reset
    - LED# pin enabled, status diode turned on
    - PowerSpan II output pins disabled, input pins inhibited
  - Card's PCI signals pre-charge
- 2. Medium pins contact PCI backplane signals:
  - PowerSpan II's Primary PCI Interface, in this case PCI-1, connects to the PCI pins on the backplane
  - PowerSpan II P1\_CLK is within specification
- 3. Short pins contact, BD\_SEL# asserted:
  - Back End Power ramps
  - Back End Power-up reset asserted
    - PowerSpan II PO\_RST\_ asserted
    - MPC8260 PORESET\_asserted, MPC8260 asserts HRESET\_
  - Clock generator begins oscillation
    - PowerSpan II PB\_CLK and P2\_CLK begin to oscillate
  - Ejector switch closes sometime after short pins contact
- 4. Back End power is within specification:
  - HEALTHY# asserted
    - LED# pin disabled
    - PowerSpan II outputs enabled, PB\_RST\_ and P2\_RST# asserted
  - MPC8260, Secondary PCI clocks are within specification
- 5. Back End Power-up reset negation:
  - PowerSpan II PLLs released from reset and begin to lock on to P1\_CLK, PB\_CLK, P2\_CLK

- MPC8260 completes its configuration master transactions
  - PowerSpan II power-up options are loaded
- MPC8260 HRESET\_ times out
- PowerSpan II PLL locking complete
  - All PowerSpan II resources out of reset, PB\_RST\_ and P2\_RST# negated
  - PowerSpan II executes EEPROM load or waits to be initialized by the processor
- 6. PowerSpan II waits for the closed ejector switch and responds by:
  - Setting INS bit in the HS\_CSR register
  - Asserting ENUM#
- 7. PowerSpan II is now able to accept Configuration cycles on PCI-1 from the CompactPCI Host

Since Px\_LOCKOUT bit in the PCI-1 Miscellaneous Control and Status (MISC\_CSR) register (see page 337) defaults to 1, PowerSpan II retries the Host Configuration accesses on the PCI-1 Interface until Px\_LOCKOUT is cleared. The Host then negates ENUM# by clearing the Insertion (INS) bit in the PCI-1 CompactPCI Hot Swap Control and Status (P1\_HS\_CSR) register (see page 317) and configures the card. The Px\_LOCKOUT bit is cleared by an EEPROM load or by access from the Processor Bus Interface. It is automatically cleared by PowerSpan II when the PWRUP\_BOOT option is set to PCI.



### Figure 8: Hot Swap Insertion

### 2.4.6 Hot Swap Extraction Process

Use the application illustrated in Figure 7 as a point of reference in the Hot Swap extraction process outlined below.

- 1. Ejector switch opens
  - The Extraction (EXT) bit in the P1\_HS\_CSR register is set, causing the assertion of ENUM#
- 2. Compact PCI Host:
  - Reads the P1\_HS\_CSR of each agent to determine which card is being extracted
  - Clears the PowerSpan II EXT bit. This causes the negation of ENUM# and arms the INS bit
  - Places the card in a software dormant state

 Sets the LED On/Off (LOO) bit in the P1\_HS\_CSR register. This causes the assertion of LED# which turns the light emitting diode to signal the operator



At this point the operator can close the ejector switch and reenter the insertion process.

- 3. Operator begins extracting the card.
- 4. Short pins break, BD\_SEL# is negated
  - Back End power goes out of specification
  - HEALTHY# negated
    - All PowerSpan II resources reset
    - LED# pin enabled, status diode turned on
    - PowerSpan II output pins disabled, input pins inhibited
  - PCI pre-charge reapplied
- 5. Medium pins break.
- 6. Long pins break.



### Figure 9: Hot Swap Extraction



After the status LED# is illuminated by the host, the operator can close the ejector switch, rather than extracting the card. If the closure or the extraction occurs, a PowerSpan II register reload from EEPROM does not occur.

# 2.5 Vital Product Data

Vital Product Data (VPD) is information which uniquely defines items of a system. These items include the hardware, software and microcode elements of a system. VPD also provides a mechanism for storing information, such as performance data on a device. VPD resides in a local storage device.

PowerSpan II supports VPD through the I<sup>2</sup>C Interface to serial EEPROM. The Vital Product Data Extended Capabilities Pointer and supporting registers reside in the configuration space of the PowerSpan II Primary PCI Interface. The VPD feature requires the VPD\_EN bit, in the "Miscellaneous Control and Status Register" on page 378, to be set and an available external EEPROM.

### 2.5.1 VPD Access

VPD accesses through PowerSpan II default to the I<sup>2</sup>C serial EEPROM device zero (VPD EEPROM Chip Select (VPD\_CS) = 0b000 in the "Miscellaneous Control and Status Register" on page 378). This is also used for EEPROM loading of the registers after reset. Since the lower bytes in the EEPROM contain data for setting up PowerSpan II before software initialization, the lower portion of the EEPROM (the first 64 bytes) are not visible through the VPD registers. The upper 192 bytes of the 256 byte EEPROM are visible through the VPD registers. Of these bytes, the first 64 bytes are VPD-Read Only and the remaining 128 bytes are VPD-Read/ Write. When VPD\_CS = 0b000, VPD addresses are translated upward by 64 bytes before being presented to the EEPROM.

PowerSpan II can be programmed with an alternate chip select for VPD access if more than the 192 accessible bytes is required. Programming of the I<sup>2</sup>C chip select is done in the PowerSpan II "Miscellaneous Control and Status Register" on page 378. If an alternate I<sup>2</sup>C chip select is used then the first 64 bytes of the VPD EEPROM is designated as VPD-Read Only and the upper 192 bytes are designated as VPD-Read/Write.

The VPD access to the EEPROM is similar to the EEPROM access implemented in PowerSpan II through the I2C\_CSR register, except that it uses the "PCI 1 Vital Product Data Capability Register" on page 319 and the "PCI 1 Vital Product Data Register" on page 321. Since they both access the same resource, a PowerSpan II semaphore register SEMAx must be used to acquire exclusive access of the I<sup>2</sup>C Interface before software initiates VPD accesses.

### 2.5.2 Reading VPD Data

PowerSpan II implements 8-bits of address for accessing the EEPROM up to a maximum of 256 bytes. The VPD address must be DWORD-aligned. A single read access reads four consecutive bytes starting from the VPD address from the EEPROM. If I<sup>2</sup>C chip select zero is used for VPD, then 192 bytes (address 0x00-BF) of VPD are accessible through the VPD read. Using another I<sup>2</sup>C chip select, the VPD Read can access the entire 256-byte EEPROM address range.

During a read access, the VPD Address (VPDA) field and the VPD Flag (F) bit are written in the "PCI 1 Vital Product Data Capability Register" on page 319. The F bit must be set to 0 to indicate a VPD read access. PowerSpan II sets the F bit to 1 when it completes reading the 4 bytes from the EEPROM. The F bit must be polled to determine when the read is complete. Byte 0 (bits 7 through 0) of the "PCI 1 Vital Product Data Register" on page 321 contains the data referenced by the VPD Address — bytes 1 through 3 contain the successive bytes.



If the Px\_VPDD register or the I2C\_CSR register is written to prior to the flag bit being set to 1, the results of the original read operation are unpredictable.

### 2.5.3 Writing VPD Data

A write can only occur to the upper 128 bytes of the EEPROM or, potentially, the upper 192 bytes if  $I^2C$  chip select is non-zero. Similar to the read operation, the write operation always writes four consecutive bytes starting from the VPD address to the EEPROM.

The "PCI 1 Vital Product Data Register" on page 321 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 VPDA field and the F bit is then written. The F bit must be set to 1 to indicate a VPD write. The F bit is polled to determine when the write to the EEPROM is completed. PowerSpan II sets the F bit to 0 when the write is completed.

When a write is attempted to the lower 64 bytes of the VPD area of the EEPROM, PowerSpan II does not perform the write operation and clears the F bit.



The Px\_VPDD or I2C\_CSR register must not be written while a write operation is occurring.

# 2.6 I<sub>2</sub>O Shell Interface

PowerSpan II provides portions of the  $I_2O$  Shell Interface for the platform it is connecting to the Primary PCI bus. The  $I_2O$  Shell Interface defined in the  $I_2O$  2.0 Specification is comprised of three main sections:

- messaging interface
- protocol for exchanging messages
- executive class messages

PowerSpan II implements the  $I_2O$  messaging interface and, in conjunction with the Input/Output Processor (IOP), enables the message passing protocol.

### 2.6.1 I<sub>2</sub>O Target Image

There are three registers which enable Memory access to the  $I_2O$  Shell Interface and local IOP Message Frames. The supporting registers include the following:

- "PCI 1 I2O Target Image Base Address Register" on page 309
- "PCI I2O Target Image Control Register" on page 415
- "PCI I2O Target Image Translation Address Register" on page 420



The I<sub>2</sub>O target image does not support Master-Based Decode.

The I<sub>2</sub>O Shell Interface consists of Inbound and Outbound Queues and supporting I<sub>2</sub>O Host interrupt registers. The queues contain Message Frame Addresses (MFAs). These MFAs specify the starting address of Message Frames relative to the base address of the memory window in PowerPC memory. PowerSpan II implements I<sub>2</sub>O support with the first Memory Base Address Register in PCI configuration space.

The I<sub>2</sub>O target image is divided into an I<sub>2</sub>O Shell Interface and a processor bus memory window intended for IOP Message Frame accesses. The I<sub>2</sub>O Shell Interface is accessed through the lower 4 Kbytes of the I<sub>2</sub>O target image. I<sub>2</sub>O Shell Interface accesses are limited to 32-bit single data phase PCI transactions. Accesses through the I<sub>2</sub>O target image memory window to IOP Message Frames are burstable up to 64-bits wide for PCI-1, but limited to 32-bit wide for PCI-2.

PowerSpan II does not support posting of more than one write transaction to the Inbound or Outbound Queue. Attempts to write to the Inbound or Outbound Queue are retried until the currently active write completes on the Processor Bus Interface.

### 2.6.2 IOP Functionality

A number of configuration steps are required before PowerSpan II and the embedded processor bus are enabled to provide IOP functionality. The following example assumes PCI-1 is the Primary PCI Interface.

The steps required to implement IOP functionality are listed below.

- 1. In order to identify PowerSpan II as an I<sub>2</sub>O Controller the "PCI 1 Class Register" on page 305 must be programmed as follows:
  - Base Class Code (BASE) = 0x0E
  - Sub Class Code (SUB) = 0x00
  - Programming Interface (PROG) = 0x01



Programming values other than the ones listed above do not affect the behavior of PowerSpan II as an I2O device.

- 2. The Inbound and Outbound Queues' location and size in IOP memory must be programmed in PowerSpan II. This is accomplished by programming the "I2O Queue Base Address Register" on page 423:
  - Processor Bus I<sub>2</sub>O Base Address (PB\_I2O\_BS): specifies base address of the Queues
  - FIFO Size (FIFO\_SIZE): specifies the size of the Queues
- 3. The PCI I<sub>2</sub>O target image must be configured to claim I<sub>2</sub>O Shell and Message Frame accesses from PCI. The following registers must be programmed:
  - Configure I<sub>2</sub>O image size with the Block size (BS) bit in "PCI I2O Target Image Control Register" on page 415 (PCI\_TI2O\_CTL).
  - Enable Base Address Register (BAR) visibility in configuration space.
    - Set BAR\_EN in the PCI\_TI2O\_CTL register.
  - Program PCI Base Address Register "PCI 1 I2O Target Image Base Address Register" on page 309.
    - Set Image Enable (IMG\_EN) in "PCI I2O Target Image Control Register" on page 415 to enable decode. Note that this occurs if a nonzero value is written to the PCI Base Address Register.
  - Configure Processor Bus Master transaction parameters.
    - Write Transfer Type (WTT) in the PCI\_TI2O\_CTL register.
    - Read Transfer Type (RTT) in the PCI\_TI2O\_CTL register.

- Global Command (GBL) in the PCI\_TI2O\_CTL register.
- Cache Inhibit (CI) in the PCI\_TI2O\_CTL register.
- Select endian conversion mechanism with the Endian Conversion (END) bit in the PCI\_TI2O\_CTL register
- Configure address translation
  - Translation Address Enable (TA\_EN) bit in the PCI\_TI2O\_CTL register.
  - Translation Address (TADDR) in the "PCI I2O Target Image Translation Address Register" on page 420 (PCI\_TI2O\_TADDR)
- Enable decode in PCI memory space.
  - Set memory Space (MS) bit in the "PCI 1 Control and Status Register" on page 301.

At this stage, the  $I_2O$  image is defined but all accesses to the PCI  $I_2O$  target image are retried.

- 4. The IOP is required to initialize all Top and Bottom Pointer registers and initialize all the MFAs in the Inbound Free List FIFO. At this point, the IOP enables PCI accesses with the following step:
  - Set the I2O Enable (I2O\_EN) bit in the "I2O Control and Status Register" on page 421.

### 2.6.3 Messaging Interface

The  $I_2O$  2.0 Specification defines a mechanism for connecting an I/O Platform (IOP) to an  $I_2O$  system through a memory-based system, such as PCI, which has no inherent message passing capability. An IOP which is connected to a memory-based system is said to be locally attached. The PowerSpan II implements four  $I_2O$  defined memory mapped registers on PCI to enable the physical and logical connection of the IOP to the system. Two of these memory-mapped registers provide the interface for the external Host platform and other IOPs to exchange messages with the local IOP sitting behind the PowerSpan II. These two registers are used as  $I_2O$  specific Interrupt Status and Enable registers for the local IOP to signal the Host platform. Additional PowerSpan II specific registers are implemented to support the messaging interface.

#### 2.6.3.1 Inbound Queue

The  $I_2O$  Inbound Queue register is the messaging interface used by the Host or external IOP to post messages to the local IOP.

The  $I_20$  Inbound Queue Register Interface is located at offset 0x040 of the PowerSpan II PCI  $I_20$  target image in PCI Memory space. The Inbound Queue has a Free List FIFO and a Post List FIFO, both of which reside in the IOP local memory.

#### 2.6.3.2 Inbound Free List FIFO and Post List FIFO

The Free List contains the Message Frame Address (MFAs) of Message Frames (MFs) in the IOP's local memory, which are available to the Host or other IOPs for writing inbound messages.

The Post List contains the MFAs of MFs in the local IOPs memory which contain inbound messages for the IOP to process.

The Inbound MFAs are 32-bit offsets from the translated PowerSpan II  $I_20$  target image window base address in local IOP memory. When the Host platform or an external IOP wishes to send a message to the local IOP it must first obtain an MFA from the Inbound Free List. The external platform is then free to place a message in the associated MF. The MFA is then placed into the Inbound Post List for the Local IOP to process.



All  $I_2O$  Inbound Queue MFAs must be offsets of greater than 4 Kbytes.

#### 2.6.3.3 Outbound Queue

The Outbound Queue Register is the messaging interface used by the local IOP to post messages to the Host. The I<sub>2</sub>O Outbound Queue Register Interface is located at offset 0x044 of the PowerSpan II PCI I<sub>2</sub>O target image in PCI memory space. The Outbound Queue has a Free List FIFO and a Post List FIFO, both of which reside in the IOP local memory. The Free List contains the Message Frame Address (MFAs) of Message Frames (MFs) in the Host system memory, which are available to the local IOP for writing outbound messages. Outbound MFAs are absolute addresses of a Message Frame in Host memory. The Post List contains the MFAs of MFs in the Host system memory which contain outbound messages for the Host to process. When the local IOP wishes to send a message to the Host platform it must first obtain an MFA from the Outbound Free List. The local IOP is then free to place a message in the associated MF. The MFA is then placed into the Outbound Post List for the Host to process. All Outbound messages are targeted for the Host platform. If the local IOP wishes to send a message to another IOP (peer-to-peer communication) it uses the external IOPs Inbound Queue to post the Message.

### 2.6.3.4 Protocol for Exchanging Messages PowerSpan II I<sub>2</sub>O Registers

The PowerSpan II PCI  $I_2O$  Shell Interface implements the following  $I_2O$  defined registers:

- I<sub>2</sub>O Outbound Post List Interrupt Status Register
- I<sub>2</sub>O Outbound Post List Interrupt Mask Register
- I<sub>2</sub>O Inbound Queue
- I<sub>2</sub>O Outbound Queue
- I<sub>2</sub>O Host Outbound Index Register (used for Outbound Option)

In addition to the registers defined in the  $I_2O$  2.0 Specification, PowerSpan II implements a number of registers to support the  $I_2O$  message passing protocol of the Shell Interface.

- PCI I<sub>2</sub>O Target Image Control Register (PCI\_TI2O\_CTL)
- PCI I<sub>2</sub>O Target Image Translation Address Register (PCI\_TI2O\_ TADDR)
- I<sub>2</sub>O Queue Base Address Register (I20\_QUEUE\_BS)
  - Processor Bus I<sub>2</sub>O Base Address Field: Base Address of the block of IOP memory that contains the four FIFOs (two Inbound and two Outbound). The Base Address alignment is 1 Mbyte.
  - FIFO Size Field: Indicates the number of bytes required for each of the Inbound Queue and Outbound Queue FIFOs implemented in local memory
- I<sub>2</sub>O Control and Status Register (I20\_CSR)
  - Host Outbound Post List Size Field: Indicates the number of entries in the Host Outbound Post List FIFO in Host memory, used for the Outbound Option.
  - I<sub>2</sub>O Enable Field: Enables/Disables PowerSpan II I<sub>2</sub>O Interface
    - PowerSpan II Primary PCI target retries I<sub>2</sub>O accesses until enabled
  - XI<sub>2</sub>O Enable Field: Enables/Disables PowerSpan II Outbound Option
    - IPL: Inbound Post List is set when the Inbound Post list FIFO is not empty
    - OFL: Outbound Free List is set when the Outbound Free List FIFO is not empty.

- Inbound Free List Bottom/Top/Top Increment Pointer Registers: (IFL\_BOT/ IFL\_TOP/IFL\_TOP\_INC)
  - Manages the Inbound Free List circular FIFO implemented in local memory
- Inbound Post List Bottom/Bottom Increment/Top Pointer Registers: (IPL\_BOT/IPL\_BOT\_INC/IPL\_TOP)
  - Used to manage the Inbound Post List circular FIFO implemented in local memory
- Outbound Free List Bottom/Bottom Increment/Top Pointer Registers: (OFL\_BOT/IPL\_BOT\_INC/OFL\_TOP)
  - Used to manage the Outbound Free List circular FIFO implemented in local memory
- Outbound Post List Bottom/Top/Top Increment Pointer Registers: (IPL\_BOT/ IPL\_TOP\_INC/IPL\_TOP)
  - Used to manage the Outbound Post List circular FIFO implemented in local memory
- IOP Outbound Index/Increment Registers: (IOP\_OI/IOP\_OI\_INC)
  - Used to manage the Host Outbound FIFO
- Host Outbound Index/Index Alias Registers: (HOST\_OI/HOST\_OIA)
  - Used to manage the Host Outbound FIFO
- Host Outbound Index Offset Registers: (HOST\_OIO)
  - Determines offset of the I<sub>2</sub>O target image at which the Host Processor can access the I<sub>2</sub>O Host Outbound Index Register

Interactions between the IOP and Host platforms during the  $I_2O$  message passing protocols are displayed in Figure 3.4. The solid lines indicate pointers which are maintained and incremented by the PowerSpan II. The dashed lines indicate pointers which are incremented by the IOP. The IOP writes one to increment to PowerSpan II increment register associated with the pointer.



Figure 10: PowerSpan II I<sub>2</sub>O Message Passing

The Top and Bottom pointers manage external FIFOs to determine the full and/or empty status of the FIFOs. After a FIFO write, the Top pointer is incremented. If the Top pointer then equals the Bottom pointer, a FIFO full condition exists. After a FIFO read, the Bottom pointer is incremented. If the Bottom pointer then equals the Top pointer, a FIFO empty condition exists.

### 2.6.4 Inbound Messages

The Inbound Free and Post List FIFOs are implemented as circular queues using Bottom and Top pointers. The PowerSpan II implements the Bottom and Top pointers for the Inbound Free List FIFO and the Inbound Post List FIFO. The FIFOs reside in the local memory. The Inbound posted messages also reside in local processor memory.

When the Host platform or external IOP wants to post a message to the local IOP, it must first acquire an MFA from the Inbound Free List. This is accomplished through a PCI read transaction to the PowerSpan II Inbound Queue Register at offset 0x040 of the I<sub>2</sub>O target image. PowerSpan II provides the next available MFA from the Inbound Free List FIFO pointed to by the Inbound Free List Bottom Pointer Register. PowerSpan II increments the Inbound Free List Bottom Pointer Register to point to the next entry of the FIFO. A read from the Inbound Queue Register when the Inbound Free List FIFO is empty (Bottom Pointer equal to Top pointer) returns 0xfff\_ffff to the requesting PCI master.

Once the Host or external IOP obtains an MFA, it is then to write a message to the IOP's local MF at the address offset from the Px\_BSI2O specified by the MFA. Once the message is transferred the Host or external IOP writes the MFA back to the same I<sub>2</sub>O target image offset (0x040). PowerSpan II accepts the write transaction on PCI and generate a write to the Inbound Post List FIFO at the local IOP memory address pointed to by the Inbound Post List Top Pointer Register. PowerSpan II then increments the Inbound Post List Top Pointer Register and asserts the I2O\_IOP Interrupt Status bit in the ISR0 register to notify the local processor of MFAs in the Inbound Post List FIFO. The IPL bit in the "I2O Control and Status Register" on page 421 is set while the Inbound Post List FIFO is not empty, indicating that Inbound Message Frames need to be processed.

#### 2.6.4.1 Local Processor Functions

For Inbound Messaging, the local processor performs the following:

- detects the interrupt
- reads the PowerSpan II ISR0 Register
- determines the source of the interrupt through the I2O\_IOP register
- clears the I2O\_IOP interrupt (write 1 to clear)
- reads the Inbound Post List FIFO Bottom Pointer Register to access the Inbound Post List FIFO to get the MFA
- increments the Inbound Post List Bottom Pointer Register by writing the Inbound Post List Bottom Pointer Increment Register
- reads and processes the MF pointed to by the MFA

- writes the MFA back to the Top of the Inbound Free List FIFO
- writes to the PowerSpan II's Inbound Free List Top Pointer Increment Register to increment the address by four
- reads the IPL bit, in the I2O\_CSR, to determine if the Inbound Post List is empty

The interrupt can be masked, leaving it to the processor to poll the ISR Register. A read from the Inbound Post List Bottom Pointer Register by the IOP when the Inbound Post List FIFO is empty returns 0xffff\_ffff to the processor if the EMTR field of the I2O\_CSR register is set to one.

### 2.6.5 Outbound Messages

The Outbound Free and Post List FIFOs are implemented as circular queues using Bottom and Top pointers. PowerSpan II implements the Bottom and Top pointers for the Outbound Free List FIFO and the Outbound Post List FIFO.

When the local IOP wants to post a message to the Host, it must first acquire an MFA from the Outbound Free List. The IOP reads the MFA pointed to by the Outbound Free List Bottom Pointer Register. The processor then increments the Outbound Free List Bottom Pointer Register by four to point to the next entry of the FIFO.

The IOP, having obtained a Host MFA, is then free to write a message through the PowerSpan II to the Host MF at the Host memory address specified by the MFA. Once the message is transferred, the IOP writes the MFA to the Outbound Post List FIFO at the address pointed to by the Outbound Post List Top pointer maintained by PowerSpan II. The processor then increments the Outbound Post List Top Pointer Register by four.

While the Outbound Post List FIFO is non-empty PowerSpan II sets an interrupt status bit in the PowerSpan II  $I_2O$  Outbound Post List Interrupt Status Register of the  $I_2O$  target image (0x030). If the Interrupt is not masked by the PowerSpan II Outbound Post List Interrupt Mask Register of the  $I_2O$  target image (0x034), PowerSpan II drives an interrupt to notify the Host processor of MFAs in the Outbound Post list FIFO. PowerSpan II determines the Outbound Post List FIFO to be non-empty when the Outbound Post List FIFO Bottom and Top pointers do not point to the same FIFO address.

#### 2.6.5.1 Host Processor Functions

For Outbound Messaging, the host processor performs the following:

- detects the interrupt.
- reads the I<sub>2</sub>O Outbound Post List Interrupt Status Register (0x030).

- reads the Outbound Queue Register at offset 0x044 of the PowerSpan II I<sub>2</sub>O target image map to obtain the next Outbound Post List MFA.
- processes the Message pointed to by the MFA.

The Outbound Interrupt Status and Mask bits are aliased in I2O\_HOST in the "Interrupt Status Register 0" on page 388 and I2O\_HOST\_MASK in the "Interrupt Status Register 0" on page 388. The IOP must program I2O\_HOST\_MAP in the "Interrupt Map Register Miscellaneous" on page 409 in order for the Outbound Interrupt to be routed to PowerSpan II's Primary PCI interrupt pin.

#### 2.6.5.2 Outbound Message Frame Addresses (MFA)

PowerSpan II provides the MFA at the Bottom of the Outbound Post List FIFO by performing a delayed read from the processor bus. The PowerSpan II increments the Outbound Post List Bottom Pointer Register and compares the value with the Outbound Post List Top Pointer to determine if the Outbound Post List FIFO is empty. When the Bottom and Top pointers contain the same value the I<sub>2</sub>O Outbound Post Queue Interrupt Status bit is cleared by the PowerSpan II. Alternatively, the interrupt can be masked out, leaving it to the Host processor to poll the Outbound Queue Register. When the Outbound Post List FIFO is empty, the PowerSpan II returns 0xffff\_ffff when the Host processor reads the Outbound Queue Register.

Once the Host processor has processed the MFA, it writes the MFA back to the Outbound Queue Register (0x044) to place it back in the Outbound Free List FIFO. PowerSpan II accepts the write transaction and takes responsibility for replacing the MFA in the Outbound Free List FIFO at the address pointed to by the Outbound Free List Top Pointer Register. PowerSpan II then increments the Outbound Free List Top Pointer Register by four.

### 2.6.6 Pull Capability

The  $I_2O$  2.0 Specification defines an enhancement that allows the IOP to provide a capability to pull the  $I_2O$  Inbound messages from the Host memory. In this configuration the Host places the  $I_2O$  Inbound messages in MFs located in the Host memory as opposed to the IOP local memory. The Host must also implement a Host Free List FIFO in Host memory. This FIFO does not replace the IOP Inbound Free List FIFO, which must still be implemented in the IOP local memory to support normal inbound message passing, or peer to-peer message passing. This capability increases server performance by virtue of the Host CPU and server platforms being optimized for memory access rather than I/O access. Under this option, the Host can post Inbound messages to the IOP with a single write to the IOP. The IOP pulls the MF from the Host memory and releases a MF to the Host by generating a single write to Host memory. The Pull capability applies only to the IOP's Inbound Queue and to the posting of messages by the Host.

The Pull model requires 16 byte alignment of the message frames, therefore, the least significant four bits of the MFA are always zero. The Pull options use these four bits to create an Extended MFA (XMFA). The Pull model uses the least significant bit of the XMFA to indicate a pull request. This bit is the Pull Indicator or the P bit. Bits 3:1 of the XMFA indicate the number of data transfers required to copy the message. This number is system specific and has no effect on the PowerSpan II's behavior.

To prevent overflow of the local Inbound Post List FIFO the IOP reports an Inbound Post List Headroom to the Host, which is the difference between the size of the Inbound Post List FIFO and the total number of IOP Inbound Message Frames allocated by the IOP in local memory. This is the number of XMFAs the Host can Post to the I<sub>2</sub>O Inbound Post List FIFO and guarantee not to overflow the Inbound Post List FIFO. The IOP must not allocate more MFAs in the Inbound Free List than can be accepted in the Inbound Post List (along with XMFAs) without causing overflow.

Equation

#Inbound Free MFAs + #XMFAs <= FIFO\_SIZE (see "I2O Queue Base Address Register" on page 423 for more information)

#### 2.6.6.1 Host Posting

The Host can post a message to the IOP using the Pull Capability by using the following methods:

- reading an XMFA from the Host Free List FIFO
- writing an Inbound Message to the MF in Host memory indicated by the XMFA
- writing an XMFA to the Inbound Queue Register at offset 0x040 of the I<sub>2</sub>O target image on PCI

The XMFA is processed by the PowerSpan II in the same way as a normal MFA posted to the local IOP by the Host or external IOP. The IOP can determine if the XMFA is posted using the Pull Capability and to pull the message from the system memory. To release an XMFA back to the Host platform the IOP writes the XMFA back to the Host Free List FIFO which resides in system memory.

### 2.6.6.2 Host Free List Address

The address and size of the Host Free List FIFO is provided to the IOP by the  $I_2O$  System Host in an  $I_2O$  defined "IOP Message Pull Extensions" Message. The Host Free List FIFO structure is located at a memory boundary equal to its size to enable the IOP to know when it has reached the end of the FIFO. When the IOP returns XMFAs to the Host Free List FIFO sets the P bit to 1. When the IOP reaches the end of the FIFO resets the FIFO index to the base address and this time through write the P bit to 0. This allows the Host to track the progress of the local IOP in returning XMFAs.



Figure 11: PowerSpan II I<sub>2</sub>O Pull Capability

Figure 11 illustrates the following steps in PowerSpan II I<sub>2</sub>0 pull capability:

- 1. Host reads XMFA from Host Free List
- 2. Host writes message to MF in Host memory
- 3. Host writes XMFA to Inbound Queue

- 4. Local processor reads XMFA from the Inbound Post List FIFO
- 5. Local processor copies MF from Host memory
- 6. Local processor writes XMFA to Host Free List Index

### 2.6.7 Outbound Option

The  $I_2O$  2.0 Specification allows for the IOP to provide an enhanced capability to post reply messages to the Host. This mechanism is independent of the Pull Capability of the previous section. This capability reduces the number of reads that the Host must perform to the IOP. Under the Outbound Option Operation, the local IOP copies out the reply message to the Host system memory and then posts the message by performing a single write to the Host memory. The Host need only to write to the PowerSpan II to return the MFA.

The Outbound option requires 16-byte alignment of the message frames and thus the least significant four bits of the MFA are always zero. The Outbound option uses these four bits to create and Extended MFA (XMFA). The least significant bit of the outbound XMFA is the Cycle Indicator bit or the C bit.

#### 2.6.7.1 Host Posting

To post a message to the Host, the IOP completes the following:

- 1. Obtains an Outbound MFA from the Outbound Free List FIFO.
- 2. Copies out the reply message to the MF indicated by the Host allocated Outbound MFA.
- 3. Posts the Outbound MFA to the HostPostList FIFO pointed to by the IOP Outbound Index Register, setting the least significant bit of the MFA to 1, and increment the IOP Outbound Index Register by writing to the IOP Outbound Index Increment Register.

The PowerSpan II IOP Outbound Index Register is initialized by the IOP with a value received along with the Host Outbound Post List FIFO Size through an "IOP Message Outbound Extensions" message from the Host. The size of the Host Outbound Post List FIFO is specified in the HOPL\_SIZE bit in the I2O\_CSR register.

The PowerSpan II IOP Outbound Index Register points to the Top of the Host Outbound Post List FIFO implemented in Host memory. When it reaches the end of the FIFO the IOP resets the IOP Outbound Index Register to the base of the FIFO. The IOP writes XMFAs to the FIFO with the C bit set to 0, and continues to alternate this pattern. This allows the Host to determine where the IOP processor has last written to the FIFO. PowerSpan II also implements a Host Outbound Index Register where the Host will write its Host Outbound Post List FIFO Index after servicing Outbound reply messages posted using the Outbound Option. The Host Outbound Index Register points to the Bottom of the Host Outbound Post List FIFO. PowerSpan II maps this register into the PowerSpan II I<sub>2</sub>O Target Image Shell Interface at the offset specified in the I<sub>2</sub>O Host Outbound Index Offset Register. This register is initialized by the IOP with an offset provided by the Host through the IOP Message Outbound Extensions message.

When  $I_2O$  Extended capabilities are enabled with I2O\_CSR[XI2O\_EN], PowerSpan II will set an interrupt status bit in the  $I_2O$  Outbound Post List Interrupt Status register when the  $I_2O$  Host Outbound Index Register is not equal to the  $I_2O$ IOP Outbound Index Register. This indicates that the Host Outbound Post List FIFO is non-empty.

PowerSpan II compares the value of the Host Outbound Index Register to the IOP Outbound Index Register. If they are identical the Interrupt is cleared by the PowerSpan II. If these registers differ, then it is assumed that the PowerSpan II has posted additional Outbound reply messages which have not yet been serviced by the Host, and therefore, the PowerSpan II continues to assert the Interrupt to the Host. The Host will post empty MFAs back to the IOP by writing to the PowerSpan II's Outbound Queue Register (0x044), with the C bit set to zero. PowerSpan II services the written MFA the same as a normal Outbound MFA being returned to the IOP.



Figure 12: PowerSpan II I<sub>2</sub>O Outbound Capability

Figure 12 illustrates the following steps in PowerSpan II I<sub>2</sub>0 outbound capability:

- 1. Local processor reads the Outbound Free List to obtain an MFA
- 2. Local processor writes the MF in the Host memory
- 3. Local processor writes the MFA to the Host Outbound Post List FIFO, setting the P bit

- 4. Host processor reads the XMFAs from the Host Outbound Post List
- 5. Host writes the XMFA to the Outbound Queue (0x044)

### 2.6.8 I<sub>2</sub>O Standard Registers

This section defines the standard  $I_2O$  register set supported by PowerSpan II. These registers are accessible within the PowerSpan II  $I_2O$  target image. In Table 10, all standards-based registers are in italics.

| Offset<br>(HEX)        | Register<br>Mnemonic                    | Register Name                                                 |  |  |
|------------------------|-----------------------------------------|---------------------------------------------------------------|--|--|
| 0x000-028              | PowerSpan II R                          | eserved                                                       |  |  |
| 0x030                  | OPL_IS                                  | I <sub>2</sub> 0 Outbound Post List Interrupt Status Register |  |  |
| 0x034                  | OPL_IM                                  | I <sub>2</sub> 0 Outbound Post List Interrupt Mask Register   |  |  |
| 0x038                  | PowerSpan II Reserved                   |                                                               |  |  |
| 0x040                  | IN_Q                                    | I <sub>2</sub> 0 Inbound Queue                                |  |  |
| 0x044                  | OUT_Q                                   | I <sub>2</sub> 0 Outbound Queue                               |  |  |
| 0x048-[HOST_OIO]-<br>4 | PowerSpan II R                          | eserved                                                       |  |  |
| [HOST_OIO]             | HOST_OI                                 | I <sub>2</sub> O Host Outbound Index Register                 |  |  |
| [HOST_OIO]+4-<br>0xFF  | PowerSpan II Reserved                   |                                                               |  |  |
| 0x100-xxx              | I <sub>2</sub> 0 Inbound Message Frames |                                                               |  |  |

Table 10: PowerSpan II I20 Target Image Map

The I<sub>2</sub>O Shell Interface is located in the first 4 Kbytes of the PowerSpan II I<sub>2</sub>O target image. The I<sub>2</sub>O Inbound Message Frames occupies offsets above the 4 Kbyte point of the PowerSpan II I<sub>2</sub>O target image. The upper limit of the I<sub>2</sub>O Inbound Message Frames is determined by the size of the PowerSpan II I<sub>2</sub>O target image, as defined by the PCI\_I2O\_CTL[BS] register.

The offset of the  $I_2O$  Host Outbound Index Register is programmed in the  $I_2O$  Host Outbound Index Offset Register (HOST\_OIO) of the PowerSpan II Register Map.

The following tables show the  $I_2O$  register definitions.

| Registe     | r Name: OPL_IS            | Register Offset: 030 |                           |       |  |  |
|-------------|---------------------------|----------------------|---------------------------|-------|--|--|
| PCI<br>Bits |                           |                      |                           |       |  |  |
| 31-24       | I <sub>2</sub> O Reserved |                      |                           |       |  |  |
| 23-16       | I <sub>2</sub> O Reserved |                      |                           |       |  |  |
| 15-08       | I <sub>2</sub> O Reserved |                      |                           |       |  |  |
| 07-00       | I <sub>2</sub> O Reserved | OPL_<br>ISR          | I <sub>2</sub> O Reserved | 24-31 |  |  |

#### **OPL\_IS** Description

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                              |
|---------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPL_ISR | R    | Px_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<br>value of the interrupt mask bit does not affect this<br>bit. |

The  $I_20$  2.0 Specification requires the Outbound Post\_List Interrupt Status register to be located at offset 0x30 in the *Memory* region specified by the first base address register ( $I_20$  Base Address Register - Px\_BSI2O).

When the  $I_20$  messaging unit in PowerSpan II is enabled (I2O\_CSR[I2O\_EN] = 1), a Memory access from PCI to offset 0x30 from Px\_BSI2O is destined for OPL\_IS.

When the  $I_20$  messaging unit in PowerSpan II is not enabled, the OPL\_IS register is not visible to read or write access. The register essentially disappears from all PowerSpan II memory maps.

OPL\_ISR is bit three of this register.

| Register Name: OPL_IM |                           |        | Register Offs             | set: 034 |  |
|-----------------------|---------------------------|--------|---------------------------|----------|--|
| PCI<br>Bits           |                           |        |                           |          |  |
| 31-24                 | I <sub>2</sub> O Reserved |        |                           |          |  |
| 23-16                 | I <sub>2</sub> O Reserved |        |                           |          |  |
| 15-08                 | I <sub>2</sub> O Reserved |        |                           |          |  |
| 07-00                 | I2O Reserved              | OP_ISM | I <sub>2</sub> O Reserved | 24-31    |  |

### Table 12: I2O Outbound Post List Interrupt Mask Register

#### **OPL\_IM** Description

| Name   | Туре | Reset<br>By | Reset<br>State | Function                                    |
|--------|------|-------------|----------------|---------------------------------------------|
| OP_ISM | R/W  | Px_RST      | 0              | Outbound Post_List Interrupt Mask           |
|        |      |             |                | 0 = Outbound Post_List Interrupt is enabled |
|        |      |             |                | 1 = Outbound Post_List Interrupt is masked  |
|        |      |             |                |                                             |

The  $I_20 2.0$  Specification requires the Outbound Post\_List Interrupt Mask register to be located at offset 0x34 in the memory region specified by the first base address register (I<sub>2</sub>0 Base Address Register - Px\_BSI2O).

When the  $I_20$  messaging unit in PowerSpan II is enabled (I2O\_CSR[I2O\_EN] = 1), a memory access from PCI to offset 034h from Px\_BSI2O is destined for OPL\_IM.

When the  $I_20$  messaging unit in PowerSpan II is not enabled, the OPL\_IM register is not visible to read or write access. The register essentially disappears from all PowerSpan II memory maps.

OP\_ISM is bit 3 of this register.

#### Table 13: I2O Inbound Queue

| Register Name: IN_Q |     | Register Offset: ( |             |  |
|---------------------|-----|--------------------|-------------|--|
| PCI<br>Bits         | Fun | ction              | PPC<br>Bits |  |
| 31-24               | Μ   | FA                 | 0-7         |  |
| 23-16               | М   | FA                 | 8-15        |  |
| 15-08               | М   | FA                 | 16-23       |  |
| 07-00               | М   | FA                 | 24-31       |  |

#### **IN\_Q** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                      |
|-----------|------|-------------|----------------|-------------------------------|
| MFA[31:0] | R/W  | Px_RST      | 0              | Inbound Message Frame Address |

**MFA**: The Inbound Message Frame Address specifies locations in the IOP memory map where Inbound Message Frames reside.

The Message Frame Address is the offset from the beginning of the  $I_2O$  target image window in the destination bus memory map and the destination address where the Message Frame begins.

A read from the  $I_2O$  Inbound Queue returns the next available MFA from the  $I_2O$  Inbound Free List FIFO. This is a destructive read.

A write to this offset is used to place a MFA into the  $I_2O$  Inbound Post List FIFO. The PowerSpan II accepts the write cycle as a posted write and is responsible for completing the cycle on the destination bus.

When the  $I_20$  Interface in PowerSpan II is not enabled, the IN\_Q register is not visible to read or write access. The register essentially disappears from all PowerSpan II memory maps.

### Table 14: I2O Outbound Queue

| Register Name: OUT_Q |     | Register Offset: 04 |             |  |
|----------------------|-----|---------------------|-------------|--|
| PCI<br>Bits          | Fun | ction               | PPC<br>Bits |  |
| 31-24                | М   | FA                  | 0-7         |  |
| 23-16                | М   | FA                  | 8-15        |  |
| 15-08                | М   | FA                  | 16-23       |  |
| 07-00                | М   | FA                  | 24-31       |  |

**OUT\_Q** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                       |
|-----------|------|-------------|----------------|--------------------------------|
| MFA[31:0] | R/W  | Px_RST      | 0              | Outbound Message Frame Address |

**MFA**: The Outbound Message Frame Address specify locations in the Host memory map where Outbound Message Frames reside.

The Message Frame Address is the Host memory address of the Message Frame.

A read from the  $I_2O$  Outbound Queue returns the next MFA from the  $I_2O$  Outbound Post List FIFO. This is a destructive read.

A write to this offset places a Free Host MFA into the  $I_2O$  Outbound Free List FIFO. PowerSpan II accepts the write cycle as a posted write and is responsible for completing the cycle on the destination bus.

When the  $I_20$  Interface in PowerSpan II is not enabled, the OUT\_Q register is not visible to read or write access. The register essentially disappears from all PowerSpan II memory maps.

| Table 15: I2O Host Outbound Index Register |
|--------------------------------------------|
|--------------------------------------------|

| Registe     | r Name: HOST_OI | Register Offset: [HOST_OIO] |   |   |            |
|-------------|-----------------|-----------------------------|---|---|------------|
| PCI<br>Bits | Fun             | ction                       |   |   | PB<br>Bits |
| 31-24       | (               | DI                          |   |   | 0-7        |
| 23-16       | (               | DI                          |   |   | 8-15       |
| 15-08       | (               | DI                          |   |   | 16-23      |
| 07-00       | OI              |                             | 0 | 0 | 24-31      |

#### **HOST\_OI** Description

| 1 | Name    | Туре | Reset<br>By | Reset<br>State | Function            |  |
|---|---------|------|-------------|----------------|---------------------|--|
| 0 | 0[29:0] | R/W  | Px_RST      | 0              | Host Outbound Index |  |

**OI**: This register indicates the address in Host memory from which the Host is to retrieve the next Outbound XMFA. This register is initialized by the IOP with an index received from the Host in an  $I_2O$  message. The register is written by the Host during  $I_2O$  Outbound Option message passing.

When the  $I_2O$  Host Outbound Index Register and the  $I_2O$  IOP Outbound Index Register differ, the Outbound Post List Interrupt Status bit is set in the OPL\_IS register at offset 0x30 of the PCI  $I_2O$  target Image. When these registers contain the same Host memory address, the Interrupt is cleared.

This feature is only supported if the  $I_2O$  Outbound Option is enabled with the XI2O\_EN bit in the I2O\_CSR register and I2O\_EN.

The HOPL\_SIZE bit in the I2O\_CSR register determines the alignment of this Index register.

The Register Offset is specified in the  $I_2O$  Host Outbound Index Offset Register at offset 0x548 of the PowerSpan II Register Map. The  $I_2O$  Host Outbound Index Register must be located in the lower 4 Kbytes of the PCI  $I_2O$  target image map.

When the  $I_20$  Interface in PowerSpan II is not enabled, the HOST\_OI register is not visible to read or write access. The register essentially disappears from all PowerSpan II memory maps.



# 3. Processor Bus Interface

This chapter describes the functionality of the Processor Bus Interface. Both the Single PCI PowerSpan II and Dual PCI PowerSpan II have a Processor Bus Interface. The following topics are discussed:

- "Overview" on page 101
- "PB Slave Interface" on page 103
- "PB Master Interface" on page 123

## 3.1 Overview

The PowerSpan II Processor Bus (PB) Interface directly connects with a wide range of processors in order to meet the demands of high end systems, the PB Interface operates up to100 MHz and has a 64-bit data bus.

# 3.2 Interface Support

The PowerSpan II Processor Bus Interface supports the following PowerPC devices:

- PowerQUICC II (MPC8260, and MPC8260A)
- MPC74xx
- PowerPC 7400
- PowerPC 750
- PowerPC 740
- PowerPC 603e processors

These interfaces are not identical, but for the most part, the processor interface on the PowerSpan II is referred to simply as the Processor Bus (PB). The interface sections in this chapter highlight where the PowerSpan II operates differently to address specific processor requirements as the need arises. An example of this different operation is the extended cycles with the MPC8260.



The MPC8260 and PowerPC 7400 must operate in 60x compatible bus mode to be used with PowerSpan II. In single MPC8260 mode the processor cannot share the bus with other external masters.

### 3.2.1 Terminology

The following terms are used in the Processor Bus Interface descriptions:

- **address retry window**: refers to the clock following the assertion of AACK\_, which is the latest a snooping master can request for an address tenure re-run.
- window of opportunity: refers to the clock following the assertion of ARTRY\_. The retrying master has to request the bus on this clock to ensure that it is the next bus owner. This enables it to perform the transactions required to maintain cache coherency.

### 3.2.2 PB Bus Interface Descriptions

The PB Bus Interface is described in terms of its master and slave functions. The PCI interfaces on PowerSpan II are described in terms of its PCI master and PCI target functions. This description is largely independent of PCI-1 versus PCI-2, or the assignment of the Primary PCI Interface functions. Exceptions to these rules are noted in the manual.

### 3.2.2.1 Transaction Ordering

For information on PowerSpan II's PCI transaction ordering refer to "Transaction Ordering" on page 47.

# 3.3 **PB Slave Interface**

### 3.3.1 PowerSpan II as PB Slave

PowerSpan II becomes active as a PB slave when one of the following conditions occurs:

- A processor bus master accesses a PCI resource, generating a memory or I/O space access
- A processor bus master accesses a PCI resource, generating a configuration or IACK access
- A processor bus master accesses PowerSpan II registers

This section covers the first two of these conditions. See "Register Access" on page 283 for a discussion of the last two items in the bullet list above.

The operation of the PB Slave is described below by dividing the PB Slave transaction into the following different phases:

• Address Phase: This section discusses the decoding of processor bus accesses.

- Data Transfer: This section describes control of transaction length.
- **Terminations**: This section describes the terminations supported by PowerSpan II, and exception handling.



The PowerSpan II PB Slave supports cacheable accesses to PCI, but it does not guarantee coherency if more than one processor accesses a given range of memory. In order to address this issue, operating system pages mapped to PowerSpan II must have the Memory Coherency Attribute (M) set to zero. PowerSpan II performs PCI read prefetches. These reads can be cached in an internal queueing memory within PowerSpan II — if PRKEEP is set to 1. When a write is performed to a prefetched address, a subsequent read yields stale data. Prefetching attributes for each image map must meet the systems cache coherency requirements.

Pull-up resistors are not required on the processor bus address (PB\_A[0:31]) and data (PB\_D[0:63]) signals to guarantee functional operation of PowerSpan II. However, adding resistors to the address and data signals minimizes the current drawn by the PowerSpan II's tristated buffers when the bus is in an idle condition. The system designer must decide whether to add these resistors to the address and data bus.

### 3.3.2 Address Phase

### 3.3.2.1 Transaction Decoding

Transaction decoding on the PB Slave operates in both normal decode mode and Master-based decode mode.

When PowerSpan II is in normal decode mode, each PB slave monitors the Processor Bus Address (PB\_A[]). When the address falls into one of the programmed windows, and the Transfer Type (PB\_TT[]) is supported, PowerSpan II claims the address tenure.



A PB slave image is defined as the range of processor bus physical address space that decodes a PowerSpan II access.

PB slave image location is controlled by setting the Base Address (BA) field in the "Processor Bus Slave Image x Base Address Register" on page 350. PB slave image size is controlled by setting the Block Size (BS) field in the "Processor Bus Slave Image x Control Register" on page 342.

PowerSpan II supports eight general purpose slave images and four specialty slave images. A general purpose slave image generates memory or I/O reads and writes to the PCI bus. For example, the eight general purpose slave images can support the local bus traffic of four MPC8260 SCCs, two threads of CPU traffic destined for PCI-1, and two threads destined for PCI-2. The specialty images are used for the generation of PCI Configuration cycles on PCI-1 and PCI-2, IACK reads on PCI-1, IACK reads on PCI-2 and PowerSpan II register accesses.

The PB slave image also controls how an incoming PB transaction is mapped to the destination port on PowerSpan II. For example, there are bits for endian mapping, prefetch behavior, etc. Table 16 describes the programming model for a PB Slave Image Control register.

The PB slave image only claims a transaction when all of the following conditions are met:

- the external address matches the slave image
- the transaction codes are supported



In normal decoding mode (see "Transaction Decoding" on page 104), the PB slave image claims transactions initiated by the PowerSpan II PB Master Interface if the transaction meets the two conditions listed above. In order to avoid the PB slave from claiming transactions from the a transaction PowerSpan II PB Master Interface, the Master-based Decode functionality can be enabled. Table 16 describes the bits and default settings of the PB Slave Image Control register (see page 342).

| Bits        | Туре | Description                                                                                                     | Default Setting                                                                                              |
|-------------|------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| IMG_EN      | R/W  | Enables the PB slave image to decode in the specified physical address range.                                   | Disabled                                                                                                     |
| TA_EN       | R/W  | Enables address translation (see "Processor Bus<br>Slave Image x Translation Address Register" on<br>page 348). | Disabled                                                                                                     |
| BS[4:0]     | R/W  | Sets the block size of the PB slave image. The size of the image is 4 Kbyte * 2 <sup>BS</sup> .                 | Default value is 0. It<br>can be programmed<br>through any port after<br>reset, or loaded<br>through EEPROM. |
| MODE        | R/W  | Maps the incoming PB transaction to either Memory or I/O space on the PCI bus.                                  | Defaults to Memory space.                                                                                    |
| DEST        | R/W  | Directs the incoming PB transaction to either of PCI-<br>1 or PCI-2                                             | Defaults to PCI-1                                                                                            |
| MEM_IO      | R/W  | Enables 1,2,3, or 4 byte memory reads on the PCI bus(es).                                                       | Regular I/O mode                                                                                             |
| PRKEEP      | R/W  | Enables PowerSpan II to keep prefetch read data over subsequent transactions.                                   | Disabled                                                                                                     |
| END[1:0]    | R/W  | Sets endian mapping to little-endian, PowerPC little-<br>endian, or big-endian                                  | Big-endian is the default mode.                                                                              |
| RD_AMT[2:0] | R/W  | Controls the prefetch read amount. Can be programmed up to a maximum of 128 bytes.                              | 8 bytes is the default prefetch read amount                                                                  |

Table 16: Programming Model for PB Slave Image Control Register



PB memory management supports a variety of memory/cache access attributes: write through (W), caching-inhibited (I), and memory coherency (M). Although PowerSpan II does not decode these attributes — external pins PB\_GBL\_ and PB\_CI\_ are output only— specific guidelines must be followed to ensure correct system operation. These guidelines are shown in Table 17.

| PowerSpan II Resource | Memory Coherency | Caching Inhibited                                        |
|-----------------------|------------------|----------------------------------------------------------|
| Registers             | M=0              | I=1                                                      |
| PCI I/O space         | M=0              | l=1                                                      |
| PCI Memory space      | M=0              | External L2 cache: I=1<br>No External L2 cache: I=0 or 1 |

#### Table 17: Recommended Memory/Cache Attribute Settings



Register and PCI I/O space accesses require I=1 because PowerSpan II does not accept burst transactions to these resources.

### Master-based Decode Mode

The PB Slave Interface supports Master-based decode mode when the internal PowerSpan II processor bus arbiter is enabled (see "Processor Bus Arbitration" on page 168) and the Master Decode Enable (MD\_EN) bit is set in the "Processor Bus Slave Image x Control Register" on page 342. When Master-based decode is enabled, a PB slave image only claims a transaction decoded for its specified physical address space if it originates from specific processor bus master or masters.

External bus masters are selected for a specific target by setting one or more of the M1 to M3 bits in the "Processor Bus Slave Image x Translation Address Register" on page 348.

The PB slave image only claims a transaction when all of the following conditions are met:

- the address matches the slave image
- the transaction codes are supported
- Mx is set and the identified master is requesting a transaction



PowerSpan II behavior is undefined if more than one identically programmed, or overlapping, slave image claims a transaction. For example, if two slave image have the same base address and size, then they must have unique master bits set in the "Processor Bus Slave Image x Translation Address Register" on page 348.

### 3.3.2.2 Transfer Types

The PB Slave only claims processor bus transactions with specific transfer types. The supported transfer types consist of address only, read, and write. They are defined in Table 18.

All reads are treated as delayed reads and can be single cycle, extended or bursts. All writes are treated as posted writes and can be single cycle, extended or bursts. PowerSpan II handles address only cycles by asserting PB\_AACK\_ — no data transfer occurs.

Address only transfer types are claimed to ensure PowerSpan II does not negatively impact cache control, reservation, or ordering transactions on the processor bus.

| TT[0:4]      | Name                              |  |  |  |  |
|--------------|-----------------------------------|--|--|--|--|
| Address Only |                                   |  |  |  |  |
| 00000        | Clean Block                       |  |  |  |  |
| 00100        | Flush Block                       |  |  |  |  |
| 01000        | Sync Block                        |  |  |  |  |
| 01100        | Kill Block                        |  |  |  |  |
| 10000        | eieio                             |  |  |  |  |
| 11000        | tlb invalidate                    |  |  |  |  |
| 00001        | lwarx                             |  |  |  |  |
| 01001        | tlb sync                          |  |  |  |  |
| 01101        | icbi                              |  |  |  |  |
| Reads        |                                   |  |  |  |  |
| 01010        | Read                              |  |  |  |  |
| 01110        | Read with intent to modify        |  |  |  |  |
| 11010        | Read Atomic                       |  |  |  |  |
| 11110        | Read with intent to modify atomic |  |  |  |  |
| 01011        | Read with no intent to cache      |  |  |  |  |
| Writes       |                                   |  |  |  |  |
| 00010        | Write with flush                  |  |  |  |  |
| 00110        | Write with kill                   |  |  |  |  |
| 10010        | Write with flush atomic           |  |  |  |  |

Table 18: PowerSpan II PB Slave Transfer Types

Because PowerSpan II does not have a cache, all read and write transfer types are treated the same. For example, a Read with Intent to Modify command (PB\_TT= 01110) is handled the same way as a Read Atomic command (PB\_TT= 11010).

PowerSpan II performs PCI read prefetches and stores read data in an internal buffer when the Prefetch Keep (PRKEEP) bit is set to 1. The purpose of a prefetch read is to fetch read information before the master requests the information. If the master then requests the information the target can respond immediately with the prefetched information. This ability protects the master from slow access times for information it requires. However, when a write is performed to a prefetched address, a subsequent read could yield stale data. In order to guarantee there is no stale data, set the PRKEEP bit to 0. This function disables the internal buffer to ensure there is no stale data. By setting this PRKEEP bit to 0 PowerSpan II is unable to perform PCI read prefetches and read performance may be decreased in the system.



Prefetching attributes for each image map must meet the system's cache coherency requirements

## 3.3.2.3 Address Tenure

Each slave on the PB Interface is responsible for the following:

- decoding the address broadcast by the master
- claiming the address tenure with PB\_AACK\_ assertion
- managing the data termination signals during the data tenure

The PB Slave uses PB\_AACK\_ to limit the level of address pipelining to one. The earliest the PB slave can assert PB\_AACK\_ is two clocks after PB\_TS\_.

The PB Slave does not acknowledge subsequent address phases until it finishes its participation in the current data tenure. If the previous address phase was claimed by another slave, the PB slave does not acknowledge the current address phase until the previous slave completes its data tenure.

The use of PB\_ARTRY\_ by the PB Slave is enabled by the Address Retry Enable (ARTRY\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361. If the ARTRY\_EN bit is set to 0, the PB\_ARTRY\_ signal is not asserted and the PB slave retains ownership of the bus. The PB Slave retains ownership after the assertion of PB\_AACK\_ and until it is able to assert PB\_TA.

When ARTRY\_EN has a value of 1, the PB Slave can assert PB\_ARTRY\_. The default setting is 0 (ARTRY\_EN is disabled). The PB Interface has higher performance if the ARTRY\_EN bit is enabled. PowerSpan II's PB Master or another external master can gain access to the bus when PowerSpan II cannot assert PB\_TA.

When ARTRY\_EN is enabled, the PB Slave asserts PB\_ARTRY\_ in the following situations:

- a write destined for PCI cannot be internally buffered
- when a read request has been latched and read data is being fetched from PCI
- a register access when a load from EEPROM is in progress
- writing to registers when another bus (PCI-1, PCI-2) is also writing to the register block

If the assertion of PB\_ARTRY\_ is enabled, it occurs the clock after PB\_AACK\_ within the *address retry window*.

#### 3.3.2.4 Address Translation

The incoming address on the PB Interface can have a translation offset applied to it using the TADDR[19:0] field of the "Processor Bus Slave Image x Translation Address Register" on page 348. When the translation offset is applied to the incoming PB address, the translated address appears on the destination bus (PCI-1 or PCI-2). The translation offset replaces the PB address, up to the size of the image. TADDR[19:0] replaces PB address lines PB\_A[0:19].

For example, if TADDR[19:0] = 0x12345 and the BS bit in the PB\_SIx\_CTL register equals 0 (4-Kbyte image) and the address on the processor bus is PB\_A[0:31] = 0x78563412, then the PCI address becomes 0x12345412. Table 19 summarizes the relationship between translation offset, processor bus address, and block size of the image.

| PB_SIx_TADDR | Processor Bus Address (PB_A) | BS bit<br>(PB_SIx_CTL register) | Block Size |
|--------------|------------------------------|---------------------------------|------------|
| 31           | 0                            | 10011                           | 2G         |
| 31:30        | 0:1                          | 10010                           | 1G         |
| 31:29        | 0:2                          | 10001                           | 512M       |
| 31:28        | 0:3                          | 10000                           | 256M       |
| 31:27        | 0:4                          | 01111                           | 128M       |
| 31:26        | 0:5                          | 01110                           | 64M        |
| 31:25        | 0:6                          | 01101                           | 32M        |
| 31:24        | 0:7                          | 01100                           | 16M        |
| 31:23        | 0:8                          | 01011                           | 8M         |
| 31:22        | 0:9                          | 01010                           | 4M         |
| 31:21        | 0:10                         | 01001                           | 2M         |
| 31:20        | 0:11                         | 01000                           | 1M         |
| 31:19        | 0:12                         | 00111                           | 512k       |
| 31:18        | 0:13                         | 00110                           | 256k       |
| 31:17        | 0:14                         | 00101                           | 128k       |
| 31:16        | 0:15                         | 00100                           | 64k        |
| 31:15        | 0:16                         | 00011                           | 32k        |
| 31:14        | 0:17                         | 00010                           | 16k        |
| 31:13        | 0:18                         | 00001                           | 8k         |
| 31:12        | 0:19                         | 00000                           | 4k         |

Table 19: Translation Address Mapping

## 3.3.2.5 Address Parity

Address parity checking is provided on each byte of the address bus. Address parity bit assignments are defined in Table 20.

| Address Bus | Address Parity |
|-------------|----------------|
| PB_A[0:7]   | PB_AP[0]       |
| PB_A[8:15]  | PB_AP[1]       |
| PB_A[16:23] | PB_AP[2]       |
| PB_A[24:31] | PB_AP[3]       |

Table 20: PowerSpan II PB Address Parity Assignments

When the PB Slave detects an address parity error during its decode process it does not assert Address Acknowledge (PB\_AACK\_). Address parity checking is enabled with the Address Parity Enable (AP\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361. Odd parity versus even parity is configured with the PARITY bit in the same register.

## Special Parity Requirements with the MPC8260

Address parity and data parity must be specially programmed in a joint PowerSpan II and MPC8260 application.

In a joint application all memory accesses from the MPC8260 to PowerSpan II must be routed through the internal memory controller on the MPC8260. When the data is passed through the memory controller both address parity and data parity can be used in the system.

If accesses do not pass through the memory controller of the MPC8260 before reaching PowerSpan II, and PowerSpan II has either or both address and data parity enabled, then PowerSpan II reports parity errors on the transaction.

To enable or disable address parity in PowerSpan II, set the Address Parity Enable (AP\_EN) bit in the Processor Bus Miscellaneous Control and Status (PB\_MISC\_CSR) register (see page 361).

To enable or disable data parity in PowerSpan II, set the Data Parity Enable (AP\_EN) bit in the Processor Bus Miscellaneous Control and Status (PB\_MISC\_CSR) register (see page 361).

## 3.3.3 Data Phase

## 3.3.3.1 Transaction Length

The PB Slave supports a set of the data transfer sizes supported by the embedded PowerPC family. All data transfer sizes supported by the PowerSpan II PB Slave are illustrated in Table 21. Burst transfers are indicated by the assertion of Processor Bus Transfer Burst (PB\_TBST\_). The shaded regions indicate transaction sizes unique to the MPC8260.

| Transfer Size                  | Bytes | PB_TBST | PB_TSIZ[0] | PB_TSIZ[1:3] |
|--------------------------------|-------|---------|------------|--------------|
| Byte                           | 1     | 1       | 0          | 001          |
| Half-word                      | 2     | 1       | 0          | 010          |
| Tri-byte                       | 3     | 1       | 0          | 011          |
| Word                           | 4     | 1       | 0          | 100          |
| Five bytes                     | 5     | 1       | 0          | 101          |
| Six bytes                      | 6     | 1       | 0          | 110          |
| Seven bytes                    | 7     | 1       | 0          | 111          |
| Double Word (DW)               | 8     | 1       | 0          | 000          |
| Extended Double (MPC8260 only) | 16    | 1       | 1          | 001          |
| Extended Triple (MPC8260 only) | 24    | 1       | 1          | 010          |
| Burst (Quad DW)                | 32    | 0       | 0          | 010          |

#### Table 21: PowerSpan II PB Transfer Sizes

## 3.3.3.2 Data Alignment

Embedded processor bus transfer sizes and alignments, defined in Table 21 and Table 22, are supported by the PB Slave for transaction accesses. The size and alignment combinations defined in Table 22 are supported by the MPC8260, PowerPC 740, and PowerPC 750 processors. The shaded table cells show transactions that support the PowerPC 7400 processor.

Table 22 lists the size and alignment transactions less than or equal to 8 bytes.PowerSpan II register accesses are limited to 4 bytes or less.



The PowerSpan II port size is 64-bit.

| Size      | TSIZ[0:3] | A[29:31] | Data Bus Byte Lanes |    |    |    |    |    |    |    |
|-----------|-----------|----------|---------------------|----|----|----|----|----|----|----|
|           |           |          | 0                   | 1  | 2  | 3  | 4  | 5  | 6  | 7  |
| Byte      | 0001      | 000      | D0                  |    |    |    |    |    |    |    |
|           | 0001      | 001      |                     | D1 |    |    |    |    |    |    |
|           | 0001      | 010      |                     |    | D2 |    |    |    |    |    |
|           | 0001      | 011      |                     |    |    | D3 |    |    |    |    |
|           | 0001      | 100      |                     |    |    |    | D4 |    |    |    |
|           | 0001      | 101      |                     |    |    |    |    | D5 |    |    |
|           | 0001      | 110      |                     |    |    |    |    |    | D6 |    |
|           | 0001      | 111      |                     |    |    |    |    |    |    | D7 |
| Half word | 0010      | 000      | D0                  | D1 |    |    |    |    |    |    |
|           | 0010      | 001      |                     | D1 | D2 |    |    |    |    |    |
|           | 0010      | 010      |                     |    | D2 | D3 |    |    |    |    |
|           | 0010      | 011      |                     |    |    | D3 | D4 |    |    |    |
|           | 0010      | 100      |                     |    |    |    | D4 | D5 |    |    |
|           | 0010      | 101      |                     |    |    |    |    | D5 | D6 |    |
|           | 0010      | 110      |                     |    |    |    |    |    | D6 | D7 |
| Tri-byte  | 0011      | 000      | D0                  | D1 | D2 |    |    |    |    |    |
|           | 0011      | 001      |                     | D1 | D2 | D3 |    |    |    |    |
|           | 0011      | 010      |                     |    | D2 | D3 | D4 |    |    |    |
|           | 0011      | 011      |                     |    |    | D3 | D4 | D5 |    |    |
|           | 0011      | 100      |                     |    |    |    | D4 | D5 | D6 |    |
|           | 0011      | 101      |                     |    |    |    |    | D5 | D6 | D7 |

 Table 22: PowerSpan II Processor Bus Single Beat Data Transfers

| Size           | TSIZ[0:3] | A[29:31] |    | Data Bus Byte Lanes |    |    |    |    |    |    |
|----------------|-----------|----------|----|---------------------|----|----|----|----|----|----|
| Word           | 0100      | 000      | D0 | D1                  | D2 | D3 |    |    |    |    |
|                | 0100      | 001      |    | D1                  | D2 | D3 | D4 |    |    |    |
|                | 0100      | 010      |    |                     | D2 | D3 | D4 | D5 |    |    |
|                | 0100      | 011      |    |                     |    | D3 | D4 | D5 | D6 |    |
|                | 0100      | 100      |    |                     |    |    | D4 | D5 | D6 | D7 |
| Five bytes     | 0101      | 000      | D0 | D1                  | D2 | D3 | D4 |    |    |    |
|                | 0101      | 001      |    | D1                  | D2 | D3 | D4 | D5 |    |    |
|                | 0101      | 010      |    |                     | D2 | D3 | D4 | D5 | D6 |    |
|                | 0101      | 011      |    |                     |    | D3 | D4 | D5 | D6 | D7 |
| Six bytes      | 0110      | 000      | D0 | D1                  | D2 | D3 | D4 | D5 |    |    |
|                | 0110      | 001      |    | D1                  | D2 | D3 | D4 | D5 | D6 |    |
|                | 0110      | 010      |    |                     | D2 | D3 | D4 | D5 | D6 | D7 |
| Seven          | 0111      | 000      | D0 | D1                  | D2 | D3 | D4 | D5 | D6 |    |
| bytes          | 0111      | 001      |    | D1                  | D2 | D3 | D4 | D5 | D6 | D7 |
| Double<br>word | 0000      | 000      | D0 | D1                  | D2 | D3 | D4 | D5 | D6 | D7 |

Table 22: PowerSpan II Processor Bus Single Beat Data Transfers



The information in Table 22 is independent of endian considerations and pertains to byte lane control on the processor bus. For endian considerations, please consult "Endian Mapping" on page 213.

## PowerPC 7400 Transaction Support

The PowerPC 7400 processors supports misaligned transactions within a double word (64-bit aligned) boundary. As long as the transaction does not cross the double word boundary, the PowerPC 7400 can transfer data on the misaligned address.

PowerSpan II supports a specific types of the PowerPC 7400 misaligned transactions (shown in Table 22) when the MODE\_7400 bit is set in the Processor Bus Miscellaneous Control and Status register (page 361). Any misaligned transaction between PowerSpan II and the MPC7400 that is a single word (32-bit) or less must be within a single word aligned boundary. Any transfer greater than a single word must start or end on a word boundary.



Software must make sure that the PowerPC 7400 does not initiate unsupported misaligned transactions to PowerSpan II

## 3.3.3.3 Cache Line Size

The supported embedded PowerPC processors implement a 32-byte cache line size. Cache wrap reads are supported by the PB slave for burst and extended transactions.



PowerPC processors do not generate cache wrap writes.

## 3.3.3.4 Reads

## Address Retry Enable

The PB slave supports up to eight concurrent delayed reads when the Address Retry Enable (ARTRY\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361 is set to 1. Refer to "Concurrent Reads" on page 38 for more information on read pipelining in PowerSpan II.

When an external master makes an initial read request, the PowerSpan II PB slave latches the address. This initiates a read on the destination bus. The destination bus is specified by the Destination Bus (DEST) bit in the "Processor Bus Slave Image x Control Register" on page 342.

## **Delayed Reads**

The outstanding read is referred to as a delayed read. Delayed reads consist of the following phases:

- 1. Delayed Read Request
  - PowerSpan II PB Slave latches transaction parameters and issues a retry
- 2. Delayed Read Completion
  - The PB Slave obtains the requested data and completion status on the destination bus
- 3. Read Completion
  - The master repeats the transaction with the same parameters used for the initial request

Any attempt by a processor bus master to complete the read transaction is retried by the PowerSpan II PB Slave until the following byte quantities are available in the line buffer:

- 32 bytes
- 8 bytes if the RD\_AMT=0 (see "Processor Bus Slave Image x Control Register" on page 342)
- 16 bytes if the RD\_AMT=1

#### **Read Amount**

All PowerSpan II PB slave reads destined for PCI Memory space are considered prefetchable to 8-byte boundaries by default. Setting the MEM\_IO bit in the Processor Bus Slave Image *x* Control register (see page 342) enables 1,2,3, or 4 byte reads from the PCI bus(es).

In order to program PowerSpan II to complete 4 byte reads on the PB bus, both the MEM\_IO bit and the MODE bit must be set to 1 in the Processor Bus Slave Image x Control register.

In order to perform a 4-byte read from the processor (60x) bus to PCI, the following bits must be programmed:

- MEM\_IO bit set to 1
- MODE bit set to 1
- END bit, in the "Processor Bus Slave Image x Control Register" on page 342, must not be set to little-endian mode (00). It can be set to PowerPC little-endian (01), or big-endian (10).



When the Slave Image Control register is programmed for 4 byte read transactions, requesting 8 byte reads causes undefined results in the system.

The amount of data prefetched on the destination bus is specified using the Prefetch Read Amount (RD\_AMT[2:0]) field in the "Processor Bus Slave Image x Control Register" on page 342. If the Prefetch Keep (PRKEEP) bit is set, then PowerSpan II automatically increments the latched address every time the processor bus master returns for read data. This PRKEEP function enables a burst read by the PowerSpan II PCI Master to be unpacked as smaller transfers on the processor bus.

The PB Interface can generate a 32-byte burst read with a starting address at the second, third or fourth 8-byte quantity. A cache wrap read always causes the PB slave to make a 32-byte read request from the destination PCI bus. In other words, PRKEEP and RD\_AMT[2:0] have no effect.

There are instances where a read requires more data than that specified by RD\_AMT. Since PB slaves cannot terminate transactions, PowerSpan II compensates for a potential hang situation — for example, not having enough read data — by over-riding the programming of RD\_AMT. PowerSpan II prefetches the larger data value. This enables the PowerSpan II to accommodate the byte count specified by the transaction. Alternatively, it initiates a new read transaction on the destination if it does not have enough data to satisfy the transaction.

The read amount values that can be programmed in the RD\_AMT field are shown in Table 23. The read amount setting determines different values to prefetch from the destination bus.

| RD_AMT[2:0] | Data Fetched |
|-------------|--------------|
| 000         | 8 bytes      |
| 001         | 16 bytes     |
| 010         | 32 bytes     |
| 011         | 64 bytes     |
| 100         | 128 bytes    |
| 101-111     | Reserved     |

**Table 23: Read Amount settings** 

## **Discard Timer**

Each PB slave image has a discard timer. If an external master does not claim data within  $2^{15}$  clocks after data is read from the destination bus, the Delayed Read Request latch is de-allocated. This prevents deadlock conditions. Read buffer contents are flushed but there is no error recorded and no interrupts are generated.

## **Posted Writes**

Posted writes have dedicated line buffers and are treated independently of reads. A write to an image does not invalidate the contents of the read line buffer currently in use.

#### Address Retry Disabled

The PB Slave supports a single read at a time when ARTRY\_EN is disabled. ARTRY\_EN is disabled by setting the bit to 0. The PB slave acknowledges the address tenure with the PB\_AACK\_ signal and captures the address in the Delayed Read latch. However, when ARTRY\_EN is disabled, the PB slave does not acknowledge the data transfer until the Read Amount (RD\_AMT) field in the "Processor Bus Slave Image x Control Register" on page 342 is read. The Delayed Read Request latch is de-allocated when the external processor bus master completes the transaction.

PRKEEP has no affect when PKEEP is set to 1 and ARTRY\_EN is disabled. A maximum of 32 bytes can be programmed in the RD\_AMT field.

#### 3.3.3.5 Writes

All writes are posted and are buffered separately from read data. The transaction length of the PB write is directly translated to the PCI bus with no address phase deletion. For example, a single cycle write on the PB results in a single cycle write on the PCI bus.

#### 3.3.3.6 Data Parity

Data parity is enabled by setting the Data Parity Enable (DP\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361. Even parity or odd parity is enabled by setting the Parity (PARITY) bit in the same register.

Parity generation and checking is provided for each byte of the data bus and for each data beat of the data tenure. Data parity bit assignments are as defined in Table 24.

| Data Bus    | Data Parity |
|-------------|-------------|
| PB_D[0:7]   | PB_DP[0]    |
| PB_D[8:15]  | PB_DP[1]    |
| PB_D[16:23] | PB_DP[2]    |
| PB_D[24:31] | PB_DP[3]    |
| PB_D[32:39] | PB_DP[4]    |
| PB_D[40:47] | PB_DP[5]    |
| PB_D[48:55] | PB_DP[6]    |
| PB_D[56:63] | PB_DP[7]    |

Table 24: PowerSpan II PB Data Parity Assignments

The data parity bits, PB\_DP[0:7], are driven to the correct values for even or odd parity by the PB slave during reads and checked during writes.

The detection of a data parity error does not affect the transaction and data is still forwarded to the destination bus. See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.

#### Special Parity Requirements with the MPC8260

Address parity and data parity must be specially programmed in a joint PowerSpan II and MPC8260 application.

In a joint application all memory accesses from the MPC8260 to PowerSpan II must be routed through the internal memory controller on the MPC8260. When the data is passed through the memory controller both address parity and data parity can be used in the system.

If accesses do not pass through the memory controller of the MPC8260 before reaching PowerSpan II, and PowerSpan II has either or both address and data parity enabled, then PowerSpan II reports parity errors on the transaction.

To enable or disable address parity in PowerSpan II, set the Address Parity Enable (AP\_EN) bit in the Processor Bus Miscellaneous Control and Status (PB\_MISC\_CSR) register (see page 361).

To enable or disable data parity in PowerSpan II, set the Data Parity Enable (DP\_EN) bit in the Processor Bus Miscellaneous Control and Status (PB\_MISC\_CSR) register (see page 361).

## 3.3.4 Terminations

## 3.3.4.1 PB Slave Termination

The PB slave uses the following pins to indicate termination of individual data beats and/or data tenure:

- Address Retry (PB\_ARTRY\_): This signal terminates the entire address and data tenure and schedules the transaction to be rerun. No data is transferred, even if asserted coincidentally with PB\_TA/PB\_DVAL\_, as in the case of a third party address retry.
- Transfer Acknowledge (PB\_TA\_): This signal is asserted by the PowerSpan II PB Slave to indicate the successful transfer of a single beat transaction, or each 8-byte quantity transferred for a burst.

- Data Valid (PB\_DVAL\_): This signal is asserted by the PB slave to indicate the successful transfer of an 8-byte quantity within an extended transfer of 16 or 24 bytes. PB\_TA\_ is asserted together with PB\_DVAL\_ on the transfer of the last 8-byte quantity.
- Transfer Error Acknowledge (PB\_TEA\_): This signal indicates an unrecoverable error and causes the external master to immediately terminate the data tenure.



The PB Slave does not assert a data termination signal earlier than the *address retry window*.

## 3.3.4.2 Assertion of PB\_TEA\_

PowerSpan II asserts PB\_TEA\_ when a particular slave image cannot handle transactions involving more than 4 bytes. This applies to the following:

- register accesses (see "Register Access" on page 283)
- accesses to general purpose slave image configured for PCI I/O space
- access to registers designed to generate PCI Configuration or IACK commands (see "Configuration and IACK Cycle Generation" on page 295)

PowerSpan II also asserts PB\_TEA\_ if a read from PCI generates a Master-Abort or Target-Abort.

The assertion PB\_TEA\_ is enabled or disabled with the TEA Enable (TEA\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361.



In a development environment, the TEA\_EN bit is set to allow the assertion of PB\_TEA\_ to support the debug of software. In a production environment, customers may find it useful to disable the assertion of PB\_TEA\_.

#### 3.3.4.3 Errors

The PowerSpan II PB Slave detects the following error conditions:

- address parity
- data parity on writes
- illegal accesses

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.

## 3.4 **PB Master Interface**

## 3.4.1 PowerSpan II as PB Master

The PowerSpan II becomes active as PB Master when:

- PowerSpan II is accessed as a PCI target
- one of the PowerSpan II DMA engines is processing a transfer

The operation of the PB Master is described by dividing a transaction into three different phases:

- Address Phase: This section discusses the arbitration for the address bus, and generation of the PB address and transfer types.
- Data Transfer: This section describes arbitration for the data bus, and control of transaction size and length.
- Terminations: This section describes the terminations supported by PowerSpan II, and exception handling.

## 3.4.2 Address Phase

## 3.4.2.1 Address Bus Arbitration and Tenure

The PB Master asserts Address Bus Busy (PB\_ABB\_) to indicate address bus ownership after it receives a qualified bus grant for its address bus request. A qualified bus grant assumes the following:

- address bus grant asserted
- PB\_ARTRY\_ negated
- address bus not busy

The PB Master negates PB\_ABB\_ for at least one clock after Address Acknowledge (PB\_AACK\_) has been asserted by the slave. This is true even if the arbiter parked the bus on PowerSpan II. For example, in Figure 13 on page 128 the bus is parked at the PowerSpan II (PB\_BG[1]\_ is asserted throughout), PB\_ABB\_ is negated the first positive clock edge after sampling PB\_AACK\_.



The PowerSpan II PB Master derives equivalent Address Bus Busy information from processor bus control signals. This allows the PowerSpan II processor bus arbiter to operate in 60x environments that do not implement ABB. The MPC8260 uses ABB to qualify address bus grants generated by the system arbiter. The PB Master operates in a multi-processor, cache-coherent PowerPC environment that requires correct implementation of the *window of opportunity*. The following PB Master behavior supports the *window of opportunity*:

- respond to PB\_ARTRY\_ in the address retry window
- snoop PB\_ARTRY\_

#### **Negating Address Bus Requests**

When the PB Master (as current address bus owner) detects Address Retry (PB\_ARTRY\_) asserted during the address retry window, it negates its bus request for at least one clock. This guarantees the snooping master that retried the cycle an opportunity to request and be granted the bus before the PowerSpan II PB Master can restart its transaction. Once the bus is re-acquired, the PB Master restarts the transaction.

#### Cache Coherency

The Global (PB\_GBL\_) and Cache Inhibit (PB\_CI\_) parameters are programmable for each PCI target image and DMA channel (GBL and CI in the "PCI 1 Target Image x Control Register" on page 322 and the "DMA x Attributes Register" on page 376). Assertion of PB\_GBL\_ during a PB master transaction instructs all processors on the bus to snoop the transaction. Control of this parameter allows the user to implement non-coherent accesses in specific areas of memory. Assertion of PB\_CI\_ prohibits external agents from caching the transaction. This ability is useful in a system with an L2 look aside cache.

The PB Master, along with all other bus masters, are required to snoop ARTRY\_ when they are not the bus owner. If ARTRY\_ is asserted, the masters must ensure the following actions are taken:

- release bus request, if it is asserted, for at least one clock
- do not acquire the bus if presently granted
- do not assert bus request during the window of opportunity

To ensure a transaction is retried, systems assert PB\_ARTRY\_ at, or before, the first assertion of PB\_TA\_. This timing avoids a data tenure being terminated after data is transferred between bus agents. Normally, a retry scenario implies PB\_ARTRY\_ assertion one clock after assertion of the PB\_AACK\_ — in the address retry window. In certain systems however, the first assertion of PB\_TA can occur before PB\_AACK\_. If this situation occurs, PB\_ARTRY\_ must be asserted at the same time as the first assertion of PB\_TA\_ and must be held until the clock after PB\_AACK\_ assertion.

#### Address Pipelining

The PB Master can operate in a system that implements up to one level of address pipelining. The PB Master does not prohibit other bus agents from pipelining transactions.



When mastering the bus, the PB Master can begin a new address tenure before the current data tenure completes.

#### Internal and External Arbitration

When the PowerSpan II processor bus arbiter is enabled (see "Arbitration" on page 163) all processor bus master address bus requests and grants are internal to PowerSpan II. When an external arbiter is used, the PB Master requests the address bus on PB\_BR[1]\_ and receives grants on PB\_BG[1]\_. For example, PowerSpan II's internal arbiter is disabled in Figure 13 on page 128.

#### 3.4.2.2 Address Translation

The address generated by the PB Master is dependent on the use of address translation in the source target image (see "PCI 1 Target Image x Control Register" on page 322. When address translation is enabled — TA\_EN bit is set in the PCI target image— PowerSpan II produces the processor bus address using three inputs:

- the incoming address from the source bus
- the block size of the target image
- the translation offset

This does not apply to DMA transfers because the destination address is assumed to have the necessary offset by design.

For more information, see "DMA x Destination Address Register" on page 368.

#### 3.4.2.3 Transaction type

The transfer type parameter of a PB master transaction, PB\_TT, is specified with the PCI target image or DMA channel registers. The following registers control the parameter for write transactions:

- WTT[4:0] field in the "PCI 1 Target Image x Control Register" on page 322
- WTT[4:0] field in the "DMA x Attributes Register" on page 376

The following registers control the parameter for read transactions:

- RTT[4:0] field in the "PCI 1 Target Image x Control Register" on page 322
- RTT[4:0] field in the "DMA x Attributes Register" on page 376

The default transfer type generated by the PowerSpan II PB Interface master is shown in Table 25.

| PB Master Transaction | PB_TT[0:4] | Processor Bus Command |
|-----------------------|------------|-----------------------|
| Writes                | 00010      | Write with flush      |
| Reads                 | 01010      | Read                  |

Table 25: Default PowerSpan II PB Master Transfer Type

## 3.4.2.4 Address Parity

Address parity generation is provided on each byte of the address bus. Address parity bit assignments are defined in Table 26

| Address Bus | Address Parity |
|-------------|----------------|
| PB_A[0:7]   | PB_AP[0]       |
| PB_A[8:15]  | PB_AP[1]       |
| PB_A[16:23] | PB_AP[2]       |
| PB_A[24:31] | PB_AP[3]       |

 Table 26: PowerSpan II PB Address Parity Assignments

During PB master transactions, PB\_AP[0:3] is driven to the correct values for either even parity or odd parity. Odd versus even parity is controlled with the PARITY bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361.

## 3.4.3 Data Phase

## 3.4.3.1 Data Bus Arbitration and Tenure

The PB Master generates a data bus request by driving Transfer Type (PB\_TT[3]) high during assertion of Transfer Start (PB\_TS\_). The PB Master asserts Data Bus Busy (PB\_DBB\_) to indicate data bus ownership when it receives a qualified bus grant (see Figure 13 on page 128). A qualified bus grant includes:

• Data Bus Grant (DBG) signal asserted



If the DBG signal is asserted past the data tenure of a transaction, the PB Master sees the assertion of the DBG signal as a new data tenure and re-asserts PB\_DBB\_.

- PB\_ARTRY\_ negated
- Data bus not busy



External slaves must not indicate a successful data transfer with the assertion of PB\_TA\_ and/or PB\_DVAL\_ earlier than two clocks after the assertion of PB\_TS\_. To ensure MPC8260 compliance with this rule, the MPC8260 register BCR[APD] must be programed to a value greater than one. This parameter specifies the earliest time after assertion of PB\_TS\_ that the MPC8260 slave asserts PB\_TA\_ to complete a data transfer. The BCR[APD] parameter is supported by the MPC8260 to accommodate processor bus agents with a range of snoop response times. BCR[APD] must be programmed to accommodate the slowest snooping device in the system.

The PB Master negates PB\_DBB\_ for at least one clock after the final data termination signal is asserted by the slave.



The PowerSpan II PB Master derives equivalent Data Bus Busy information from PB control signals. This allows the PowerSpan II processor bus arbiter to operate in processor bus environments that do not implement DBB. The MPC8260 uses DBB to qualify data bus grants generated by the system arbiter.

## 3.4.3.2 Transaction Length

The PB Master can generate a super-set of the data transfer sizes supported by the embedded PowerPC family. The user can disable certain data transfer sizes that are unique to the MPC8260. All data transfer sizes supported by the PowerSpan II PB master are illustrated in Table 27 below. Burst transfers are indicated by the assertion of Processor Bus Transfer Burst (PB\_TBST\_, see Figure 13 and Figure 14). PB\_TBST\_ is negated during single cycle transactions (see Figure 15 and Figure 16 below).

The shaded regions in Table 27 indicate transaction sizes that are unique to the MPC8260. The extended cycles supported by the MPC8260 are identified with an additional size pin, Processor Bus Transfer Size (PB\_TSIZ[0]). Extended cycles are enabled using the EXTCYC bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361.



PowerSpan II only interfaces to 64-bit slaves.

| Transfer Size                  | Bytes | PB_TBST | PB_TSIZ[0] | PB_TSIZ[1:3] |
|--------------------------------|-------|---------|------------|--------------|
| Byte                           | 1     | 1       | 0          | 001          |
| Half-word                      | 2     | 1       | 0          | 010          |
| Tri-byte                       | 3     | 1       | 0          | 011          |
| Word                           | 4     | 1       | 0          | 100          |
| Five bytes                     | 5     | 1       | 0          | 101          |
| Six bytes                      | 6     | 1       | 0          | 110          |
| Seven bytes                    | 7     | 1       | 0          | 111          |
| Double Word (DW)               | 8     | 1       | 0          | 000          |
| Extended Double (MPC8260 only) | 16    | 1       | 1          | 001          |
| Extended Triple (MPC8260 only) | 24    | 1       | 1          | 010          |
| Burst (Quad DW)                | 32    | 0       | 0          | 010          |

Table 27: PowerSpan II PB Transfer Sizes

The following figures, Figure 13 and Figure 14, illustrate burst reads and burst writes on the PB Master.







Figure 14: PB Master Interface Burst Write

The following figures, Figure 15 and Figure 16, illustrate single cycle read and single cycle write transfers on the PB Master Interface.

#### Figure 15: PB Master Interface Single Cycle Read





Figure 16: PB Master Interface Single Cycle Write

#### 3.4.3.3 Data Alignment

Embedded processor bus transfer sizes and alignments are supported by the PowerSpan II PB Master for transaction accesses. The PB master creates the necessary sequence of transactions from a set of processor bus data size and alignment options. The size and alignment combinations defined in Table 29 are supported by the MPC8260, PowerPC 740, and PowerPC 750 processors. This set includes:

- transactions less than or equal to 8-bytes (single beat transactions)
- specific misaligned transactions
- extended transactions of 16 or 24-bytes
- burst of 32-bytes

Table 28 illustrates the lanes used to carry each byte of a multi-byte structure on a64-bit processor data bus.

| Byte Address | PB Byte Lanes |                      |              |             |  |  |
|--------------|---------------|----------------------|--------------|-------------|--|--|
| PB_A[29:31]  | Lane Number   | PowerSpan II<br>Pins | MPC8260 Pins | MPC740 Pins |  |  |
| 000          | 0             | PB_D[0:7]            | D[0:7]       | DH[0:7]     |  |  |
| 001          | 1             | PB_D[8:15]           | D[8:15]      | DH[8:15]    |  |  |
| 010          | 2             | PB_D[16:23]          | D[16:23]     | DH[16:23]   |  |  |
| 011          | 3             | PB_D[24:31]          | D[24:31]     | DH[24:31]   |  |  |

Table 28: 64-bit PB Data Bus Byte Lane Definitions

| Byte Address | PB Byte Lanes |             |          |           |  |
|--------------|---------------|-------------|----------|-----------|--|
| 100          | 4             | PB_D[32:39] | D[32:39] | DL[0:7]   |  |
| 101          | 5             | PB_D[40:47] | D[40:47] | DL[8:15]  |  |
| 110          | 6             | PB_D[48:55] | D[48:55] | DL[16:23] |  |
| 111          | 7             | PB_D[56:63] | D[56:63] | DL[24:31] |  |

Table 28: 64-bit PB Data Bus Byte Lane Definitions

Table 29 lists the size and alignment transactions less than or equal to 8-bytes. The shaded table cells show transactions that support the PowerPC 7400 processor.

 Table 29: PowerSpan II Processor Bus Single Beat Data Transfers

| Size      | TSIZ[0:3] | A[29:31] | Data Bus Byte Lanes |    |    |    |    |    |    |    |
|-----------|-----------|----------|---------------------|----|----|----|----|----|----|----|
|           |           |          | 0                   | 1  | 2  | 3  | 4  | 5  | 6  | 7  |
| Byte      | 0001      | 000      | D0                  |    |    |    |    |    |    |    |
|           | 0001      | 001      |                     | D1 |    |    |    |    |    |    |
|           | 0001      | 010      |                     |    | D2 |    |    |    |    |    |
|           | 0001      | 011      |                     |    |    | D3 |    |    |    |    |
|           | 0001      | 100      |                     |    |    |    | D4 |    |    |    |
|           | 0001      | 101      |                     |    |    |    |    | D5 |    |    |
|           | 0001      | 110      |                     |    |    |    |    |    | D6 |    |
|           | 0001      | 111      |                     |    |    |    |    |    |    | D7 |
| Half word | 0010      | 000      | D0                  | D1 |    |    |    |    |    |    |
|           | 0010      | 001      |                     | D1 | D2 |    |    |    |    |    |
|           | 0010      | 010      |                     |    | D2 | D3 |    |    |    |    |
|           | 0010      | 011      |                     |    |    | D3 | D4 |    |    |    |
|           | 0010      | 100      |                     |    |    |    | D4 | D5 |    |    |
|           | 0010      | 101      |                     |    |    |    |    | D5 | D6 |    |
|           | 0010      | 110      |                     |    |    |    |    |    | D6 | D7 |

| Size           | TSIZ[0:3] | A[29:31] | Data Bus Byte Lanes |    |    |    |    |    |    |    |
|----------------|-----------|----------|---------------------|----|----|----|----|----|----|----|
| Tri-byte       | 0011      | 000      | D0                  | D1 | D2 |    |    |    |    |    |
|                | 0011      | 001      |                     | D1 | D2 | D3 |    |    |    |    |
|                | 0011      | 010      |                     |    | D2 | D3 | D4 |    |    |    |
|                | 0011      | 011      |                     |    |    | D3 | D4 | D5 |    |    |
|                | 0011      | 100      |                     |    |    |    | D4 | D5 | D6 |    |
|                | 0011      | 101      |                     |    |    |    |    | D5 | D6 | D7 |
| Word           | 0100      | 000      | D0                  | D1 | D2 | D3 |    |    |    |    |
|                | 0100      | 001      |                     | D1 | D2 | D3 | D4 |    |    |    |
|                | 0100      | 010      |                     |    | D2 | D3 | D4 | D5 |    |    |
|                | 0100      | 011      |                     |    |    | D3 | D4 | D5 | D6 |    |
|                | 0100      | 100      |                     |    |    |    | D4 | D5 | D6 | D7 |
| Five bytes     | 0101      | 000      | D0                  | D1 | D2 | D3 | D4 |    |    |    |
|                | 0101      | 001      |                     | D1 | D2 | D3 | D4 | D5 |    |    |
|                | 0101      | 010      |                     |    | D2 | D3 | D4 | D5 | D6 |    |
|                | 0101      | 011      |                     |    |    | D3 | D4 | D5 | D6 | D7 |
| Six bytes      | 0110      | 000      | D0                  | D1 | D2 | D3 | D4 | D5 |    |    |
|                | 0110      | 001      |                     | D1 | D2 | D3 | D4 | D5 | D6 |    |
|                | 0110      | 010      |                     |    | D2 | D3 | D4 | D5 | D6 | D7 |
| Seven          | 0111      | 000      | D0                  | D1 | D2 | D3 | D4 | D5 | D6 |    |
| bytes          | 0111      | 001      |                     | D1 | D2 | D3 | D4 | D5 | D6 | D7 |
| Double<br>word | 0000      | 000      | D0                  | D1 | D2 | D3 | D4 | D5 | D6 | D7 |

Table 29: PowerSpan II Processor Bus Single Beat Data Transfers



The information in Table 29 is independent of endian considerations and pertains to byte lane control on the processor bus. For endian considerations, please consult "Endian Mapping" on page 213.

#### PowerPC 7400 Transaction Support

The PowerPC 7400 processors supports misaligned transactions within a double word (64-bit aligned) boundary. As long as the transaction does not cross the double word boundary, the PowerPC 7400 can transfer data on the misaligned address.

PowerSpan II supports a specific types of the PowerPC 7400 misaligned transactions (shown in Table 29) when the MODE\_7400 bit is set in the Processor Bus Miscellaneous Control and Status register (page 361). Any misaligned transaction between PowerSpan II and the MPC7400 that is a single word (32-bit) or less must be within a single word aligned boundary. Any transfer greater than a single word must start or end on a word boundary.



Software must make sure that the PowerPC 7400 does not initiate unsupported misaligned transactions to PowerSpan II.

## 3.4.3.4 Cache Line Size

The PowerPC processors supported by PowerSpan II implement a 32-byte cache line size (8 words). Cache wrap bursts are not generated because the PB master starts a burst transaction at a 32-byte aligned address. For a transaction that is not 32-byte aligned, the PB master utilizes one or more single beat or extended transaction size, to align to the cache line boundary, before generating the required burst transaction or transactions.



The PowerSpan II PB Master assumes all external slaves can accept burst transactions.

#### 3.4.3.5

## Data Parity

Data Parity is enabled by setting the DP\_EN bit in the Processor Bus Control and Status register (see "Processor Bus Miscellaneous Control and Status Register" on page 361). Even or odd parity can be enabled by setting the PARITY bit on the Processor Bus Control and Status register.

Parity generation and checking is provided for each byte of the data bus and for each data beat of the data tenure. Data parity bit assignments are as defined in Table 30.

| Table 30: | PowerSpan | II PB Data | a Parity Assignments |
|-----------|-----------|------------|----------------------|
|-----------|-----------|------------|----------------------|

| Data Bus    | Data Parity |
|-------------|-------------|
| PB_D[0:7]   | PB_DP[0]    |
| PB_D[8:15]  | PB_DP[1]    |
| PB_D[16:23] | PB_DP[2]    |

| Data Bus    | Data Parity |
|-------------|-------------|
| PB_D[24:31] | PB_DP[3]    |
| PB_D[32:39] | PB_DP[4]    |
| PB_D[40:47] | PB_DP[5]    |
| PB_D[48:55] | PB_DP[6]    |
| PB_D[56:63] | PB_DP[7]    |

#### Table 30: PowerSpan II PB Data Parity Assignments

The data parity bits, PB\_DP[0:7], are driven to the correct values for even or odd parity by the PB Master during writes. If checking is enabled (by setting the DP\_EN bit) the data parity bits, PB\_DP[0:7], are checked by the PB Master during reads. The detection of a data parity error does not affect the transaction, and data is still forwarded to the destination.

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.

## 3.4.4 Terminations

The PB master uses the following pins as termination signals for individual data beats and data tenure:

- Address Retry (PB\_ARTRY\_): This signal terminates the entire data tenure and schedules the transaction to be rerun. No data is transferred.
- Transfer Acknowledge (PB\_TA\_): This signal is asserted by the external slave to indicate the successful transfer of a single beat transaction, or each 8 byte quantity transferred for a burst.
- Data Valid (PB\_DVAL\_): This signal is asserted by the external slave to indicate the successful transfer of a quantity of data. The MPC8260 provides this pin to support the termination of extended cycles. The external slave asserts this pin once for each successful 8 byte transfer. PB\_TA\_ is asserted, with PB\_DVAL\_, on the final transfer of the transaction. The slave uses PB\_TA\_ and/or PB\_DVAL\_ to insert wait states. The PB master ignores PB\_DVAL\_ when the EXTCYC bit cleared in the "Processor Bus Miscellaneous Control and Status Register" on page 361.
- Transfer Error Acknowledge (PB\_TEA): This signal indicates an unrecoverable error and causes the PB master to immediately terminate the data tenure.

## 3.4.4.1 Errors

The PB master detects three error conditions:

- data parity on reads
- assertion of PB\_TEA\_ by external slave
- expiration of maximum retry counter (MAX\_RETRY bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361).

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.



# **4. DMA**

A direct memory access (DMA) channel allows a transaction to occur between two devices without involving the host processor (for example, a read transaction between a peripheral device and host processor memory). Because less time is required to complete transactions, applications that contain one or more DMA channels support faster read and write transfers than applications that support only host-assisted transactions.

discusses the following topics about the PowerSpan II DMA:

- "DMA Operation" on page 138
- "DMA Interrupts" on page 149
- "DMA Error Handling" on page 150

## 4.1 Overview

PowerSpan II has four identical Direct Memory Access (DMA) channels for independent data transfer between the three ports of the Dual PCI PowerSpan II: Processor Bus Interface (PB), PCI Interface 1 (PCI-1) and PCI Interface 2 (PCI-2). The programming and operation of the four DMAs are the same. This chapter discusses DMA operation within the context of a single channel. In addition, since the DMAs are able to transfer data from any port to any port, the DMA discussion refers to "source" bus and "destination" bus with no reference to bus type. Exceptions to this guideline are noted in the manual.



In the Single PCI PowerSpan II, the PCI-2 specific DMA bits must not be programmed. DMA transfers must not be directed to the PCI-2 Interface. There are two modes of operation for the PowerSpan II DMA: Direct mode and Linked-List mode. In Direct mode, the DMA control registers are directly programmed for each DMA transfer — one start address and transfer size. In Linked-List mode, the PowerSpan II loads its DMA registers from a linked-list of "command packets". The packets are essentially pre-programmed register contents for a PowerSpan II DMA channel.

## 4.2 DMA Operation

## 4.2.1 DMA Register Description

The DMA registers are the same for each DMA channel. DMA registers are described in Table 31. The registers for DMA1 begin at offset 0x300 and their organization in PowerSpan II register space is described in "Register Descriptions" on page 283.

| Register      | Register Description and Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAx_SRC_ADDR | The Source Address Register can be programmed for an address on any one of<br>the three PowerSpan II buses. This register can be programmed in Direct mode or<br>automatically loaded in Linked-List mode. Writing to this register while the DMA is<br>in operation has no effect. While the DMA is active, this register provides the<br>current status of the source address. This address is byte-aligned.                                                                                                                                                       |
| DMAx_DST_ADDR | The Destination Address Register can be programmed for an address on any one of the three PowerSpan II buses — even the same bus as that used for the Source Address. This register can be programmed in Direct mode or automatically loaded in Linked-List mode. Writing to this register while the DMA is in operation has no effect. While the DMA is active, this register provides the status of the current destination address. This address is byte-aligned. The lower bits on the destination address are the same as the lower bits on the source address. |
| DMAx_TCR      | The DMA Transfer Control Register specifies the source and destination buses, the endian conversion mode of a transfer involving the processor bus and a PCI bus (see "Endian Mapping" on page 213), and specifies the byte count from any remaining Direct mode operation.                                                                                                                                                                                                                                                                                          |
| DMAx_CPP      | The DMA Command Packet Pointer register specifies the 32-byte aligned address of the next command packet in the linked-list. This is programmed by PowerSpan II as it loads a command packet. There is a LAST flag in this register to indicate the end of the linked-list.                                                                                                                                                                                                                                                                                          |
| DMAx_GCSR     | The DMA General Control and Status Register controls DMA activity, reflects operational status and enables DMA-specific interrupts (see Table 32)                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DMAx_ATTR     | The DMA Attributes Register controls the transfer type and cache-specific behavior of processor bus transactions. It also selects the command packet port.                                                                                                                                                                                                                                                                                                                                                                                                           |

Table 31: DMA Register Description



Most DMA channel registers are locked against any changes by the user while the channel is active. However, both the Stop Request (STOP\_REQ) and Halt Request (HALT\_REQ) bits, in the "DMA x General Control and Status Register" on page 372, are not locked.

## 4.2.1.1 Source and Destination Addresses

The lower three bits of DMA Destination Address register are taken directly from the lower three bits of the Source Address register. This enforces 8-byte alignment of the starting source and destination addresses. The source and destination address registers are part of the command packet contents ("Linked-List Mode DMA Operation" on page 145).

The starting byte address on the source port is specified in "DMA x Source Address Register" on page 367. The starting byte address on the Destination port is specified in "DMA x Destination Address Register" on page 368.

## 4.2.1.2 Transfer Control Register

The "DMA x Transfer Control Register" on page 369 details the programming options for this register. It controls the direction of the transfer, the endian conversion between the processor bus and the PCI bus and specifies the transfer byte count. Note that the maximum byte count is 16 Mbytes. The DMA Transfer Control Register is part of the command packet contents ("Linked-List Mode DMA Operation" on page 145).



In the Single PCI PowerSpan II, the PCI-2 specific DMA bits must not be programmed. DMA transfers must not be directed to the PCI-2 Interface.

## 4.2.1.3 Command Packet Addressing

The "DMA x Command Packet Pointer Register" on page 371 specifies the address for the command packets in Linked-List mode. See "Linked-List Mode DMA Operation" on page 145 for more details on command packet processing.

## 4.2.1.4 Address Retry

The Address Retry Enable (ARTRY\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361 controls PowerSpan II's assertion of PB\_ARTRY\_ during the servicing of transactions. When the ARTRY\_EN bit is set to 0, the PB Slave is disabled from generating address retries.

#### **DMA Addresses and Retries**

If a PowerSpan II DMA transaction is retried enough times the its retry counter may expire. When the retry timer expires, the DMA transaction does not try to restart the transaction at the original address; it jumps the address. The new address starts at the nearest address boundary. The nearest address boundary depends on the value programmed in the DBS field (see "DMA x General Control and Status Register" on page 372). For example, the nearest address boundary for a incremented address when the DMA block size is set to 128 bytes is 0x80. In this case, the equation for the incremented address value is: original address + 0x80.

By advancing the address, PowerSpan II provides a method to step-out of the error condition.

#### 4.2.1.5 General DMA Control and Status

The "DMA x General Control and Status Register" on page 372 is not part of the command packet contents and is set up prior to any DMA operation (Direct or Linked-List mode). The contents of the DMA General Control and Status Register are described in Table 32 below.

| Bits     | Туре              | Description                                                                                                                              | Default Setting |
|----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| GO       | Write 1<br>to set | Initiates DMA activity                                                                                                                   | Clear           |
| CHAIN    | R/W               | Enables the Linked-List mode of operation.                                                                                               | Disabled        |
| STOP_REQ | Write 1<br>to set | Stops DMA operation after the internally buffered data is written out to the destination bus.                                            | Clear           |
| HALT_REQ | Write 1<br>to set | Halts DMA operation after the completion of the current command packet.                                                                  | Clear           |
| DACT     | R                 | Provides status of DMA activity (active or inactive).                                                                                    | Clear           |
| DBS[1:0] | R/W               | Controls the byte size of DMA transactions when DBS_EN is set to 1.                                                                      | Clear           |
| DBS_EN   | R/W               | Enables byte size control of transactions generated<br>by the DMA Channel. Transaction size is based on<br>the setting of the DBS field. | Clear           |
| OFF      | R/W               | DMA Channel Off Counter (number of PB clocks)<br>Controls the number of Processor clocks between<br>sequential PB tenures.               | Clear           |

Table 32: Programming Model for DMA General Control and Status Register

| Bits      | Туре                      | Description                                                                                                           | Default Setting |
|-----------|---------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------|
| P1_ERR    | R/<br>Write 1<br>to clear | A status bit indicating an error has occurred on PCI-<br>1.                                                           | Clear           |
| P2_ERR    | R/<br>Write 1<br>to clear | A status bit indicating an error has occurred on PCI-2. Disregard this bit with the Single PCI PowerSpan II.          | Clear           |
| PB_ERR    | R/<br>Write 1<br>to clear | A status bit indicating an error has occurred on the processor bus.                                                   | Clear           |
| STOP      | R/<br>Write 1<br>to clear | A status bit indicating if the DMA has been stopped (STOP_REQ was set)                                                | Clear           |
| HALT      | R/<br>Write 1<br>to clear | A status bit indicating if the DMA has been halted (HALT_REQ was set).                                                | Clear           |
| DONE      | R/<br>Write 1<br>to clear | A status bit indicating if the DMA has been completed its Direct mode or Linked-List mode.                            | Clear           |
| P1_ERR_EN | R/W                       | Enables an interrupt if an error occurs on PCI-1.                                                                     | Disabled        |
| P2_ERR_EN | R/W                       | Enables an interrupt if an error occurs on PCI-2. Do<br>not program this bit if using the Single PCI<br>PowerSpan II. | Disabled        |
| PB_ERR_EN | R/W                       | Enables an interrupt if an error occurs on the processor bus.                                                         | Disabled        |
| STOP_EN   | R/W                       | Enables an interrupt if the DMA has been stopped (STOP_REQ bit was set).                                              | Disabled        |
| HALT_EN   | R/W                       | Enables an interrupt if the DMA has been halted (HALT_REQ bit was set).                                               | Disabled        |
| DONE_EN   | R/W                       | Enables an interrupt if the DMA completes its Direct mode or Linked-List mode.                                        | Disabled        |

Table 32: Programming Model for DMA General Control and Status Register

## 4.2.1.6 Processor Bus Transfer Attributes

The "DMA x Attributes Register" on page 376 controls the read and write transactions generated by the DMA as a processor bus master.

The default transfer type generated by the processor bus master is shown in Table 33.

| PB Master Transfer | PB_TT[0:4] | 60x Command      |
|--------------------|------------|------------------|
| Writes             | 00010      | Write with flush |
| Reads              | 01010      | Read             |

#### Table 33: Default PowerSpan II PB Master Transfer Type

The Global (PB\_GBL\_) and Cache Inhibit (PB\_CI\_) parameters are programmable for each DMA in the "DMA x Attributes Register" on page 376. Assertion of PB\_GBL\_ during a processor bus master transaction instructs all processors on the bus to snoop the transaction. Control of this parameter enables the user to implement non-coherent accesses in specific areas of memory. Assertion of PB\_CI\_ prohibits external agents from caching the transaction.

## 4.3 Direct Mode DMA Operation

In Direct mode, the contents for all of a DMA channel registers are directly programmed into PowerSpan II before every DMA operation (see Table 31). This results in higher software overhead than in Linked-List mode since PowerSpan II register accesses are required for every DMA block transfer.

## 4.3.1 Initializing a Direct Mode Operation

The GO bit in the "DMA x General Control and Status Register" on page 372 is used when the following conditions are met:

- The CHAIN bit is zero which indicates a Direct mode operation
- All status bits in the DMA General Control and Status Register are cleared, including:

P1\_ERR

P2\_ERR

PB\_ERR

STOP

HALT

DONE

The CHAIN bit and status bits can be properly configured on the same register write which sets the GO bit.

The DMA channel delivers data from the source port to the destination port until:

- DMA is stopped by setting the STOP\_REQ bit
- DMA encounters an error on one of the buses
- transfer byte count decrements to zero

When the Direct mode operation completes the programmed transfer, PowerSpan II sets the DONE bit. The operation completes when the transfer byte count decrements to zero. The operation of a Direct mode operation is illustrated in Figure 17.



Figure 17: Direct Mode DMA Transfers

#### 4.3.1.1 Direct Mode Transfer Acknowledgment

The following registers are updated during a transfer and can be used to monitor status during DMA channel activity:

- DMA Source Address (DMAx\_SRC\_ADDR) in the "DMA x Source Address Register" on page 367
- DMA Destination Address (DMAx\_DST\_ADDR) in the "DMA x Destination Address Register" on page 368
- Byte Count (BC[23:0]) field in the "DMA x Destination Address Register" on page 368.

#### 4.3.1.2 Terminating a Direct Mode Transfer

The current Direct mode transfer can be stopped by writing 1 to the STOP\_REQ bit in the "DMA x General Control and Status Register" on page 372. When this occurs, the channel stops attempting to buffer data from the source bus. When the remaining buffered source data is written to the destination bus, the STOP status bit is set.

The channel can be restarted by clearing the STOP status bit (along with any other status bits) and then writing a 1 to the GO bit.



Due to the pipelined nature of DMA channel requests, up to 256-bytes can be transferred after the user programmed the initial stop request.

# 4.4 Linked-List Mode DMA Operation

In Linked-List (scatter-gather) mode, PowerSpan II steps through a linked series of command packets in external memory. The DMA is configured with the starting address of this list and independently reads command packets and executes the transfers specified.

Each command packet is 32-byte aligned. If the command packets are resident in PCI memory, the byte ordering is little-endian. If the command packets are resident in processor bus memory, the byte ordering is big-endian. command packets can reside on any one of the three PowerSpan II interfaces. The contents of a command packet are described, with the associated DMA register, in Table 34.

| Register      | Register Description and Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAx_SRC_ADDR | The Source Address Register can be programmed for an address on<br>any one of the three PowerSpan II buses. This register can be<br>programmed in Direct mode or automatically loaded in Linked-List<br>mode. Writing to this register while the DMA is in operation has no<br>effect. While the DMA is active, this register provides the status on the<br>current source address. This address is byte-aligned.                                                                                                                                                                              |
| DMAx_DST_ADDR | The Destination Address Register can be programmed for an address<br>on any one of the three PowerSpan II buses (including the same bus as<br>that used for the Source Address). This register can be programmed in<br>Direct mode or automatically loaded in Linked-List mode. Writing to this<br>register while the DMA is in operation has no effect. While the DMA is<br>active, this register provides the status on the current destination<br>address. This address is byte-aligned. The lower bits on the destination<br>address are the same as the lower bits on the source address. |
| DMAx_TCR      | The DMA Transfer Control Register specifies the source and destination buses, the endian conversion mode of a transfer involving the Processor Bus and a PCI bus (see "Endian Mapping" on page 213), and specifies the byte count from any remaining Direct mode operation.                                                                                                                                                                                                                                                                                                                    |
| DMAx_CPP      | The DMA Command Packet Pointer register specifies the 32-byte aligned address of the next command packet in the linked-list. This is programmed by PowerSpan II as it loads a command packet. There is a LAST flag in this register to indicate the end of the linked-list.                                                                                                                                                                                                                                                                                                                    |
| DMAx_ATTR     | The DMA Attributes Register specifies to the channel the location of the linked-list port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

The Command Packet Pointer register (DMAx\_CPP) contains two elements: the Next Command Packet Pointer (NCP[31:5]) and the LAST bit. The NCP[31:5] field directs the PowerSpan II DMA to the next command packet in the linked-list. The LAST bit indicates the end of the linked-list.

The chaining of the command packets is illustrated in Figure 18.





## 4.4.1 Initializing a Linked-List Mode Transfer

A Linked-List mode DMA transfer is configured using the following steps:

- 1. Set-up the command packet linked-list in memory accessible to any one of the PowerSpan II's three ports. The command packet port selection is independent of the port selected as the source or destination port.
- 2. Configure DMAx\_ATTR parameters and DMAx\_GCSR.
- 3. Set-up the NCP[31:5] field to point to the first command packet.
- 4. Ensure the BC[23:0] field in the DMA Transfer Control Register is 0.
- 5. Clear all status bits in the DMA General Control and Status Register.
- 6. Set the GO bit.

The steps to configure a Linked-List mode DMA transfer are illustrated in Figure 19.



Figure 19: Sequence of Operations in a Linked-List Transfer

The DMA walks through the linked-list of command packets until it executes the last packet. When the operation programmed with that last Command Packet is completed, the DMA sets the DONE bit. The LAST bit indicates the end of the linked-list.

If the Linked-List mode is started with a non-zero byte count in the DMA Transfer Control Register, a Direct mode DMA transfer is initiated by PowerSpan II to clear the remaining byte count value. Once that Direct mode transfer is complete, the DMA then processes the linked-list pointed to in the DMA Command Packet Pointer Register. This mechanism allows the restart of a linked-list transfer that has been stopped with the STOP\_REQ bit in the "DMA x General Control and Status Register" on page 372.

#### 4.4.1.1 Terminating Linked-List Mode

Linked-List mode is terminated in two ways: setting the STOP\_REQ bit or the HALT\_REQ bit in the "DMA x General Control and Status Register" on page 372. When the STOP\_REQ bit is set, the DMA stops making source port requests. When all outstanding transactions are completed on the destination bus, the STOP status bit is set. The channel can be restarted by clearing the STOP status bit (along with any other status bits) and then writing a one to the GO bit.

Processing of the current linked-list can also be halted by setting the HALT\_REQ bit. If this bit is set, transfers specified by the current command packet are completed and then the DMA sets the HALT status bit. Since DMAx\_CPP contains the address of the next command packet, the channel can be restarted by writing 1 to HALT bit (to clear the HALT state), the CHAIN bit (to re-initiate the Linked-List mode), and the GO bit (to re-activate the DMA).

# 4.5 DMA Interrupts

The PowerSpan II DMA supports a number of interrupt sources for each channel. Individual enable and status bits exist for each source. The status and enable bits are contained in the "DMA x General Control and Status Register" on page 372:

| Table 35: DMA Channel Interrupt Sources and | Enables |
|---------------------------------------------|---------|
|---------------------------------------------|---------|

| Interrupt Source | Enable bit |
|------------------|------------|
| DONE             | DONE_EN    |
| P1_ERR           | P1_ERR_EN  |
| P2_ERR           | P2_ERR_EN  |
| PB_ERR           | PB_ERR_EN  |
| HALT             | HALT_EN    |
| STOP             | STOP_EN    |

See "Interrupt Handling" on page 173 for a complete description of the mapping and status bits for each of these interrupt sources.

# 4.6 DMA Error Handling

PowerSpan II can encounter external bus errors while mastering the source, destination or command packet ports on behalf of a DMA channel. Each DMA channel provides the following status bits in the "DMA x General Control and Status Register" on page 372 that indicate an error condition occurred during DMA bus master activity:

- P1\_ERR
- P2\_ERR
- PB\_ERR

In addition to the reporting provided by a DMA channel, the participating Master also reports the error. See "Error Handling" on page 187.

### 4.6.1 PCI Error Bits

The error bits for PCI-1 and PCI-2 are set when the corresponding PowerSpan II PCI Master encounters one of the following conditions while servicing a DMA channel:

- Master-Abort
- Target-Abort
- Maximum retry limit is reached

### 4.6.2 Processor Bus Error Bit

The error bit for the processor bus is set if the PowerSpan II PB Master encounters one of the following conditions while servicing a DMA channel.

- assertion of PB\_TEA\_
- maximum retry limit is reached



The occurrence of data parity error does not affect DMA channel behavior but is captured by the appropriate interface.

## 4.6.3 Source Port Errors

When an error occurs on the source port, transactions initiated by the source port are terminated. Any source data buffered in the PowerSpan II is written to the destination port and the appropriate DMAx\_GCSR error bit is set.

Due to the pipelined nature of DMA channel requests, additional Source port transaction activity may occur until all outstanding channel requests are completed.

## 4.6.4 Destination Port Errors

When an error occurs on the destination port transactions associated with any buffered data are terminated, and the appropriate DMAx\_GCSR error bit is set.

Due to the pipelined nature of DMA channel requests, additional destination port transaction activity can occur until all outstanding channel requests are completed.

## 4.6.5 Command Port Errors

When an error occurs on the command port the appropriate DMAx\_GCSR error bit is set. The DMA channel registers are not updated with command packet data.



Each PowerSpan II external port has error log registers that provides additional diagnostic information to assist in error recovery. These error log registers indicate when multiple errors occur due to the pipelined nature of DMA channel requests.

See "Error Handling" on page 187 and "Interrupt Handling" on page 173 for a full description of error logging support and associated interrupt mapping options.



# 5. I<sup>2</sup>C/EEPROM

The I<sup>2</sup>C (Inter-IC) bus is a bi-directional, two-wire serial data and serial clock bus that provides communication links between integrated circuits (ICs) in an embedded application. Each device is recognized by a unique address and can operate as either a receiver device (for example, an LCD driver), or a transmitter device (for example, EEPROM) with the capability to both receive and send information. Transmitters and receivers can operate in either master or slave mode, depending on whether the IC initiates data transfers.

This chapter discusses the following topics about the PowerSpan II I<sup>2</sup>C/EEPROM Interface:

- "Power-Up Configuration" on page 154
- "Bus Master I<sup>2</sup>C Transactions" on page 161
- "PCI Vital Product Data (VPD)" on page 161

# 5.1 Overview

PowerSpan II has a master only, I<sup>2</sup>C bus compatible interface which supports up to eight I<sup>2</sup>C slave devices. This interface is primarily used by PowerSpan II for the initialization of registers and for reading and writing PCI Vital Product Data (VPD). However, PowerSpan II also provides a mechanism for processor bus and PCI masters to access the I<sup>2</sup>C devices.



PowerSpan II does not support multiple masters on the same  $I^2C$  bus.

PowerSpan II I<sup>2</sup>C Interface supports the following features:

• I<sup>2</sup>C 7-bit device addressing

- Standard mode (up to 100 Kbits/s)
- Single read/write (random read, byte write)
- Sequential read during power-up configuration

The interface consists of two pins: I2C\_SDA and I2C\_SCLK. I2C\_SDA is a bidirectional open drain signal for transferring address, control, and data bits. I2C\_SCLK is the clock output for the I<sup>2</sup>C slave devices. I2C\_SCL is derived from the processor bus clock. For example, at the maximum Processor Bus Clock (PB\_CLK) frequency of 100 MHz, the I2C\_SCLK clock rate is 100 kHz.

# 5.2 **Power-Up Configuration**

At the end of each PowerSpan II reset sequence, the I<sup>2</sup>C Interface initiates a sequential read with device select code 0b1010000. If no response is detected, the read is terminated and the EEPROM Load bit (ELOAD), in the "Reset Control and Status Register" on page 385 (RST\_CSR), is cleared to indicate the absence of an external EEPROM.

When an EEPROM is not used in the system for initialization, the initialization occurs from the processor bus. Once initialization is complete, the P1\_LOCKOUT and P2\_LOCKOUT bits must be cleared in the "Miscellaneous Control and Status Register" on page 378 (MISC\_CSR) to enable the host processor to assign memory space.

When a EEPROM is used in a system, the EEPROM device responds and a number of PowerSpan II register bits are loaded from the external device and the ELOAD bit is set. During this loading process, all accesses to PowerSpan II's external interfaces are retried.

#### 5.2.1 EEPROM Loading

When the reset sequence is initiated by assertion of PO\_RST\_ — a power-up reset — the register loading process is defined by Table 36. The first byte read from the EEPROM defines the loading option and is reflected in the EEPROM Load Option (ELOAD\_OPT) field, in the "Miscellaneous Control and Status Register" on page 378, at the conclusion of the loading process.

The loading options for EEPROM are short loading and long loading. The short load consists of 29 bytes and is designed to provide a PowerSpan II configuration to support the absence of a processor on the PB Interface. The long load is 61 bytes in length and provides additional configuration convenience. The upper 192 bytes of the EEPROM are reserved for PCI Vital Product Data (see "PCI Vital Product Data (VPD)" on page 161).

Table 36 defines the power-up EEPROM load sequence. The shaded areas indicateregisters not visible in the Single PCI PowerSpan II.



Table 36 assumes PCI little-endian bit ordering. Consult the register tables for each of the registers listed in the table to obtain the corresponding PowerPC big-endian bit ordering.

#### Table 36: Power-up EEPROM Load Sequence

| Byte   |     |                       |                                           |
|--------|-----|-----------------------|-------------------------------------------|
| Offset | Bit | Name                  | Description                               |
| 0x00   | 7-0 | MISC_CSR[ELOAD_OPT]   | 0b0000001=short load                      |
|        |     |                       | 0b0000010=long load                       |
|        |     |                       | 0b00000100=reserved                       |
|        |     |                       | others=do not load                        |
| 0x01   | 7-0 | PowerSpan II Reserved |                                           |
| 0x02   | 7-0 | PowerSpan II Reserved |                                           |
| 0x03   | 7-0 | PowerSpan II Reserved |                                           |
|        |     | Start of short lo     | bad                                       |
| 0x04   | 7-0 | PowerSpan II Reserved |                                           |
| 0x05   | 7-4 | PowerSpan II Reserved |                                           |
|        | 3   | P1_CSR[BM]            | PCI-1 Bus Master Enable                   |
|        | 2   | P1_CSR[MS]            | PCI-1 Memory Space Enable                 |
|        | 1   | P2_CSR[BM]            | PCI-2 Bus Master Enable                   |
|        | 0   | P2_CSR[MS]            | PCI-2 Memory Space Enable                 |
| 0x06   | 7-5 | PowerSpan II Reserved |                                           |
|        | 4   | P1_BSI2O[PRFTCH]      | PCI-1 I2O target image prefetch indicator |
|        | 3   | P1_BST0[PRFTCH]       | PCI-1 Target image 0 prefetch indicator   |
|        | 2   | P1_BST1[PRFTCH]       | PCI-1 Target image 1 prefetch indicator   |
|        | 1   | P1_BST2[PRFTCH]       | PCI-1 Target image 2 prefetch indicator   |
|        | 0   | P1_BST3[PRFTCH]       | PCI-1 Target image 3 prefetch indicator   |
| 0x07   | 7-0 | P1_SID[SID[15:8]]     | PCI-1 Subsystem ID bits 15-8              |
| 0x08   | 7-0 | P1_SID[SID[7:0]]      | PCI-1 Subsystem ID bits 7-0               |

Table 36: Power-up EEPROM Load Sequence

| Byte<br>Offset | Bit                       | Name Description              |                                                   |
|----------------|---------------------------|-------------------------------|---------------------------------------------------|
| 0x09           | 7-0                       | P1_SID[SVID[15:8]]            | PCI-1 Subsystem vendor ID bits 15-8               |
| 0x0A           | 7-0                       | P1_SID[SVID[7:0]]             | PCI-1 Subsystem vendor ID bits 7-0                |
| 0x0B           | 7-2                       | Powe                          | erSpan II Reserved                                |
|                | 1                         | P1_MISC1[INT_PIN[0]]          | PCI-1 Interrupt pin bit 0                         |
|                | 0                         | P2_MISC1[INT_PIN[0]]          | PCI-2 Interrupt pin bit 0                         |
| 0x0C           | 7-5                       | PowerSpan II Reserved         |                                                   |
|                | 4                         | P1_MISC_CSR[BSREG_BAR_<br>EN] | PCI-1 Register image base address register enable |
| 3              |                           | P1_TI0_CTL[BAR_EN]            | PCI-1 Target image 0 base address register enable |
|                | 2                         | P1_TI1_CTL[BAR_EN]            | PCI-1 Target image 1 base address register enable |
|                | 1 P1_TI2_CTL[BAR_EN]      |                               | PCI-1 Target image 2 base address register enable |
| 0              |                           | P1_TI3_CTL[BAR_EN]            | PCI-1 Target image 3 base address register enable |
| 0x0D           | 7-4                       | P1_TI0_CTL[BS]                | PCI-1 Target image 0 block size                   |
|                | 3-0                       | P1_TI1_CTL[BS]                | PCI-1 Target image 1 block size                   |
| 0x0E           | 7-4                       | P1_TI2_CTL[BS]                | PCI-1 Target image 2 block size                   |
|                | 3-0                       | P1_TI3_CTL[BS]                | PCI-1 Target image 3 block size                   |
| 0x0F           | 7                         | MISC_CSR[VPD_EN]              | PCI Vital Product Data enable                     |
|                | 6-4                       | MISC_CSR[VPD_CS[2:0]]         | PCI Vital Product Data chip select                |
|                | 3-0 PowerSpan II Reserved |                               |                                                   |

Table 36: Power-up EEPROM Load Sequence

| Byte<br>Offset | Bit | Name                  | Description                                                    |  |
|----------------|-----|-----------------------|----------------------------------------------------------------|--|
|                |     |                       | -                                                              |  |
| 0x10           | 7   | MISC_CSR[P1_LOCKOUT]  | PCI-1 Lockout                                                  |  |
|                | 6   | MISC_CSR[P2_LOCKOUT]  | PCI-2 Lockout                                                  |  |
|                | 5-4 |                       | erSpan II Reserved                                             |  |
|                | 3   | MISC_CSR[PCI_ARB_CFG] | PCI Arbiter Configuration Complete                             |  |
|                | 2   | MISC_CSR[PCI_M7]      | PCI Arbiter Master 7                                           |  |
|                | 1   | MISC_CSR[PCI_M6]      | PCI Arbiter Master 6                                           |  |
|                | 0   | MISC_CSR[PCI_M5]      | PCI Arbiter Master 5                                           |  |
| 0x11           | 7   | IDR[P2_HW_DIR]        | P2_INTA Direction                                              |  |
|                | 6   | IDR[P1_HW_DIR]        | P1_INTA Direction                                              |  |
|                | 5   | IDR[INT5_HW_DIR]      | INT[5] Direction                                               |  |
|                | 4   | IDR[INT4_HW_DIR]      | INT[4] Direction                                               |  |
|                | 3   | IDR[INT3_HW_DIR]      | INT[3] Direction                                               |  |
|                | 2   | IDR[INT2_HW_DIR]      | INT[2] Direction                                               |  |
|                | 1   | IDR[INT1_HW_DIR]      | INT[1] Direction                                               |  |
|                | 0   | IDR[INT0_HW_DIR]      | INT[0] Direction                                               |  |
| 0x12           | 7-6 | Powe                  | erSpan II Reserved                                             |  |
|                | 5   | PCI_I2O_CTL[BAR_EN]   | PCI I <sub>2</sub> O Target image base address register enable |  |
|                | 4   | Powe                  | erSpan II Reserved                                             |  |
|                | 3-0 | PCI_I2O_CTL[BS]       | PCI I <sub>2</sub> O Target image block size                   |  |
| 0x13           | 7-5 | Powe                  | PowerSpan II Reserved                                          |  |
|                | 4   | P2_BSI2O[PRFTCH]      | PCI-2 I2O target image prefetch indicator                      |  |
|                | 3   | P2_BST0[PRFTCH]       | PCI-2 Target image 0 prefetch indicator                        |  |
|                | 2   | P2_BST1[PRFTCH]       | PCI-2 Target image 1 prefetch indicator                        |  |
|                | 1   | P2_BST2[PRFTCH]       | PCI-2 Target image 2 prefetch indicator                        |  |
|                | 0   | P2_BST3[PRFTCH]       | PCI-2 Target image 3 prefetch indicator                        |  |

Table 36: Power-up EEPROM Load Sequence

| Byte<br>Offset | Bit | Name                          | Description                                       |
|----------------|-----|-------------------------------|---------------------------------------------------|
|                | ļ   |                               |                                                   |
| 0x14           | 7-0 | P2_SID[SID[15:8]]             | PCI-2 Subsystem ID bits 15-8                      |
| 0x15           | 7-0 | P2_SID[SID[7:0]]              | PCI-2 Subsystem ID bits 7-0                       |
| 0x16           | 7-0 | P2_SID[SVID[15:8]]            | PCI-2 Subsystem vendor ID bits 15-8               |
| 0x17           | 7-0 | P2_SID[SVID[7:0]]             | PCI-2 Subsystem vendor ID bits 7-0                |
| 0x18           | 7-5 | PowerSpan II Reserved         |                                                   |
|                | 4   | P2_MISC_CSR[BSREG_BAR_<br>EN] | PCI-2 Register image base address register enable |
|                | 3   | P2_TI0_CTL[BAR_EN]            | PCI-2 Target image 0 base address register enable |
|                | 2   | P2_TI1_CTL[BAR_EN]            | PCI-2 Target image 1 base address register enable |
| 1              |     | P2_TI2_CTL[BAR_EN]            | PCI-2 Target image 2 base address register enable |
|                | 0   | P2_TI3_CTL[BAR_EN]            | PCI-2 Target image 3 base address register enable |
| 0x19           | 3-0 | P2_TI0_CTL[BS]                | PCI-2 Target image 0 block size                   |
|                | 3-0 | P2_TI1_CTL[BS]                | PCI-2 Target image 1 block size                   |
| 0x1A           | 3-0 | P2_TI2_CTL[BS]                | PCI-2 Target image 2 block size                   |
|                | 3-0 | P2_TI3_CTL[BS]                | PCI-2 Target image 3 block size                   |
| 0x1B-0x1F      |     | Powe                          | erSpan II Reserved                                |
|                |     | End of short load, long lo    | ad continues                                      |
| 0x20           | 7-0 | P1_ID[DID[15:8]]              | PCI-1 Device ID bits 15-8                         |
| 0x21           | 7-0 | P1_ID[DID[7:0]]               | PCI-1 Device ID bits 7-0                          |
| 0x22           | 7-0 | P1_ID[VID[15:8]]              | PCI-1 Vendor ID bits 15-8                         |
| 0x23           | 7-0 | P1_ID[VID[7:0]]               | PCI-1 Vendor ID bits 7-0                          |
| 0x24           | 7-0 | P1_CLASS[BASE]                | PCI-1 Base Class Code                             |
| 0x25           | 7-0 | P1_CLASS[SUB]                 | PCI-1 Sub Class Code                              |
| 0x26           | 7-0 | P1_CLASS[PROG]                | PCI-1 Programming Interface                       |

Table 36: Power-up EEPROM Load Sequence

| Byte<br>Offset | Bit                                       | Name                                                                       | Description                                     |  |
|----------------|-------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------|--|
|                |                                           |                                                                            | Description                                     |  |
| 0x27           | 7-0                                       | P1_CLASS[RID]                                                              | PCI-1 Revision ID                               |  |
| 0x28           |                                           | Powe                                                                       | erSpan II Reserved                              |  |
|                | 6                                         | PB_SI0_CTL[TA_EN]                                                          | PB Slave image 0 translation enable             |  |
|                | 5                                         | PB_SI0_CTL[MD_EN]                                                          | PB Slave image 0 Master decode enable           |  |
|                | 4-0                                       | PB_SI0_CTL[BS]                                                             | PB Slave image 0 block size                     |  |
| 0x29           | 7                                         | PB_SI0_CTL[MODE]                                                           | PB Slave image 0 image select                   |  |
|                | 6                                         | PB_SI0_CTL[DEST]                                                           | PB Slave image 0 destination                    |  |
|                | 5-0                                       | Powe                                                                       | erSpan II Reserved                              |  |
| 0x2A           | 7                                         | PB_SI0_CTL[PRKEEP]                                                         | PB Slave image 0 image prefetch read keep       |  |
|                | 6-5                                       | PB_SI0_CTL[END]                                                            | PB Slave image 0 image endian conversion        |  |
|                | 4-3                                       | PowerSpan II Reserved                                                      |                                                 |  |
|                | 2-0                                       | PB_SI0_CTL[RD_AMT]                                                         | PB Slave image 0 Read Prefetch Amount           |  |
| 0x2B           | 7-0                                       | PB_SI0_TADDR[31:24]     PB Slave image 0 translation address b       31-24 |                                                 |  |
| 0x2C           | 7-0                                       | PB_SI0_TADDR[23:16] PB Slave image 0 translation address bit 23:16         |                                                 |  |
| 0x2D           | 7-4 PB_SI0_TADDR[15:12] PB Slave<br>15-12 |                                                                            | PB Slave image 0 translation address bits 15-12 |  |
|                | 3                                         | PB_SI0_TADDR[M3]                                                           | PB Slave image 0 master 3 select                |  |
|                | 2                                         | PB_SI0_TADDR[M2]                                                           | PB Slave image 0 master 2 select                |  |
|                | 1                                         | PB_SI0_TADDR[M1]                                                           | PB Slave image 0 master 1 select                |  |
|                | 0                                         | PowerSpan II Reserved                                                      |                                                 |  |
| 0x2E           | 7-0                                       | PB_SI0_BADDR[31:24]                                                        | PB Slave image 0 base address bits 31-24        |  |
| 0x2F           | 7-0                                       | PB_SI0_BADDR[23:16]                                                        | PB Slave image 0 base address bits 23-16        |  |
| 0x30           | 7-4                                       | PB_SI0_BADDR[15:12]                                                        | PB Slave image 0 base address bits 15-12        |  |
|                | 3-0                                       | Powe                                                                       | erSpan II Reserved                              |  |
| 0x31           | 7-0                                       | PB_REG_ADDR[31:24]                                                         | PB Slave register image base address bits 31-24 |  |

| Table 36: Power-u | p EEPROM Load | Sequence |
|-------------------|---------------|----------|
|-------------------|---------------|----------|

| Byte<br>Offset | Bit | Name                                       | Description                                     |  |
|----------------|-----|--------------------------------------------|-------------------------------------------------|--|
| 0x32           | 7-0 | PB_REG_ADDR[23:16]                         | PB Slave register image base address bits 23-16 |  |
| 0x33           | 7-4 | PB_REG_ADDR[15:12]                         | PB Slave register image base address bits 15-12 |  |
|                | 3-2 | Powe                                       | erSpan II Reserved                              |  |
|                | 0   | PB_REG_ADDR[END]                           | PB Slave register image endian conversion       |  |
| 0x34           | 7-0 | P2_ID[DID[15:8]]                           | PCI-2 Device ID bits 15-8                       |  |
| 0x35           | 7-0 | P2_ID[DID[7:0]] PCI-2 Device ID bits 7-0   |                                                 |  |
| 0x36           | 7-0 | P2_ID[VID[15:8]] PCI-2 Vendor ID bits 15-8 |                                                 |  |
| 0x37           | 7-0 | P2_ID[VID[7:0]] PCI-2 Vendor ID bits 7-0   |                                                 |  |
| 0x38           | 7-0 | P2_CLASS[BASE] PCI-2 Base Class Code       |                                                 |  |
| 0x39           | 7-0 | P2_CLASS[SUB]                              | PCI-2 Sub Class Code                            |  |
| 0x3A           | 7-0 | P2_CLASS[PROG] PCI-2 Programming Interface |                                                 |  |
| 0x3B           | 7-0 | P2_CLASS[RID] PCI-2 Revision ID            |                                                 |  |
| 0x3C-0x3F      | 7-0 | PowerSpan II Reserved                      |                                                 |  |
|                | •   | End of load sequ                           | ence                                            |  |
| 0x40-0xFF      | 7-0 | Reserved for PCI Vital Product Data (VPD)  |                                                 |  |



When a long EEPROM load is executed, the PB Slave Image 0 is enabled automatically. The IMG\_EN bit is set to 1 in the PB\_S1\_CTL register.

When the reset sequence is initiated by assertion of PB\_RST\_, P1\_RST# or P2\_RST#, the first byte of the EEPROM is read to determine the loading sequence desired. All bytes for the selected load option are read from the EEPROM, but only a subset of PowerSpan II registers are updated. This subset is defined by the external reset pin that initiated the reset sequence. Only those register bits affected by the active reset pin(s) are updated with EEPROM contents. See "Register Descriptions" on page 283 for more information.

# 5.3 Bus Master I<sup>2</sup>C Transactions

I<sup>2</sup>C master reads and writes can be performed from any one of the PowerSpan II's three interfaces — PB, PCI-1 or PCI-2. These I<sup>2</sup>C transactions are generated by accessing the "I2C/EEPROM Interface Control and Status Register" on page 383. This register can be used to access EEPROMs or perform arbitrary single byte transfers to other I<sup>2</sup>C compatible devices. Since the I<sup>2</sup>C Interface is a shared resource, software must use a PowerSpan II register semaphore, SEMAx, to acquire exclusive access to interface before initiating transactions with I2C\_CSR. The I2C\_CSR register contains the following fields:

- EEPROM Address (ADDR): The 8-bit EEPROM address specifies the address for byte writes and random reads.
- Data (DATA): The 8-bit data field is the source for writes and destination for reads.
- Device Code (DEV\_CODE): Device code is the 4-bit field that specifies the I<sup>2</sup>C device type. The default is 1010b which is the code for EEPROMs.
- Chip Select (CS): Chip select is the 3-bit field use to select one of the eight slaves on the I<sup>2</sup>C bus. The device code and chip select fields together form the I<sup>2</sup>C 7-bit device address.
- Read/Write (RW)
- Active (ACT): When the active bit is set, a transfer is in progress and the register is in read-only mode. After performing a write or read access, the user must poll the active bit until it is negated before performing other transfers. The active bit is also asserted during power-up EEPROM load and when a PCI Vital Product Data transfer is in progress.
- Error (ERR): If the PowerSpan II is unable to complete an I<sup>2</sup>C access, the ERR bit is set when the ACT is negated. The ERR bit must be cleared before attempting another access.

# 5.4 PCI Vital Product Data (VPD)

Vital Product Data (VPD) is the information that uniquely defines items such as the 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. PowerSpan II supports VPD through the serial EEPROM. If an external EEPROM is not used, the VPD feature is disabled.

There are four bits in Table 36 associated with PCI Vital Product Data: VPD\_EN and VPD\_CS[2:0]. These bits may also be programmed in the "Miscellaneous Control and Status Register" on page 378.

When VPD\_EN is set, PowerSpan II supports PCI Vital Product Data through the VPD capabilities registers in the PCI Configuration Space of the designated Primary PCI Interface (see "Primary PCI" on page 44). The VPD may be located in two different places: the upper 192 bytes of the first EEPROM (VPD\_CS=000) or the entire 256 bytes of a second EEPROM with chip select VPD\_CS. The VPD Enable and VPD Chip Select fields in the "Miscellaneous Control and Status Register" on page 378 are initialized as part of the short load post reset sequence.

If VPD is located in the first EEPROM, the first byte is located at offset 0x40. On every VPD transfer, PowerSpan II adds the offset 0x40 to the address in the P1\_VPDC or P2\_VPDC register. If VPD is not located in the first EEPROM, then the address in the P1\_VPDC or P2\_VPDC register is used directly as the 8 bit EEPROM address.

Accesses to Vital Product Data in external EEPROM is performed in the manner described in "Bus Master I<sup>2</sup>C Transactions" on page 161.



The bit ordering of the data returned from EEPROM in the "PCI 1 Vital Product Data Register" on page 321 can be addressed according to little-endian or big-endian conventions. See the bit ordering information in the register table to obtain the necessary bit ordering information.



# 6. Arbitration

Arbitration is a process used by multi-drop bus protocols, such as PCI, to support read and write access on a peripheral bus. A bus arbiter is a logic module that controls access to the bus by the devices residing on it. For example, when a device requires access to the bus it sends a request signal to the bus arbiter. If the bus is not active, the arbiter grants the device access; otherwise, the device must continue to request access until it is successful in obtaining the bus.

This chapter discusses the following topics about PowerSpan II's Processor Bus and PCI arbitration capabilities:

- "PCI Interface Arbitration" on page 163
- "Processor Bus Arbitration" on page 168

# 6.1 **Overview**

PowerSpan II has three arbiters. There is an arbiter on each PCI interface: PCI-1 and PCI-2. There is also one arbiter for the Processor Bus Interface.

# 6.2 PCI Interface Arbitration

Each PowerSpan II PCI Interface supports a PCI central arbiter. Each arbiter has dedicated support for the PowerSpan II PCI Master — with internal request and grant signaling and up to four external PCI masters.

PowerSpan II provides external pins to support three additional external PCI masters — PCI\_REQ[7:5]#/PCI\_GNT[7:5]#. Pairs of these additional arbitration pins can be individually assigned to the PCI-1 arbiter or the PCI-2 arbiter (see Figure 20). Assignment of these pins is accomplished by initializing the PCI Arbiter Master (PCI\_Mx) bits and PCI Arbiter Pins Configuration (PCI\_ARB\_CFG) bit in the "Miscellaneous Control and Status Register" on page 378. These bits can be configured either through EEPROM load at reset (see "I2C/EEPROM" on page 153) or direct PowerSpan II register access. Requests on PCI\_REQ#[7:5] are ignored until these bits are initialized.



Signals PCI\_REQ[7:5]# / PCI\_GNT[7:5]# operate at a maximum of 33 MHz.



Figure 20: Assignment of Additional Bus Requesters with PCI Arbiters



In the Single PCI PowerSpan II, PCI\_REQ#[7:5]/PCI\_GNT#[7:5] are assigned to the PCI-1 arbiter

## 6.2.1 Arbitration Levels

The PowerSpan II PCI arbiter implements a fairness algorithm in order to prevent deadlocks. There are two priority levels signed to the PCI master agents. Fairness is defined by the *PCI 2.2 Specification* as an algorithm that grants all potential PCI masters access to the bus, independent of other requests.

#### 6.2.1.1 High and Low Priority PCI Agents

There are two priority levels assigned to the PCI Master Agents: high priority and low priority. Each priority level performs a round-robin arbitration algorithm among the PCI masters assigned to each level. For example, all the PCI masters assigned to the lower priority level represent one entry in the higher priority round-robin arbitration. For every turn of the high priority round-robin arbitration, high priority PCI masters asserting Px\_REQ# are granted access to the PCI bus. At the same time, only one lower priority level PCI master asserting Px\_REQ# is granted access to the PCI bus.

Arbitration on PowerSpan II is hidden. Hidden arbitration means it occurs during the previous access so that no PCI cycles are consumed due to arbitration — except when the bus is in an idle state.

#### 6.2.1.2 Requesting the PCI Bus

When the bus is idle a master requesting the bus has 16 clocks from the detection of Px\_GNT# asserted to drive Px\_FRAME# asserted. If the 16 clocks is exceeded, the arbiter assumes the master is unable to drive the bus and re-arbitrates the bus to another requesting master. PCI masters unable to assert Px\_FRAME# within 16 clocks of detecting Px\_GNT# asserted lose their turn to access the PCI bus.



The PCI bus is idle when both Px\_FRAME# and Px\_IRDY# are negated.

#### Functioning and Non-functioning PCI Masters

A master that does not respond to the Px\_GNT# signal in 16 clocks is considered a non-functioning master by the PowerSpan II PCIx Arbiter when the Status enable (STATUS\_EN) bit is set to 1 in the PCIx Arbiter Control register (see page 339). The STATUS\_EN bit enables an internal monitor in the PowerSpan II PCIx Arbiter that checks that no PCI Master waits longer than 16 PCI clock cycles before starting a transaction.

When a master takes longer than 16 clocks before starting a transaction, the STATUS bit is set to 1 in the PCI*x* Arbiter Control register (see page 339). When the STATUS bit is set to 1 by the PowerSpan II PCI*x* arbiter, the PowerSpan II arbiter does not include the non-functioning PCI Master in its arbitration algorithm. When the bit is set to 0, the operating status of the PCI Master is considered by the arbiter to be functioning and the PCI Master is included in the arbitration algorithm used by PowerSpan II.

When PowerSpan II is reset, all masters are considered functioning — the STATUS bit is set to 0.

Refer to "Bus Parking on a Non-functioning Master" on page 168 for more information on bus parking on a master that is non-functioning.

#### 6.2.1.3 PCI Master Driving the PCI Bus

A PCI master accessing the PCI bus has extended assertion of Px\_GNT# by the arbiter if no other masters are attempting to access the bus. The arbiter keeps Px\_GNT# asserted for the PCI master actively driving the bus. This enables the PCI master to extend its PCI access beyond the Latency Timer.

The Px\_GNT# to the driving PCI master remains asserted for the duration of the transaction, regardless of the state of the master's Px\_REQ# signal. The arbiter does not try to park the bus on another master while the present master is actively driving the bus with Px\_REQ# negated.

The arbiter negates all Px\_GNT# lines for all masters except the PCI master accessing the PCI bus if another PCI master asserts Px\_REQ# to gain the bus. Px\_GNT# is negated for the duration of the active access. The PowerSpan II arbiter updates the arbitration when it detects Px\_FRAME# negated and Px\_IRDY# asserted — which occurs in the last data phase of the transaction. The arbitration update is designed to minimize the latency to higher priority PCI masters which may have asserted their Px\_REQ# while the present transaction was active.

The arbitration algorithm is illustrated in Figure 21.





Each PowerSpan II PCI arbiter is programmable with the corresponding arbiter control register (see "PCI 1 Bus Arbiter Control Register" on page 339) and enabled through power-up option PCI x Arbiter enable (PWRUP\_Px\_ARB\_EN) (see "Resets, Clocks and Power-up Options" on page 201). Each master has a arbitration level for PCI Master Device x (Mx\_PRI) bit in the "PCI 1 Bus Arbiter Control Register" on page 339 (Px\_ARB\_CTRL) to determine its arbitration level.

#### External Arbitration

When an external arbiter is used, the PowerSpan II PCI Master uses Px\_REQ#[1]/ Px\_GNT#[1] to acquire the bus.

## 6.2.2 Bus Parking

The PowerSpan II PCI arbiter provides a flexible address bus parking scheme. When no master is requesting the address bus, the PCI arbiter can park on either the:

- last bus master
- specific bus master

The bus parking mode is determined by PARK bit in the Px\_ARB\_CTRL register. When Specific Master mode is selected by setting the PARK bit to 0, the BM\_PARK[2:0] field selects the specific bus master for bus parking. The parked master must enable its drivers for the following PCI signals:

- AD[31:0]
- Px\_C/BE#[3:0]
- PAR

Bus parking does not occur until the PCI bus is idle. When a PCI master is accessing the bus when no Px\_REQ# signals are asserted to the PowerSpan II PCI arbiter, Px\_GNT# remains asserted to the master until the bus becomes idle.

#### 6.2.2.1 Bus Parking on a Non-functioning Master

It is possible for PowerSpan II to park the bus on a master that is considered nonfunctioning or to park the bus on the last master that has a status that has changed to non-functioning by the STATUS bit is set to 1 in the PCLx Arbiter Control register (see page 339). Refer to "Functioning and Non-functioning PCI Masters" on page 165 for a detailed description of functioning and non-functioning PCI Masters.

When PowerSpan II parks the bus on a non-functioning PCI Master, the PowerSpan II PCIx Arbiter waits for another master to request the bus. Once another master request the bus the PCIx Arbiter then ignores the non-functioning master until the master is considered functioning. The master status is considered functioning after PowerSpan II is reset (default setting) or the STATUS bit is cleared.

# 6.3 **Processor Bus Arbitration**

PowerSpan II's internal processor bus arbiter is enabled through a power-up option (PWRUP\_PB\_ARB\_EN, see "Resets, Clocks and Power-up Options" on page 201). When the internal arbiter is enabled, PowerSpan II's PB Master uses an internal arbitration mechanism to acquire the processor bus. When the internal arbiter is disabled an external arbiter is implemented. The PB Master uses Address Bus Request (PB\_BR[1]\_), Address Bus Grant (PB\_BG[1]\_) and Data Bus Grant (PB\_DBG[1]\_) to gain external bus ownership.

PowerSpan II's internal processor bus arbiter supports three external processor bus masters and implements internal request and grant lines for the PowerSpan II itself — four processor bus masters in total. The external masters are enabled with the External Master x Enable (Mx\_EN) bits in the "Processor Bus Arbiter Control Register" on page 364.

The processor bus arbiter implements two levels of priority. Devices programmed into a specific priority level operate in a round robin fashion. Each master has a External Master x Priority Level (Mx\_PRI) bit in the PB\_ARB\_CTRL register to determine its arbitration level for the address bus. The arbitration level for each master can be reconfigured during system run-time.

### 6.3.1 Address Bus Arbitration

The PB\_BG\_ pins change state under the following conditions:

- The assertion of PB\_REQ\_ when the bus is idle.
- After the assertion of PB Address Acknowledge (PB\_AACK\_), Bus Grant (PB\_BG\_) changes to the next requesting master or the parked master.



Requesting masters are required to qualify bus grants before beginning an address tenure.

The MPC8260 and other processor bus agents require the system signal ABB\_ to qualify address bus grants. The PowerSpan II PB Master Interface does not require ABB\_ to qualify data bus grants.

#### 6.3.1.1 Bus Parking

The PowerSpan II processor bus arbiter provides a flexible address bus parking scheme. When no master is requesting the address bus, the processor bus arbiter can park on either the:

- last bus master
- specific bus master

The bus parking mode is determined by the PARK bit in the PB\_ARB\_CTRL Register. When specific master mode is selected (PARK = 0), the BM\_PARK[1:0] field selects the specific bus master for address parking.



The parked master does not drive any address bus signals until it generates a request to use the address bus.

## 6.3.2 Data Bus Arbitration

The arbiter samples PB\_TT[3] when PB\_TS\_ is asserted to generate data bus requests. The arbiter grants the data bus to the current address bus owner by asserting one of PB\_DBG[1:3]\_ signals. The signal is asserted, by default, one clock after PB\_TS\_. The PB arbiter can be programmed to sample requests two clocks after the PB\_TS\_ signals is asserted. The arbiter is programmed through the **TS\_DLY** bit in the Processor Bus Arbiter Control register (see page 364).



An example application for this feature is some L2 caches hold the BR\_ signal after the TS\_ signal starts. The PowerSpan II arbiter could see this as a valid request and give the bus to the L2 cache when the bus was not requested. This bit delays when the PB arbiter samples the signal so a false bus request is not granted.

The current data bus grant is negated when the requesting master has qualified the grant.



Requesting masters are required to qualify bus grants before beginning an data tenure.

The MPC8260 and other processor bus agents require the system signal DBB\_ to qualify data bus grants. The PowerSpan II PB Master does not require DBB\_ to qualify data bus grants.

#### 6.3.2.1 Qualifying Data Bus Grant

Some processors, specifically the MPC7400, must have the data bus grant qualified by the arbiter before it is issued to the master. PowerSpan II, by default, does not qualify the data bus grant by the PowerSpan II PB Arbiter and requires that the requesting master qualify bus grants before beginning an data tenure.

The PowerSpan II PB Arbiter can be programmed to qualify data bus grants before issuing them by setting the 7400\_MODE bit in the Reset control and Status register (see page 385). When the 7400\_MODE bit is set to 1, the PB arbiter qualifies data bus grants before issuing them to a processor bus master. When the 7400\_MODE bit is disabled (default setting) the PB arbiter issues a data bus grant to the processor bus master and expects that the processor bus master the at receives the grant qualifies the grant.

The 7400\_MODE bit is a power-up option.

## 6.3.3 Address Only Cycles

The arbiter supports address only cycles. If Transfer Type (PB\_TT[3]) is sampled low during PB\_TS\_, the arbiter does not grant the data bus. The use of PB\_TT[3] as a data bus request means that the PowerSpan II PB arbiter does not support the processor bus instructions eciwx and ecowx.

## 6.3.4 PowerSpan II Arbiter and System Boot

System boot from the PCI bus can be selected by configuring the processor bus arbiter at power-up to ignore all external requests on PB\_BR[3:1]\_. This allows an external PCI master, with the PowerSpan II PB Master, to configure the MPC8260 memory controller and load boot code before enabling recognition of requests on PB\_BR[3:1]\_.

Alternatively, at power-up the processor bus arbiter can be configured to recognize requests on PB\_BR[1]\_ and ignore requests on PB\_BR[3:2]\_. In this case the processor connected to PB\_BR[1]\_ can enable recognition of requests from other masters when its system configuration tasks are complete.

The PowerSpan II processor bus arbiter controls system boot with the M3\_EN, M2\_EN and M1\_EN bits in the "PCI 1 Bus Arbiter Control Register" on page 339 (PB\_ARB\_CTRL), as well as the power-up option PWRUP\_BOOT.

The default value of these Mx\_EN bits in the PB\_ARB\_CTRL register are set using the PWRUP\_BOOT option shown in Table 37. When PWRUP\_BOOT is selected to boot from PCI, both Px\_LOCKOUT bits in the MISC\_CSR register are cleared automatically, even if an EEPROM is not present.

| PWRUP_BOOT<br>Selection | RST_CSR Register | M1_EN | M2_EN | M3_EN |
|-------------------------|------------------|-------|-------|-------|
| Boot PCI                | PCI_BOOT=1       | 0     | 0     | 0     |
| Boot PB                 | PCI_BOOT=0       | 1     | 0     | 0     |

Table 37: Mx\_EN Default State

The processor bus arbiter does not have to be enabled to select either PCI or processor bus boot. The PWRUP\_BOOT option sets the M1\_EN bit in the PB\_ARB\_CTL register and the P1\_LOCKOUT and P2\_LOCKOUT bits in the MISC\_CSR register. Setting the Px\_LOCKOUT bits means any configuration cycles for PowerSpan II on the PCI bus are retried until the Px\_LOCKOUT bits are cleared from the processor bus or the EEPROM. When PCI\_BOOT is set to 1 (boot is from PCI) the Px\_LOCKOUT bits are not set

For more information on power-up options and boot selection, refer to "PowerSpan II Power-up Options" on page 207.



# 7. Interrupt Handling

An interrupt is a signal informing a program that an event (for example, an error) has occurred. When a program receives an interrupt signal, it temporarily suspends normal processing and diverts the execution of instructions to a sub-routine handled by an interrupt controller. The controller communicates with the host processor and the device that initiated the interrupt to determine how to handle the interrupt.

This chapter discusses the following topics about the PowerSpan II interrupt features:

- "Interrupt Sources" on page 173
- "Interrupt Registers" on page 175
- "Interrupt Pins" on page 183
- "Mailboxes" on page 185
- "Doorbells" on page 185

# 7.1 Overview

PowerSpan II handles interrupts both from normal device operation and from exceptions. These interrupts are programmed through certain register settings and are signaled through both input and output signal pins.

The following sections describes PowerSpan II interrupt handling.

# 7.2 Interrupt Sources

Interrupt sources are classified as originating from normal device operation or conditions generated from an exception.

These classifications are discussed in the following sections.

## 7.2.1 Interrupts from Normal Operations

Interrupt sources associated with normal device operations are:

• Eight bidirectional, configurable interrupts pins:

P1\_INTA#, P2\_INTA#, INT[5:0]\_

- DMA channels (see "DMA Interrupts" on page 184 for DMA interrupt sources)
- Doorbell interrupts (see "Interrupt Enable Register 0" on page 393 for doorbell interrupt generation)
- Mailbox interrupts (see "Mailbox x Register" on page 412)

#### 7.2.2 Interrupts from Transaction Exceptions

Bus transaction exceptions can occur on any one of the PowerSpan II interfaces — PCI-1, PCI-2 or Processor Bus (PB) — because of bus errors, address parity errors, or data parity errors. When an error occurs, PowerSpan II tracks the direction of the transaction through the interrupt enabling and status function.

Interrupt sources associated with exceptions are:

- 1. PB Interface errors
  - PB\_P1\_ERR
  - PB\_P2\_ERR
  - PB\_A\_PAR
  - PB\_P1\_D\_PAR
  - PB\_P2\_D\_PAR
  - PB\_P1\_RETRY
  - PB\_P2\_RETRY
  - PB\_PB\_ERR
  - PB\_PB\_D\_PAR
  - PB\_PB\_RETRY
- 2. PCI-1 Interface errors
  - P1\_PB\_ERR
  - P1\_P2\_ERR
  - P1\_A\_PAR

- P1\_PB\_RETRY
- P1\_P2\_RETRY
- P1\_P1\_ERR
- P1\_P1\_RETRY
- 3. PCI-2 Interface errors
  - P2\_PB\_ERR
  - P2\_P1\_ERR
  - P2\_A\_PAR
  - P2\_PB\_RETRY
  - P2\_P1\_RETRY
  - P2\_P2\_ERR
  - P2\_P2\_RETRY

See "Error Handling" on page 187 for information on how these interrupts for bus transaction exceptions are associated with error logging functionality.

# 7.3 Interrupt Registers

PowerSpan II interrupt status and enabling, as well as message passing through mailboxes and doorbells are controlled by the interrupt registers. Table 38 provides a description of PowerSpan II registers controlling these functions.

| Register Type | Register Description and Operation                                                                                                                                                                                                                                                             |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Status        | The status register bits cover all of the interrupt sources supported PowerSpan II<br>and indicate active interrupt sources when set (see "Interrupt Status" on<br>page 177).<br>With a some exceptions, all bits in these registers are read and cleared by setting<br>("R/Write 1 to Clear") |  |
| Enable        | The enable register bits cover all of the interrupt sources supported by PowerSpan II and allow status bits to assert an external pin (see "Interrupt Enable" on page 179).<br>With some exceptions, all bits in these registers are Read/Write.                                               |  |

Table 38: Interrupt Register Description

| Register Type | Register Description and Operation                                                                                                                                                                                                                     |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mapping       | This series of registers allow each interrupt source to be mapped to a specific interrupt output pin. The mapping definitions are provided in Table 43 (see "Interrupt Mapping" on page 181)                                                           |  |
| Direction     | Interrupt Direction refers to the ability to control the input/output characteristi<br>the PowerSpan II interrupt pins. Each pin has a corresponding bit that configu<br>as either an input-only or an output-only (see "Interrupt Pins" on page 183). |  |
| Mailbox       | The Mailbox registers are a series of eight 32-bit Read/Write registers available for message passing between PowerSpan II interfaces (see "Mailboxes" on page 185)                                                                                    |  |

Table 38: Interrupt Register Description

## 7.3.1 Interrupt Status

When an interrupt source becomes active, the relevant status bit is set in one of the interrupt status registers. Interrupt Status is reported through two registers: "Interrupt Enable Register 0" on page 393 and "Interrupt Status Register 1" on page 390. Interrupt Status Register 0 provides status for interrupts resulting from normal device operation. This includes I<sup>2</sup>O, DMA, hardware, doorbell and mailbox interrupts. A register description for ISR0 is provided in Table 39.

All status bits are clear by default.

| Bits      | Туре                      | Description                                                                                                                                                                       |
|-----------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ISR1_ACTV | R                         | This bit indicates an active status bit in ISR1. This enables software to monitor activity of the other interrupt status register while observing this interrupt status register. |
| I2O_HOST  | R                         | Indicates to the Host that there are outstanding Message Frame<br>Addresses in the Outbound Post List FIFO.                                                                       |
| 120_10P   | R/<br>Write 1<br>to Clear | Indicates to the IOP that there are outstanding Message Frame<br>Addresses in the Inbound Post List FIFO.                                                                         |
| DMAx      | R/<br>Write 1<br>to Clear | Status bit is set when DMAx generates an interrupt. See "DMA x General Control and Status Register" on page 372 for details of DMAx interrupt sources.                            |
| x_HW      | R/<br>Write 1<br>to Clear | An interrupt is outstanding on an interrupt input (one of eight interrupt pins, see "Interrupt Pins" on page 183).                                                                |
| DBx       | R/<br>Write 1<br>to Clear | Set when a doorbell register is written to in the corresponding IER0 bit.                                                                                                         |
| MBOXx     | R/<br>Write 1<br>to Clear | Set when there is a write to a mailbox.                                                                                                                                           |

#### Table 39: Register Description for Interrupt Status Register 0

Interrupt Status Register 1 provides status for interrupts resulting from exceptions occurring during device operation. This includes maximum retry errors, bus errors, and parity error. A register description for ISR1 is provided in Table 40.

Table 40: Register Description for Interrupt Status Register 1

| Bits       | Туре                      | Description                                                                                                                                                                                                     |
|------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ISR0_ACTV  | R                         | This bit allows software to monitor activity of the other interrupt status register while observing this interrupt status register. It essentially chains the two registers so both are only read if necessary. |
| PB_x_RETRY | R/<br>Write 1<br>to Clear | The PowerSpan II PB Master Interface has detected more than the maximum allowable retries.                                                                                                                      |
| PB_x_ERR   | R/<br>Write 1<br>to Clear | The PowerSpan II PB Interface asserted (as slave) or received (as master) PB_TEA The PB slave detects illegal conditions, while the PB master receives PB_TEA                                                   |
| PB_A_PAR   | R/<br>Write 1<br>to Clear | An address parity error was detected on the PB.                                                                                                                                                                 |
| PB_x_D_PAR | R/<br>Write 1<br>to Clear | A data parity error was detected on the PB.                                                                                                                                                                     |
| P2_x_ERR   | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-2 Interface detected an error. The corresponding PCI Control and Status Register must be checked for the error.                                                                            |
| P2_A_PAR   | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-2 Interface detected an address parity error.                                                                                                                                              |
| P2_x_RETRY | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-2 Master has detected more than the maximum allowable retries.                                                                                                                             |

| Bits       | Туре                      | Description                                                                                                                          |
|------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| P1_x_ERR   | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-1 Interface detected an error. The corresponding PCI Control and Status Register must be checked for the error. |
| P1_A_PAR   | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-1 Interface detected an address parity error.                                                                   |
| P1_x_RETRY | R/<br>Write 1<br>to Clear | The PowerSpan II PCI-1 Master has detected more than the maximum allowable retries.                                                  |

#### Table 40: Register Description for Interrupt Status Register 1

The description in Table 40 groups several bits under one name. For example, P1\_x\_RETRY actually corresponds to P1\_P2\_RETRY, P1\_PB\_RETRY, and P1\_P1\_RETRY.

PowerSpan II has the following conventions:

- For errors detected by a master, PowerSpan II has separate reporting mechanisms for each source interface. For example, if the PowerSpan II PCI-2 master detects an address parity error on a transaction claimed by the PB slave, the P2\_PB\_A\_PAR bit in the ISR1 register is set.
- For errors detected by a target/slave, PowerSpan II has separate reporting mechanisms for each destination port. For example, if the PowerSpan II PB slave detects a data parity error on a transaction destined for an agent connected to the PCI-1 external interface, the P1\_PB\_A\_PAR bit in the ISR1 register is set.

## 7.3.2 Interrupt Enable

Each interrupt enable bit allows an active source status bit to assert one of the external interrupt pins. Interrupt enabling is controlled through two registers: "Interrupt Enable Register 0" on page 393 and "Interrupt Status Register 1" on page 390. Interrupt Enable Register 0 enables interrupts resulting from normal device operation. This includes I<sup>2</sup>O, DMA, hardware, doorbell and mailbox interrupts. A register description for IER0 is in Table 41.

All interrupts are disabled by default.

| Bits          | Туре              | Description                                                                                                            |
|---------------|-------------------|------------------------------------------------------------------------------------------------------------------------|
| I2O_HOST_MASK | R/W               | Masks an interrupt to the Host that there are outstanding MFAs in the Outbound Post List FIFO.                         |
| I2O_IOP_EN    | R/W               | Enables an interrupt to the IOP indicating that there are outstanding MFAs in the Inbound Post List FIFO.              |
| DMAx_EN       | R/W               | Enables the DMAx interrupt                                                                                             |
| x_HW_EN       | R/W               | Enables the corresponding hardware interrupt source t (one of eight interrupt pins, see "Interrupt Pins" on page 183). |
| DBx_EN        | Write 1<br>to Set | Sets the corresponding status bit                                                                                      |
| MBOXx_EN      | R/W               | Enables the Mailbox interrupt source                                                                                   |

 Table 41: Register Description for Interrupt Enable Register 0

Interrupt Enable Register 1 enables interrupts resulting from errors occurring during the device operation. This includes maximum retry errors, bus errors, and parity errors. A register description for IER1 is in Table 42.

Table 42: Register Description for Interrupt Enable Register 1

| Bits          | Туре | Description                                                                                                                                                     |
|---------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_x_RETRY_EN | R/W  | Enables interrupt if the PowerSpan II PB Master has detected more than the maximum allowable retries.                                                           |
| PB_x_ERR_EN   | R/W  | Enables interrupt if the PowerSpan II PB Interface asserted (as slave) or received (as master) PB_TEA                                                           |
| PB_A_PAR_EN   | R/W  | Enables interrupt if an address parity error was detected on the PB.                                                                                            |
| PB_x_D_PAR_EN | R/W  | Enables interrupt if a data parity error was detected on the PB.                                                                                                |
| P2_x_ERR_EN   | R/W  | Enables interrupt if the PowerSpan II PCI-2 Interface detected an error.<br>The corresponding PCI Control and Status Register must be checked for<br>the error. |
| P2_A_PAR_EN   | R/W  | Enables interrupt if the PowerSpan II PCI-2 Interface detected an address parity error.                                                                         |
| P2_x_RETRY_EN | R/W  | Enables interrupt if the PowerSpan II PCI-2 Master has detected more than the maximum allowable retries.                                                        |

| Bits          | Туре | Description                                                                                                                                                     |
|---------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1_x_ERR_EN   | R/W  | Enables interrupt if the PowerSpan II PCI-1 Interface detected an error.<br>The corresponding PCI Control and Status Register must be checked for<br>the error. |
| P1_A_PAR_EN   | R/W  | Enables interrupt if the PowerSpan II PCI-1 Interface detected an address parity error.                                                                         |
| P1_x_RETRY_EN | R/W  | Enables interrupt if the PowerSpan II PCI-1 Master has detected more than the maximum allowable retries.                                                        |

| Table 42: Register | <b>Description fo</b> | r Interrupt Enable | <b>Register 1</b> |
|--------------------|-----------------------|--------------------|-------------------|
|                    |                       |                    |                   |

The descriptions in Table 40, Table 41, and Table 42 groups several bits under one name. For example, P1\_x\_RETRY actually corresponds to P1\_P2\_RETRY, P1\_PB\_RETRY, and P1\_P1\_RETRY.

For errors detected by a master, PowerSpan II has separate reporting mechanisms for each source port. For example, if the PCI-2 master detects an address parity error on a transaction claimed by the PB slave, the P2\_PB\_A\_PAR bit in the ISR1 register is set.

For errors detected by a target/slave, PowerSpan II has separate reporting mechanisms for each destination port. For example, if the PowerSpan II PB slave detects a data parity error on a transaction destined for an agent connected to the PCI-1 external interface, the P1\_PB\_A\_PAR bit in the ISR1 register is set.

### 7.3.3 Interrupt Mapping

The following registers contain mapping bits for PowerSpan II interrupt sources:

- IMR\_MBOX (mailbox sources)
- IMR\_DB (doorbell sources)
- IMR\_DMA (DMA channel sources)
- IMR\_HW (external pin sources)
- IMR\_P1 (PCI-1 sources)
- IMR\_P2 (PCI-2 sources)
- IMR\_PB (Processor Bus sources)
- IMR2\_PB (Processor Bus sources)
- IMR\_MISC (I<sub>2</sub>O sources)

Each interrupt source contains a three bit field in an IMR\_x register. This mapping field determines which external pin to assert when the source is active and enabled.

Table 43 details the mapping scheme. The shaded area in the table denotes the shaded map field and interrupt pin information apply only to the Dual PCI PowerSpan II

| Map Field | Interrupt Pin |
|-----------|---------------|
| 000       | P1_INTA#      |
| 001       | P2_INTA#      |
| 010       | INT[0]_       |
| 011       | INT[1]_       |
| 100       | INT[2]_       |
| 101       | INT[3]_       |
| 110       | INT[4]_       |
| 111       | INT[5]_       |

Table 43: Mapping Definition

# 7.4 Interrupt Pins

PowerSpan II has the following interrupt pins:

- P1\_INTA#
- P2\_INTA#
- INT[5:0]\_

Pins INT[5:0]\_ are 5V tolerant and general purpose interrupt pins. Interrupt pins are active low and, when configured as input, are sampled on three successive processor bus clock edges to ensure appropriate setting of a status bit.

Each pin is bidirectional, open drain, active low and level sensitive. The input/ output character of each interrupt pin is controlled through a corresponding bit in the "Interrupt Direction Register" on page 410. Each pin can be configured as either an input or output. All pins are configured as inputs by default.

P1\_INTA# and P2\_INTA# are intended to be used with PCI interfaces PCI-1 and PCI-2. They are electrically PCI compliant. To configure PCI interface Px with interrupt capability, the following register settings are required:

- INT\_PIN = 0x01, in the "PCI 1 Miscellaneous 1 Register" on page 315 (Px\_MISC1). This setting enables a single function PCI device INTA#
- Px\_HW\_DIR = 0x01, in the "Interrupt Direction Register" on page 410 (ID). Px\_INTA# is configured as an output pin.

If the PCI interface Px does not require interrupt capability, the following register settings are necessary:

- INT\_PIN = 0x00, in the Px\_MISC1 register. This setting enables a single function PCI device that is using no interrupts.
- Px\_INTA = user defined, in the ID register. Px\_INTA# is used as general purpose pin.

PowerSpan II provides an EEPROM load feature to automatically control the interrupt capabilities of PCI-1 and PCI-2 (see "I2C/EEPROM" on page 153).

## 7.5 DMA Interrupts

The PowerSpan II DMA supports a number of interrupt sources for each channel. Individual enable and status bits exist for each source. The status and enable bits are contained in the "DMA x General Control and Status Register" on page 372:

| Interrupt Source | Enable bit |
|------------------|------------|
| DONE             | DONE_EN    |
| P1_ERR           | P1_ERR_EN  |
| P2_ERR           | P2_ERR_EN  |
| PB_ERR           | PB_ERR_EN  |
| HALT             | HALT_EN    |
| STOP             | STOP_EN    |

**Table 44: DMA Channel Interrupt Sources and Enables** 

The following programming steps route done, halt and stop interrupts on DMA channel two onto INT[3]\_:

- Set the DMA2\_EN bit in the IER0 register
- Program the DMA2\_MAP bit to 0bx101 in the IMR\_DMA register
- Set the DONE\_EN, HALT\_EN, STOP\_EN bits in the "DMA x General Control and Status Register" on page 372 (DMAx\_GCSR)

### 7.5.1 DMA Interrupt Servicing

To service a DMA interrupt, the following steps must be taken:

- Read "Interrupt Enable Register 0" on page 393 (ISR0) to determine which DMA channel caused the interrupt
- Read DMAx\_GCSR to determine which DMA source caused the interrupt
- Service the interrupt
- Write 1 to clear DMAx\_GCSR[*status\_bit*] and allow a restart of the DMA channel
- Write 1 to clear the DMAx\_EN bit in the ISR0 register and negate the interrupt signal

# 7.6 Mailboxes

PowerSpan II provides eight 32-bit general Mailbox registers for passing messages between processes. Each Mailbox has an associated interrupt enable and status bit. When enabled, an interrupt is generated whenever there is a write to the Mailbox register.

# 7.7 Doorbells

The Doorbell interrupts are generated by writing 1 to the corresponding Doorbell x Enable (DBx\_EN) bit in the "Interrupt Enable Register 0" on page 393. The Doorbell interrupt is cleared by writing a 1 to the corresponding Doorbell x (DBx) bit in the "Interrupt Status Register 0" on page 388.



# 8. Error Handling

Errors occur in a system as a result of parity, bus, or internal problems. In order to handle errors so that they have minimum effects on an application, devices have a logic module called an error handler. The error handler logs data about the error then communicates the information to another device (for example, a host processor) that is capable of resolving the error condition.

This chapter discusses the following topics about PowerSpan II's error handling features:

- "PB Interface Errors" on page 188
- "PCI Interface Errors" on page 192
- "DMA Errors" on page 198

### 8.1 **Overview**

PowerSpan II has error detection, error reporting and error recovery mechanisms for each of the major interfaces — Processor Bus (PB), PCI-1 and PCI-2.

The master and target/slave of each interface provides error detection for transactions where they participate. The types of errors identified are:

- address parity
- data parity
- bus errors (Target-Abort, Master-Abort, and PB\_TEA\_ assertion)
- maximum retry errors

Each of PowerSpan II's interfaces has a mechanism for reporting detected errors to hardware and/or software. The reporting mechanisms include:

- interrupt status bits in the "Interrupt Status Register 1" on page 390 the error is reported through PowerSpan II's interrupt generation mechanisms
- PCI standard error reporting mechanisms
- error logging registers that capture parameters from the transaction that caused the error
- assertion of external bus protocol pins

PowerSpan II has separate reporting mechanisms for each source port when errors are detected by a master. For example, if the PC1-2 Master detects a address parity error on a transaction claimed by the PB slave, the P2\_PB\_A\_PAR bit in the ISR1 register is set.

For errors detected by a target/slave, PowerSpan II provides separate reporting tools for each destination port. For example, if the PowerSpan II PB slave detects a data parity error on a transaction destined for an agent connected to the PCI-1 external interface, the PB\_P1\_D\_PAR bit in the ISR1 is set.

Each PowerSpan II DMA channel provides an additional reporting mechanism (see "DMA Errors" on page 198).

### 8.2 **PB Interface Errors**

The PB master and slave detect error conditions while participating in PB transactions. In addition to Interrupt Status Register 1, the PB Interface has the following error reporting mechanisms:

- Assertion of PB\_TEA\_ provided the Transfer Error Acknowledge Enable (TEA\_EN) bit in the "Processor Bus Miscellaneous Control and Status Register" on page 361 (PB\_MISC\_CSR) is set to 1
- Capture of specific parameters from the transaction that caused the error
  - a. "Processor Bus Error Control and Status Register" on page 359 (PB\_ERRCS) logs:
    - PB\_TT signals
    - PB\_TSIZ signals
  - b. "Processor Bus Address Error Log" on page 360 (PB\_AERR) logs:
    - PB\_A signals

Table 45 itemizes the error cases detected and reported by the PB master and the PB slave. Error logging in PB\_ERRCS and PB\_AERR is triggered for each of the error cases outlined in Table 45.

| Interface | Error                                                 | Destination/Source                              | Conditions                                                                                             | Reporting                               |
|-----------|-------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------|
| PB slave  | Address parity                                        | PCI-1, PCI-2,<br>Registers                      | Address only, Write,<br>Read                                                                           | PB_A_PAR in the ISR1 register           |
|           | Data parity                                           | PCI-1, Registers                                | Write                                                                                                  | PB_P1_D_PAR in the ISR1 register        |
|           |                                                       | PCI-2                                           | Write                                                                                                  | PB_P2_D_PAR in the ISR1 register        |
|           | Illegal access                                        | PCI-1 (Memory)                                  | Unaligned access in <i>PPC</i><br><i>little-endian</i> mode                                            | PB_TEA if TEA_EN=1,<br>PB_P1_ERR in the |
|           |                                                       | PCI-1 (Configuration,<br>IO, IACK)<br>Registers | Unaligned access in <i>PPC</i><br><i>little-endian</i> mode,<br>Transaction Size > 4<br>bytes or burst | ISR1 register                           |
|           |                                                       | PCI-2 (Memory)                                  | Unaligned access in <i>PPC</i><br><i>little-endian</i> mode                                            | PB_TEA if TEA_EN=1,<br>PB_P2_ERR in the |
|           |                                                       | PCI-2 (Configuration,<br>IO, IACK)              | Unaligned access in <i>PPC</i><br><i>little-endian</i> mode,<br>Transaction Size > 4<br>bytes or burst | ISR1 register                           |
|           | Propagation of<br>error from<br>destination<br>master | PCI-1                                           | Read                                                                                                   | PB_TEA if<br>TEA_EN=1                   |
|           |                                                       | PCI-2                                           | Read                                                                                                   | PB_TEA if<br>TEA_EN=1                   |

Table 45: PB Interface Errors

| Interface | Error                                | Destination/Source                                         | Conditions | Reporting                         |
|-----------|--------------------------------------|------------------------------------------------------------|------------|-----------------------------------|
| PB Master | Data parity                          | External PCI-1 agent<br>PB to PCI-1 DMA                    | Read       | PB_P1_D_PAR in the ISR1 register  |
|           |                                      | External PCI-2 agent<br>PB to PCI-2 DMA                    | Read       | PB_P2_D_PAR in the ISR1 register  |
|           |                                      | DMA PB Linked-List<br>PB to PB DMA                         | Read       | PB_PB_D_PAR in the ISR1 register  |
|           | External agent<br>asserts<br>PB_TEA_ | External PCI-1 agent<br>PB to PCI-1 DMA<br>PCI-1 to PB DMA | Read/Write | PB_P1_ERR in the<br>ISR1 register |
|           |                                      | External PCI-2 agent<br>PB to PCI-2 DMA<br>PCI-2 to PB DMA | Read/Write | PB_P2_ERR in the ISR1 register    |
|           |                                      | DMA PB Linked-List<br>PB to PB DMA                         |            | PB_PB_ERR in the ISR1 register    |
|           | Max retry<br>expires                 | External PCI-1 agent<br>PB to PCI-1 DMA<br>PCI-1 to PB DMA |            | PB_P1_RETRY in the ISR1 register  |
|           |                                      | External PCI-2 agent<br>PB to PCI-2 DMA<br>PCI-2 to PB DMA |            | PB_P2_RETRY in the ISR1 register  |

 Table 45: PB Interface Errors

The shaded row from the PB slave section of Table 45 indicates the PB slave asserts PB\_TEA\_ and sets a bit in the ISR1 register when an external PB master attempts a register access or a PCI-1 Configuration, IO or IACK transaction with any of the following characteristics:

- not naturally aligned if Endian (END) bit in the PB\_REG\_BADDR register is programmed for PowerPC little-endian mode
- Transfer Size, PB\_TSIZ, indicates a transfer greater than 4 bytes

When a PowerSpan II PCI master is performing a read and encounters a Target-Abort, or generates a Master-Abort, an error indication is latched. When the Address Retry Enable (ARTRY\_EN) bit, in the "Processor Bus Miscellaneous Control and Status Register" on page 361, is set to 0 the error is immediately signaled by the PB slave and the transaction terminates. If ARTRY\_EN is set to 1, the PB slave propagates this error to the initiating the processor bus agent when it returns to retrieve the read data it requested.

The assertion of the PB\_TEA\_ signal is controlled with assertion the Transfer Error Acknowledge Enable (TEA\_EN) bit in the PB\_MISC\_CSR register. If TEA\_EN is set, the PB slave reports error scenarios as defined in Table 45. If TEA\_EN is cleared, transactions determined to be in error are not forwarded to the intended interface or registers. The appropriate ISR1 status bits are set.

The PB slave propagation of PCI Master-Abort for Configuration commands is controlled with the Master-Abort Configuration Error Mapping (MAC\_TEA) bit in the PB\_MISC\_CSR register. When MAC\_TEA is set, the PB slave returns all ones on a PCI Configuration read which terminates with Master-Abort. If MAC\_TEA is cleared, the PB slave asserts PB\_TEA\_.

The shaded row from the PB master section of Table 45 indicates that the PB master sets a bit in the ISR1 register if its transaction is terminated with PB\_TEA\_. The sources for such a transaction are:

- external PCI-1 agent read or write
- DMA channel moving data to/from PCI-1

A typical interrupt service routine for a PB Interface error — as illustrated for in Table 45 — executes the following steps:

- 1. Read ISR1 to determine which interface reported the error.
- 2. Read error logs PB\_ERRCS and PB\_AERR to obtain diagnostic information if the PB Interface reported the error.
- 3. Clear the Error Status (ES) bit in the PB\_ERRCS to enable future error logging.
- 4. Clear the status bit in ISR1—this negates external interrupt pin.
- 5. Fix the configuration issue that caused the error.
- 6. Retry the transaction that caused the error.

The flow of transactions through the PowerSpan II interfaces is independent of error status bits in ISR1 and Error Status bit in the "Processor Bus Error Control and Status Register" on page 359. If PowerSpan II detects an error while processing a transaction, subsequent transactions are not affected.

The transaction response for a PB slave error is as follows:

- address parity: do not claim the transaction
- data parity: transaction proceeds normally to its destination
- illegal access (see Table 45)

The transaction response for a PB master error is as follows:

• data parity on reads:

transaction proceeds normally back to the source

correct data parity is calculated internally and propagated back to the source

• assertion of PB\_TEA\_, expiration of max retry counter:

all writes

- stop the transaction
- purge the entire source transaction from the Switching Fabric
- for DMA writes, error status sent to DMA channel registers

all reads

- stop the transaction
- latch error condition for propagation back to source

### 8.3 PCI Interface Errors

In the following discussion Px refers to the PCI Interface that detected the error and Py refers to the alternate PCI Interface.

The Px master and target detect error conditions while participating in PCI bus transactions. In addition to the "Interrupt Status Register 1" on page 390 (ISR1), the Px Interface provides the following reporting mechanisms:

• External signaling of the following signals:

Target-Abort

Master-Abort

address parity errors

data parity errors

Detection of Target-Abort.

- Standard PCI error reporting in "PCI 1 Control and Status Register" on page 301 (Px\_CSR).
- Capture of specific parameters from the transaction that caused the error:

Error Control and Status register Px\_ERRCS, which logs PCI command

Address Error Log register Px\_AERR, which logs PCI Address (Px\_AD)

Table 46 itemizes the error cases detected and reported by the Px master and the Px target. Error logging in Px\_ERRCS and Px\_AERR is triggered for each of these error cases

 Table 46: PCI Interface Errors

| Interface    | Error                                                 | Destination/<br>Source | Conditions  | Reporting                                                                                                                                                                         |
|--------------|-------------------------------------------------------|------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>target | Address<br>parity                                     | PB, Registers, Py      | Write, Read | Px_SERR if<br>PERESP=1 and<br>SERR_EN=1,<br>S_SERR in the Px_CSR<br>register if<br>PERESP=1 and<br>SERR_EN=1,<br>D_PE in the Px_CSR register,<br>Px_A_PAR in the ISR1<br>register |
|              | Data parity                                           | PB, Registers          | Write       | Px_PERR if<br>PERESP=1,<br>D_PE in the Px_CSR register,<br>Px_PB_ERR in the ISR1<br>register                                                                                      |
|              |                                                       | Ру                     | Write       | Px_PERR if<br>PERESP=1,<br>D_PE in the Px_CSR register,<br>Px_Py_ERR in the ISR1<br>register                                                                                      |
|              | Propagation<br>of error from<br>destination<br>master | РВ                     | Read        | Target-Abort,<br>S_TA in the Px_CSR register,<br>Px_PB_ERR in the ISR1<br>register                                                                                                |
|              |                                                       | Ру                     | Read        | Target-Abort,<br>S_TA in the Px_CSR register,<br>Px_Py_ERR in the ISR1<br>register                                                                                                |

Table 46: PCI Interface Errors

| Interface    | Error                          | Destination/<br>Source                            | Conditions | Reporting                                                                                                                                       |
|--------------|--------------------------------|---------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>master | . ,                            | External PB agent<br>Px to PB DMA                 | Read       | Px_PERR if<br>PERESP=1,<br>MDP_D in the Px_CSR<br>register if<br>Px_PERR,<br>D_PE in the Px_CSR register,<br>Px_PB_ERR in the ISR1<br>register  |
|              |                                | External Py agent<br>Px to Py DMA                 | Read       | Px_PERR if<br>PERESP=1,<br>Px_CSR[MDP_D] if<br>Px_PERR_,<br>D_PE in the Px_CSR register,<br>Px_Py_ERR in the ISR1<br>register                   |
|              |                                | DMA Px Linked-List<br>Px to Px DMA                | Read/Write | Px_PERR if<br>PERESP=1,<br>MDP_D in the Px_CSR<br>register if<br>Px_PERR_,<br>D_PE in the Px_CSR register,<br>Px_Px_ERR in the ISR1<br>register |
|              | External<br>agent<br>generates | External PB agent<br>Px to PB DMA<br>PB to Px DMA | Read/Write | R_TA in the Px_CSR register,<br>Px_PB_ERR in the ISR1<br>register                                                                               |
|              | Target-Abort                   | External Py agent<br>Px to Py DMA<br>Py to Px DMA | Read/Write | R_TA in the Px_CSR register,<br>Px_Py_ERR in the ISR1<br>register                                                                               |
|              |                                | DMA Px Linked-List<br>Px to Px DMA                |            | R_TA in the Px_CSR register,<br>Px_Px_ERR in the ISR1<br>register                                                                               |

| Interface    | Error                                  | Destination/<br>Source                            | Conditions | Reporting                                                            |
|--------------|----------------------------------------|---------------------------------------------------|------------|----------------------------------------------------------------------|
| Px<br>master | Px master<br>generates<br>Master-Abort | External PB agent<br>Px to PB DMA<br>PB to Px DMA | Read/Write | R_MA in the Px_CSR<br>register,<br>Px_PB_ERR in the ISR1<br>register |
|              |                                        | External Py agent<br>Px to Py DMA<br>Py to Px DMA |            | R_MA in the Px_CSR<br>register,<br>Px_Py_ERR in the ISR1<br>register |
|              |                                        | DMA Px Linked-List<br>Px to Px DMA                |            | R_MA in the Px_CSR<br>register,<br>Px_Px_ERR in the ISR1<br>register |
| Px<br>master | Max retry<br>expires                   | External PB agent<br>Px to PB DMA<br>PB to Px DMA |            | Px_PB_RETRY in the ISR1 register                                     |
|              |                                        | External Py agent<br>Px to Py DMA<br>Py to Px DMA |            | Px_Py_RETRY in the ISR1 register                                     |
|              |                                        | DMA Px Linked-List<br>Px to Px DMA                |            | Px_Px_RETRY in the ISR1 register                                     |

#### Table 46: PCI Interface Errors

When the PB master or Py master are performing a read and encounter an error condition, an error indication is latched. The Px target propagates this error to the initiating Px external master when it comes back to acquire the read data it requested. This scenario is indicated by the shaded row in the Px target section of Table 46. The Px target signals a Target-Abort on the bus and sets the Px Processor Bus Error (Px\_PB\_ERR) bit in the ISR1 and Signaled Target-Abort (S\_TA) bit in the Px\_CSR. In this case the PowerSpan II PB Master or Py master and the Px target reports the error.

The shaded row from the Px master section of Table 46 indicates that the Px master sets the Px\_PB\_ERR bit in the ISR1 register and the R\_TA bit in the Px\_CSR register if its transaction terminates with a Target-Abort. The sources for such a transaction are:

- an external PB agent read or write
- a DMA channel moving data to/from PB

The MDP\_D bit in the Px\_CSR register is also set for data parity errors detected by an external target during write transactions. This condition was not included in the Px master section of Table 46 because the master does not detect the error.

The assertion of Px\_PERR# is controlled with the Parity Error Response (PERESP) bit in the Px\_CSR. The assertion of Px\_SERR# is controlled with the PERESP bit and SERR# Enable (SERR\_EN) bit in the Px\_CSR.

The user controls the Px target propagation of PCI Master-Abort Configuration command initiated on Py with MAC\_ERR. When the Master-Abort Configuration Error Mapping (MAC\_ERR) bit is set in the Px\_MISC\_CSR, the Px target returns all ones on a Py Configuration read that terminates with Master-Abort. When the MAC\_ERR bit is cleared, the Px target responds with Target-Abort.

A typical interrupt service routine for a PB Interface error — as illustrated for in Table 46 — executes the following steps:

- 1. Read ISR1 to determine which interface reported the error.
- 2. If the PCI-1 Interface reported the error:
  - Read error logs Px\_ERRCS and Px\_AERR to obtain diagnostic information.
  - Read Px\_CSR to distinguish address parity, data parity, Target-Abort, Master-Abort scenarios.
- 3. Clear Px\_ERRCS[ES] to enable future error logging.
- 4. Clear the status bit in ISR1.

Negates external interrupt pin.

- 5. Clear the error bits in Px\_CSR.
- 6. Fix the configuration issue that caused the error.
- 7. Retry the transaction that caused the error.

The flow of transactions through PowerSpan II is independent of error status bits in ISR1, error status bits in P1\_CSR and the error log status bit P1\_ERRCS[ES].

The transaction response for a Px target error is:

- address parity: claim and complete as normal
- data parity: transaction proceeds normally to its destination

The transaction response for a Px master error is:

• data parity on reads

transaction proceeds normally to its source

correct data parity is calculated internally and propagated back to the source

• detection of Target-Abort, generation of Master-Abort, expiration of max retry counter:

all writes:

- stop the transaction
- purge the entire source transaction from the Switching Fabric
- for DMA writes, error status sent to DMA channel registers

all reads:

- stop the transaction
- latch error condition for propagation back to source

### 8.4 DMA Errors

A PowerSpan II DMA channel requires a PowerSpan II master to service source activity and a second PowerSpan II master to service destination activity. These masters provide error detection and reporting services as described in the previous sections. The DMA channel provides the following additional status bits to indicate an error condition on an interface currently in use:

- Processor Bus Error (PB\_ERR) bit in the "DMA x General Control and Status Register" on page 372 (DMAx\_GCSR)
- PCI-1 Bus Error (P1\_ERR) in the DMAx\_GCSR register
- PCI-2 Bus Error (P2\_ERR) in the DMAx\_GCSR register

These status bits can be used to cause the assertion of a PowerSpan II interrupt pin according to "Interrupt Handling" on page 173.

Assume that an error occurred at the PCI-1 master using DMA-2. A typical interrupt service routine executes the following steps:

- 1. ISR1 read to determine which interface reported the error.
- 2. If PCI-1 reports the error:
  - error logs P1\_ERRCS and P1\_AERR read to obtain diagnostic information.
  - P1\_CSR read to distinguish address parity, data parity, target abort, master abort scenarios.
- 3. ISR0 read to determine if a DMA2 status bit is set.
- 4. DMA2\_GCSR read to determine which condition caused the channel to interrupt.
- 5. The ES bit is cleared in the P1\_ERRCS register to enable future error logging.
- 6. The status bit in ISR is cleared this negates external interrupt pin.
- 7. The status bit in P1\_CSR is cleared.
- 8. Configuration issue that caused the error is corrected.
- 9. P1\_ERR bit in the DMA2\_GCSR is cleared to allow DMA channel two to restart.
- 10. DMA channel two is restarted.



# 9. Resets, Clocks and Power-up Options

This chapter describes the resets, clocks and power-up options implemented by PowerSpan II. The following topics are discussed:

- "Reset" on page 201
- "Clocks" on page 205
- "Power-Up Options" on page 205
- "MPC8260 Configuration Slave Mode" on page 209

### 9.1 Reset

PowerSpan II provides reset capabilities for Host, Adapter and Hot Swap applications. Host and Adapter situations are described in "Typical Applications" on page 481, while Hot Swap information is in "PCI Interface" on page 43.

### 9.1.1 Reset Pins

PowerSpan II reset pins are listed in Table 47..

#### Table 47: PowerSpan II Reset Pins

| Pin Name | Direction                | Description              |
|----------|--------------------------|--------------------------|
| PO_RST_  | Input                    | Power-On Reset           |
| HEALTHY_ | Input                    | Board Status             |
| PB_RST_  | Bidirectional Open Drain | Processor Bus Hard Reset |

P2\_RST#

TRST

| -        |               |                 |  |
|----------|---------------|-----------------|--|
| Pin Name | Direction     | Description     |  |
| P1_RST#  | Bidirectional | PCI-1 Bus Reset |  |

Bidirectional

Input

Table 47: PowerSpan II Reset Pins

All pins indicate a reset condition when driven low, except for HEALTHY# signal.

PCI-2 Bus Reset

JTAG Reset

#### 9.1.1.1 Reset Direction Control Pins

Each bidirectional reset pin has a dedicated direction control pin. The assertion of a reset pin configured as input propagates to all reset pins configured as output.

The relationship between the reset and direction control pins is defined in Table 48.

| Control Pin | Associated Reset<br>Pin | Description                                 |
|-------------|-------------------------|---------------------------------------------|
| PB_RST_DIR  | PB_RST                  | Direction of PB_RST_<br>0=Input<br>1=Output |
| P1_RST_DIR  | P1_RST                  | Direction of P1_RST#<br>0=Input<br>1=Output |
| P2_RST_DIR  | P2_RST                  | Direction of P2_RST#<br>0=Input<br>1=Output |

Table 48: Reset Direction Control Pins

The dedicated direction control pins must either be pulled up or down at all times. At least one of the bidirectional reset pins must be configured as an input.

#### 9.1.1.2 Reset Response

The assertion of an external reset pin elicits a specific response from PowerSpan II. Table 49 defines how various PowerSpan II resources are affected by active reset pins.

| PowerSpan II Resource |      |                    |                    |                 | rce                                             |                          |
|-----------------------|------|--------------------|--------------------|-----------------|-------------------------------------------------|--------------------------|
| Reset Pin             | PLLs | PCI-1<br>Registers | PCI-2<br>Registers | PB<br>Registers | PowerSpan II<br>Device<br>Specific<br>Registers | Finite State<br>Machines |
| PO_RST_=0             | Yes  | Yes                | Yes                | Yes             | Yes                                             | Yes                      |
| HEALTHY# = 1          | Yes  | Yes                | Yes                | Yes             | Yes                                             | Yes                      |
| PB_RST_ = 0           | No   | No                 | No                 | Yes             | Yes                                             | Yes                      |
| P1_RST# = 0           | No   | Yes                | No                 | No              | Yes                                             | Yes                      |
| P2_RST# = 0           | No   | No                 | Yes                | No              | Yes                                             | Yes                      |

Table 49: PowerSpan II Reset Response

PowerSpan II's response to the assertion of a bidirectional reset pin is independent of the direction of that pin.

PowerSpan II's PB\_RST\_, P1\_RST# and P2\_RST# are considered bidirectional. When they are configured as outputs, they still sense logic lows on the PowerSpan II reset signal. If these signals sense the logic low on their particular reset signal, the signal stays asserted and PowerSpan II is in a reset state. For example, if PB\_RST\_ is asserted low PowerSpan II enters a reset state.

PowerSpan II's response to the assertion of each pin is asynchronous — it does not require the presence of a clock. PowerSpan II synchronizes the negation of reset. The de-assertion edge of all input signals is required to be monotonic (bounce free) through the input switching range.

The Phase Locked Loops (PLLs) in PowerSpan II are reset by the assertion of PO\_RST\_ or negation of HEALTHY#. The assertion of PO\_RST\_ or negation of HEALTHY# causes all other PowerSpan II resources to be reset. These resources are not released from reset until all PLLs are locked.



Applications that use both HEALTHY# and PO\_RST\_ must assert HEALTHY# before negating PO\_RST\_.

The HEALTHY# pin affects the tristate enable control of PowerSpan II outputs, as well as the inhibit control of PowerSpan II input buffers. See "CompactPCI Hot Swap Silicon Support" on page 67 for more details on the use of HEALTHY#.

The assertion of TRST\_ resets the JTAG controller and configures the Boundary Scan Register for normal system operation.



Customers must assert TRST\_ concurrently with PO\_RST\_ as part of the power-up reset sequence.

#### 9.1.1.3 Reset Generation

Each of PowerSpan II's three interfaces have bidirectional reset pins that are used to reset the hardware on the associated bus.

PowerSpan II assertion of PB\_RST\_ occurs if PB\_RST\_DIR is pulled high and one of the following occurs:

- PO\_RST\_ asserted
- P1\_RST\_DIR is pulled low and P1\_RST# is asserted
- P2\_RST\_DIR is pulled low and P2\_RST# is asserted

PowerSpan II assertion of P1\_RST# occurs if P1\_RST\_DIR is pulled high and on of the following occurs:

- PO\_RST\_ asserted
- PB\_RST\_DIR is pulled low and PB\_RST# is asserted
- P2\_RST\_DIR is pulled low and P2\_RST# is asserted

PowerSpan II assertion of P2\_RST\_ occurs if P2\_RST\_DIR is pulled high and on of the following occurs:

- PO\_RST\_ asserted
- PB\_RST\_DIR is pulled low and PB\_RST# is asserted
- P1\_RST\_DIR is pulled low and P1\_RST# is asserted

The negation of HEALTHY# tristates all PowerSpan II output pins, including the reset outputs. PowerSpan II reset outputs do not respond immediately to the negation of PO\_RST\_ because they are negated once all PLLs are locked.

## 9.2 Clocks

Each of the PowerSpan II external ports has a clock input pin. The pins are:

- PB\_CLK
- P1\_CLK
- P2\_CLK

The clock input for each port enables PowerSpan II's master/target state machines to be synchronized to the external bus. Each interface has a dedicated PLL designed to eliminate clock tree insertion delay. PowerSpan II requires the input clock to be at the specified frequency before the PLL is removed from reset. PowerSpan II PLLs are reset during the assertion of PO\_RST\_ or the negation of HEALTHY#. The PLLs are not locked until after the negation of PO\_RST\_ or HEALTHY#.

Each PLL has a dedicated configuration pin to indicate the desired operating frequency range. The following configuration pins are used by the PLL:

- PB\_FAST
- P1\_M66EN
- P2\_M66EN

The input clocks are not required to maintain specific phase relationships. However, there is a limitation on the range of input clock periods. The ratio of the maximum period to minimum period, for all three clock inputs, must be less than four. For example, if the period of PB\_CLK is 10 ns, the periods of P1\_CLK and P2\_CLK must be less than, but not equal to, 40 ns.

PowerSpan II has power-up options for bypassing all three PLLs and observing the locking status of each PLL in system operation. Refer to "Power-Up Options" on page 205 for more information on power-up options.

## 9.3 Power-Up Options

To ensure proper operation, a number of PowerSpan II features must be configured by completion of the power-up reset sequence. PowerSpan II has the following modes to configure these power-up options:

- Multiplexed System Pins mode
- MPC8260 Configuration Slave mode

The Multiplexed System Pins mode multiplexes a system pin during the power-up reset sequence to configure each of the power-up options.

In the MPC8260 Configuration Slave mode, the power-up options are latched from PB\_D with PB\_RSTCONF\_.

The PB\_RSTCONF\_ signal determines the configuration mode used by PowerSpan II. If PB\_RSTCONF\_ is asserted low, then the MPC8260 Configuration Slave mode is used to configure PowerSpan II. At all other times the Multiplexed System Pins mode is used by PowerSpan II. The Multiplexed System Pins mode determines the value of the power-up options.

Power-up option status can be confirmed by reading the Reset Control and Status (RST\_CSR) register (see "MPC8260 Configuration Slave Mode" on page 209 for more information).



Power-up options are not affected by reset events on the PB\_RST\_, P1\_RST# or P2\_RST# pins.

Table 50 lists PowerSpan II power-up options and directions for their configuration with PowerSpan II system pins and the processor data bus in configuration slave mode.

Table 50: PowerSpan II Power-up Options

| Power-up Option      | Selection                | System Pin <sup>a</sup> | PB_D Pin <sup>b</sup> | RST_CSR Register |
|----------------------|--------------------------|-------------------------|-----------------------|------------------|
| PB Arbiter Enable    | Enable PB Arbiter        | PB_FAST=1               | PB_D[0]=1             | PB_ARB_EN=1      |
| (PWRUP_PB_ARB_EN)    | Disable PB Arbiter       | PB_FAST=0               | PB_D[0]=0             | PB_ARB_EN=0      |
| PCI-1 Arbiter Enable | Enable<br>PCI-1 Arbiter  | P1_M66EN=1              | PB_D[1]=1             | P1_ARB_EN=1      |
| (PWRUP_P1_ARB_EN)    | Disable<br>PCI-1 Arbiter | P1_M66EN=0              | PB_D[1]=0             | P1_ARB_EN=0      |
| PCI-2 Arbiter Enable | Enable<br>PCI-2 Arbiter  | P2_M66EN=1              | PB_D[2]=1             | P2_ARB_EN=1      |
| (PWRUP_P2_ARB_EN)    | Disable<br>PCI-2 Arbiter | P2_M66EN=0              | PB_D[2]=0             | P2_ARB_EN=0      |
| Primary PCI Select   | PCI-1 is Primary         | INT[5]_=1               | PB_D[3]=0             | PRI_PCI=0        |
| (PWRUP_PRI_PCI)      | PCI-2 is Primary         | INT[5]_=0               | PB_D[3]=1             | PRI_PCI=1        |
| PCI-1 REQ64 Enable   | Disable<br>P1_REQ64_     | INT[4]_=1               | PB_D[4]=0             | P1_R64_EN=0      |
| (PWRUP_P1_R64_EN)    | Enable<br>P1_REQ64_      | INT[4]_=0               | PB_D[4]=1             | P1_R64_EN=1      |
| Boot select          | PB Boot                  | INT[3]_=1               | PB_D[5]=0             | PCI_BOOT=0       |
| (PWRUP_BOOT)         | PCI Boot                 | INT[3]_=0               | PB_D[5]=1             | PCI_BOOT=1       |
| 7400 Mode Enable     | Disable<br>7400_Mode     | INT[2]_=1               | PB_D[6]=0             | 7400_MODE=0      |
| (PWRUP_7400_MODE)    | Enable<br>7400_Mode      | INT[2]_=0               | PB_D[6]=1             | 7400_MODE=1      |
| PLL Bypass Enable    | Disable PLL<br>Bypass    | INT[1]_=1               | PB_D[7]=0             | BYPASS_EN=0      |
| (PWRUP_BYPASS_EN)    | Enable PLL<br>Bypass     | INT[1]_=0               | PB_D[7]=1             | BYPASS_EN=1      |

- a. The information in the System Pin column is used when PowerSpan II is in Multiplexed System Pin mode (see page 208)
- b. The information in the PB\_D Pin column is used when PowerSpan II is in MPC8260 Configuration Slave mode (page 209).

The options PWRUP\_PB\_ARB\_EN, PWRUP\_P1\_ARB\_EN, and PWRUP\_P2\_ARB\_EN are used to select between an external arbiter or a PowerSpan II arbiter for each interface.

PWRUP\_PRI\_PCI designates PCI-1 or PCI-2 as being connected to the Primary PCI Interface segment in the system (see "Primary PCI" on page 44 for more details on Primary PCI Interface functionality).

When PWRUP\_P1\_R64\_EN is enabled, the PowerSpan II PCI-1 Interface pulses P1\_REQ64# during assertion of P1\_RST# to signal the presence of a 64-bit data path to all agents on the bus segment. PowerSpan II must be the Central Resource in the system and control both P1\_REQ64# and P1\_RST#. By meeting these requirements, PowerSpan II ensures that the timing parameters a for a 64-bit data width are satisfied.

The option PWRUP\_BOOT enables the system designer to control boot from PCI or from the processor bus. Refer to "Arbitration" on page 163 for more information

By enabling option PWRUP\_BYPASS\_EN, all PLLs in the design are bypassed.

In the Single PCI PowerSpan II, the following power-up options are not configurable:

- PWRUP\_P2\_ARB\_EN
  - PCI-2 arbiter is always disabled
- PWRUP\_PRI\_PCI
  - PCI-1 is always the Primary Interface

### 9.3.1 Multiplexed System Pin Mode

PowerSpan II multiplexes a number of system pins to provide power-up support (see Table 50). The multiplexed pins are used to communicate system or power-up information. The multiplexed system pins mode is the default mode for PowerSpan II power-up options.

During the assertion of PO\_RST\_, the following pins are in system mode:

• PB\_FAST

- P1\_M66EN
- P2\_M66EN

During the assertion of PO\_RST\_, the following pin is in power-up option mode:

• INT[5:1]\_



When PO\_RST\_ is asserted, the PLL frequency is selected.

The required system levels are latched by PowerSpan II at the negation of PO\_RST\_ (see Figure 22). The level on these pins determines the power-up options settings. The system levels are typically provided by external transceiver or FPGA.

System operation of these pins requires external pull-ups. Default values for powerup options loaded by INT[5:1]\_ are highlighted in Table 50 and are selected to require a minimum number of transceivers in most applications.



#### Figure 22: PowerSpan II Power-up Waveform

### 9.3.2 MPC8260 Configuration Slave Mode

When there is a configuration master in a PowerSpan II system, for example the MPC8260, the MPC8260 Configuration Slave mode overrides the default power-up option — the Multiplexed System Pins mode. The MPC8260's slave mode power-up options overwrite the multiplex system pin mode power-up options that were sampled at PO\_RST\_ (see Figure 22).

MPC8260 systems provide support for a single configuration master and up to seven configuration slaves. During the assertion of HRESET\_, the configuration master MPC8260 reads configuration words from memory and writes them to the configuration slaves. A total of seven 64-bit words are transferred over the data bus. One of A[0:6] lines is strobed to transfer each word.



When PowerSpan II is the configuration slave and the MP8260 is the configuration master, the MP8260 drives the HRESET\_ signal.

PowerSpan II acts as a configuration slave under the following conditions:

- PB\_RSTCONF\_ is connected to one of the MPC8260 A[0:6] lines
- PB\_RST\_ is connected to the MPC8260 HRESET\_ signal
- PB\_D is connected to the MPC8260 Data (D) line

When the MPC8260 Configuration Slave mode is enabled, the multiplexed pins are sampled first then the configuration word overrides the original setting. In this case, the power-up options are configured by PB\_D as defined in Table 50.

PowerSpan II configuration slave timing is illustrated in Figure 23.

#### Figure 23: PowerSpan II Configuration Slave Timing



The MPC8260 configuration master updates all configuration slaves for each HRESET\_ sequence. PowerSpan II receives the same configuration word after each sequence.

### 9.3.3 Assertion of P1\_REQ64#

When the PWRUP\_P1\_REQ64\_EN bit is set to 1, in the RST\_CSR register (see page 385), PowerSpan II does not assert P1\_REQ64# signal until the configuration word is latched. A 10 clock setup time for the P1\_REQ64# signal is required by the *PCI 2.2 Specification*. In order to meet this requirement, PowerSpan II must not be the last four MPC8260 slaves. PowerSpan II must be the Central Resource in the system and control both P1\_REQ64# and P1\_RST#. By meeting these requirements, PowerSpan II ensures that the timing parameters for a 64-bit data width are satisfied.



# **10. Endian Mapping**

Big-endian refers to a method of formatting data where address 0 (or the smallest address referencing to the data) points to the most significant byte of the data.

Little-endian refers to a method of formatting data where address 0 (or the smallest address referencing the data) points to the least significant byte of the data.

Data in a system must be consistent; that is, the system must be entirely big-endian or little-endian.

This chapter describes the endian mapping system used in PowerSpan II. The following topics are discussed:

- "Conventions" on page 214
- "Processor Bus and PowerSpan II Register Transfers" on page 215
- "Processor Bus and PCI Transfers" on page 219

### 10.1 Overview

PowerSpan II supports a flexible endian conversion scheme for the following transactions involving the Processor Bus (PB) Interface:

- Access of PowerSpan II registers from the PB Interface
- Transfers between the processor bus and PCI both externally initiated and PowerSpan II DMA initiated



No endian conversion is performed for transactions mapped between the two PCI interfaces: PCI-1 and PCI-2.

## 10.2 Conventions

Table 51 illustrates the data bus lanes used to carry each byte of a multi-bytestructure on PCI. PCI stores multi-byte structures with little-endian byte ordering.

| Byte Address | PCI Byte Lanes     |                |                    |             |              |
|--------------|--------------------|----------------|--------------------|-------------|--------------|
| AD[2:0]      | 64-bit Transaction |                | 32-bit Transaction |             |              |
|              | Lane Number Pins   |                | AD[2]              | Lane Number | Pins         |
| 000          | 0                  | P1_AD[7:0]     | 0                  | 0           | Px_AD[7:0]   |
| 001          | 1                  | P1_AD[15:8]    | 0                  | 1           | Px_AD[15:8]  |
| 010          | 2                  | P1_AD[23:16]   | 0                  | 2           | Px_AD[23:16] |
| 011          | 3                  | P1_AD[31:24]   | 0                  | 3           | Px_AD[31:24] |
| 100          | 4                  | P1_AD[39:32]   | 1                  | 0           | Px_AD[7:0]   |
| 101          | 5                  | P1_AD[47:40]   | 1                  | 1           | Px_AD[15:8]  |
| 110          | 6                  | P1_AD[55:48]   | 1                  | 2           | Px_AD[23:16] |
| 111          | 7                  | 7 P1_AD[63:56] |                    | 3           | Px_AD[31:24] |

Table 51: PCI Byte Lane Definitions

Table 52 illustrates the lanes used to carry each byte of a multi-byte structure on a64-bit PB Interface data bus.

Table 52: 64-bit PB Data Bus Byte Lane Definitions

| Byte Address | Processor Bus Byte Lanes |                      |              |             |  |
|--------------|--------------------------|----------------------|--------------|-------------|--|
| PB_A[29:31]  | Lane Number              | PowerSpan II<br>Pins | MPC8260 Pins | MPC740 Pins |  |
| 000          | 0                        | PB_D[0:7]            | D[0:7]       | DH[0:7]     |  |
| 001          | 1                        | PB_D[8:15]           | D[8:15]      | DH[8:15]    |  |
| 010          | 2                        | PB_D[16:23]          | D[16:23]     | DH[16:23]   |  |
| 011          | 3                        | PB_D[24:31]          | D[24:31]     | DH[24:31]   |  |
| 100          | 4                        | PB_D[32:39]          | D[32:39]     | DL[0:7]     |  |

| Byte Address | Processor Bus Byte Lanes |             |          |           |  |
|--------------|--------------------------|-------------|----------|-----------|--|
| 101          | 5                        | PB_D[40:47] | D[40:47] | DL[8:15]  |  |
| 110          | 6                        | PB_D[48:55] | D[48:55] | DL[16:23] |  |
| 111          | 7                        | PB_D[56:63] | D[56:63] | DL[24:31] |  |

Table 52: 64-bit PB Data Bus Byte Lane Definitions

PowerSpan II supports both big-endian and PowerPC little-endian byte ordering. Endian selection with PowerPC is performed with the processor register MSR[LE] and defaults to big-endian. PowerPC little-endian mode allows a PowerPC and Pentium processor to share a data structure in memory.

## 10.3 Processor Bus and PowerSpan II Register Transfers

The PowerSpan II PB Slave supports register accesses from a PowerPC operating in big-endian or PowerPC little-endian mode. The endian conversion mode for processor access to PowerSpan II registers is selected by programming the END bit in the "Processor Bus Register Image Base Address Register" on page 351. The default mode is big-endian, which matches the default mode of the processor bus.

PowerSpan II registers are little-endian structures. The endian conversion process provided by PowerSpan II for processor bus accesses to its registers is designed to preserve the significance of the programmer's multi-byte structures or scalars. Endian conversion for access to PowerSpan II registers from the processor is data invariant.

When the processor bus is operating in big-endian mode, the END bit must be set to big-endian mode. In this case, the PowerSpan II PB slave maps the processor bus byte lanes to PowerSpan II register addresses according to Table 53.

|                  | Starting        |    |    |       |      |        |      |    |    | Ро   |    | an II F<br>ddres: | Registe<br>s | )r |
|------------------|-----------------|----|----|-------|------|--------|------|----|----|------|----|-------------------|--------------|----|
| Tronofor         | Address         |    | F  | Power | РС В | yte La | anes |    |    |      |    | A[                | 1:0]         |    |
| Transfer<br>Size | PB_A<br>[29:31] | 0  | 1  | 2     | 3    | 4      | 5    | 6  | 7  | A[2] | 11 | 10                | 01           | 00 |
| Byte             | 000             | D0 |    |       |      |        |      |    |    | 0    | D0 |                   |              |    |
|                  | 001             |    | D1 |       |      |        |      |    |    | 0    |    | D1                |              |    |
|                  | 010             |    |    | D2    |      |        |      |    |    | 0    |    |                   | D2           |    |
|                  | 011             |    |    |       | D3   |        |      |    |    | 0    |    |                   |              | D3 |
|                  | 100             |    |    |       |      | D4     |      |    |    | 1    | D4 |                   |              |    |
|                  | 101             |    |    |       |      |        | D5   |    |    | 1    |    | D5                |              |    |
|                  | 110             |    |    |       |      |        |      | D6 |    | 1    |    |                   | D6           |    |
|                  | 111             |    |    |       |      |        |      |    | D7 | 1    |    |                   |              | D7 |
| Two              | 000             | D0 | D1 |       |      |        |      |    |    | 0    | D0 | D1                |              |    |
| bytes            | 001             |    | D1 | D2    |      |        |      |    |    | 0    |    | D1                | D2           |    |
|                  | 010             |    |    | D2    | D3   |        |      |    |    | 0    |    |                   | D2           | D3 |
|                  | 100             |    |    |       |      | D4     | D5   |    |    | 1    | D4 | D5                |              |    |
|                  | 101             |    |    |       |      |        | D5   | D6 |    | 1    |    | D5                | D6           |    |
|                  | 110             |    |    |       |      |        |      | D6 | D7 | 1    |    |                   | D6           | D7 |
| Tri-             | 000             | D0 | D1 | D2    |      |        |      |    |    | 0    | D0 | D1                | D2           |    |
| byte             | 001             |    | D1 | D2    | D3   |        |      |    |    | 0    |    | D1                | D2           | D3 |
|                  | 100             |    |    |       |      | D4     | D5   | D6 |    | 1    | D4 | D5                | D6           |    |
|                  | 101             |    |    |       |      |        | D5   | D6 | D7 | 1    |    | D5                | D6           | D7 |
| Word             | 000             | D0 | D1 | D2    | D3   |        |      |    |    | 0    | D0 | D1                | D2           | D3 |
|                  | 100             |    |    |       |      | D4     | D5   | D6 | D7 | 1    | D4 | D5                | D6           | D7 |

#### Table 53: PowerSpan II Big-Endian PB Register Accesses

In PowerPC little-endian mode, the processor munges the address and places the scalar on the external byte lanes starting at this modified address. The scalar is still in big-endian order. This operation is only defined for starting addresses that are a multiple of the size of the scalar. In PowerPC literature, this is referred to as being naturally aligned.



Munging the address makes the address appear to the processor bus that individual aligned scalars are stored as little-endian values when they are actually stored in big-endian order. They are stored at different byte addresses with a double word.

The munging performed by the processor is illustrated in Table 54.

| Transfer Size | Address modification |
|---------------|----------------------|
| 4 bytes       | XOR with 0b100       |
| 2 bytes       | XOR with 0b110       |
| 1 byte        | XOR with 0b111       |

Table 54: Processor Bus Address Munging

When the processor bus is operating in PowerPC little-endian mode, END bit must be set to PowerPC little-endian mode. In this case, the PB Slave munges the processor bus address, and maps byte lanes to register addresses to preserve the significance of the scalar. The byte lane to register address mapping is shown in Table 55. Only munged cases are illustrated. The PB slave asserts PB\_TEA\_ in response to an unaligned access to a register if the END bit is set for PowerPC little-endian mode.

|                  | Starting<br>Address |    |    |      |      |        |       |    |    | Power | Span II | Regis | ster Ad | dress |
|------------------|---------------------|----|----|------|------|--------|-------|----|----|-------|---------|-------|---------|-------|
|                  | (Munged)            |    |    | Powe | erPC | Byte I | Lanes | 5  |    |       |         | A[    | 1:0]    |       |
| Transfer<br>Size | PB_A<br>[29:31]     | 0  | 1  | 2    | 3    | 4      | 5     | 6  | 7  | A[2]  | 11      | 10    | 01      | 00    |
| Byte             | 000                 | D0 |    |      |      |        |       |    |    | 1     |         |       |         | D0    |
|                  | 001                 |    | D1 |      |      |        |       |    |    | 1     |         |       | D1      |       |
|                  | 010                 |    |    | D2   |      |        |       |    |    | 1     |         | D2    |         |       |
|                  | 011                 |    |    |      | D3   |        |       |    |    | 1     | D3      |       |         |       |
|                  | 100                 |    |    |      |      | D4     |       |    |    | 0     |         |       |         | D4    |
|                  | 101                 |    |    |      |      |        | D5    |    |    | 0     |         |       | D5      |       |
|                  | 110                 |    |    |      |      |        |       | D6 |    | 0     |         | D6    |         |       |
|                  | 111                 |    |    |      |      |        |       |    | D7 | 0     | D7      |       |         |       |
| Two bytes        | 000                 | D0 | D1 |      |      |        |       |    |    | 1     |         |       | D0      | D1    |
|                  | 010                 |    |    | D2   | D3   |        |       |    |    | 1     | D2      | D3    |         |       |
|                  | 100                 |    |    |      |      | D4     | D5    |    |    | 0     |         |       | D4      | D5    |
|                  | 110                 |    |    |      |      |        |       | D6 | D7 | 0     | D6      | D7    |         |       |
| Word             | 000                 | D0 | D1 | D2   | D3   |        |       |    |    | 1     | D0      | D1    | D2      | D3    |
|                  | 100                 |    |    |      |      | D4     | D5    | D6 | D7 | 0     | D4      | D5    | D6      | D7    |

 Table 55: PowerSpan II PowerPC Little-Endian PB Register Accesses

A PCI transaction is generated by accessing the following registers:

- Processor Bus Configuration Cycle Data register (PB\_CONF\_DATA)
- Processor Bus to PCI-1 Interrupt Acknowledge Cycle Generation register (PB\_P1\_IACK)
- Processor Bus to PCI-2 Interrupt Acknowledge Cycle Generation register (PB\_P2\_IACK)

The endian conversion scheme applied for processor bus access to these registers is controlled by the END bit, but the endian mapping scheme in this case is described in "Processor Bus and PCI Transfers" on page 219.

## 10.4 Processor Bus and PCI Transfers

The following endian conversion modes are provided for transactions involving the processor bus and a PCI Interface:

- big-endian (swap or address invariance)
- little-endian (no swap or data invariance)
- PowerPC little-endian (no swap and address munge)
- true little-endian (swap or address invariance)

The following PowerSpan II register bits are used to control the endian conversion for transactions involving the PB Interface and PCI:

- END [1:0] field in the Py\_TIx\_CTL Registers
- END [1:0] field in the PCI\_TI2O\_CTL Registers
- END [1:0] field in the PB\_SIx\_CTL Registers
- END [1:0] field in the DMAx\_TCR Registers

The endian conversion mode of a DMA channel can be updated for each direct mode transaction or for each element in a linked-list.

The following sections describe each of the endian conversion modes.

## 10.4.1 Big-endian Mode

When operating in big-endian mode, PowerSpan II uses an address invariant scheme for mapping processor bus byte lanes. In this mode, all elements of a multibyte structure or scalar appear at the same address in both PCI and processor bus spaces, but their relative significance is not preserved.

If the processor bus is programmed to be big-endian, PowerSpan II big-endian mode must be used for processor bus/PCI transactions.

PowerSpan II byte lane mappings for big-endian mode support are illustrated in Table 56. Byte lane number references are defined in Table 51 and Table 52.

| Transfer  | Start   |    | I  | Powe | rPC | Byte | Lane | s  |    |    |    | PC | CI Byt | e Lai | nes |    |    |
|-----------|---------|----|----|------|-----|------|------|----|----|----|----|----|--------|-------|-----|----|----|
| Size      | Address | 0  | 1  | 2    | 3   | 4    | 5    | 6  | 7  | 7  | 6  | 5  | 4      | 3     | 2   | 1  | 0  |
| Byte      | 000     | D0 |    |      |     |      |      |    |    |    |    |    |        |       |     |    | D0 |
|           | 001     |    | D1 |      |     |      |      |    |    |    |    |    |        |       |     | D1 |    |
|           | 010     |    |    | D2   |     |      |      |    |    |    |    |    |        |       | D2  |    |    |
|           | 011     |    |    |      | D3  |      |      |    |    |    |    |    |        | D3    |     |    |    |
|           | 100     |    |    |      |     | D4   |      |    |    |    |    |    | D4     |       |     |    |    |
|           | 101     |    |    |      |     |      | D5   |    |    |    |    | D5 |        |       |     |    |    |
|           | 110     |    |    |      |     |      |      | D6 |    |    | D6 |    |        |       |     |    |    |
|           | 111     |    |    |      |     |      |      |    | D7 | D7 |    |    |        |       |     |    |    |
| Two       | 000     | D0 | D1 |      |     |      |      |    |    |    |    |    |        |       |     | D1 | D0 |
| bytes     | 001     |    | D1 | D2   |     |      |      |    |    |    |    |    |        |       | D2  | D1 |    |
|           | 010     |    |    | D2   | D3  |      |      |    |    |    |    |    |        | D3    | D2  |    |    |
|           | 100     |    |    |      |     | D4   | D5   |    |    |    |    | D5 | D4     |       |     |    |    |
|           | 101     |    |    |      |     |      | D5   | D6 |    |    | D6 | D5 |        |       |     |    |    |
|           | 110     |    |    |      |     |      |      | D6 | D7 | D7 | D6 |    |        |       |     |    |    |
| Tri-byte  | 000     | D0 | D1 | D2   |     |      |      |    |    |    |    |    |        |       | D2  | D1 | D0 |
|           | 001     |    | D1 | D2   | D3  |      |      |    |    |    |    |    |        | D3    | D2  | D1 |    |
|           | 100     |    |    |      |     | D4   | D5   | D6 |    |    | D6 | D5 | D4     |       |     |    |    |
|           | 101     |    |    |      |     |      | D5   | D6 | D7 | D7 | D6 | D5 |        |       |     |    |    |
| Word      | 000     | D0 | D1 | D2   | D3  |      |      |    |    |    |    |    |        | D3    | D2  | D1 | D0 |
|           | 100     |    |    |      |     | D4   | D5   | D6 | D7 | D7 | D6 | D5 | D4     |       |     |    |    |
| Five      | 000     | D0 | D1 | D2   | D3  | D4   |      |    |    |    |    |    | D4     | D3    | D2  | D1 | D0 |
| bytes     | 011     |    |    |      | D3  | D4   | D5   | D6 | D7 | D7 | D6 | D5 | D4     | D3    |     |    |    |
| Six bytes | 000     | D0 | D1 | D2   | D3  | D4   | D5   |    |    |    |    | D5 | D4     | D3    | D2  | D1 | D0 |
|           | 010     |    |    | D2   | D3  | D4   | D5   | D6 | D7 | D7 | D6 | D5 | D4     | D3    | D2  |    |    |

## Table 56: PowerSpan II Big-endian Mode Byte Lane Mapping

| Transfer Start<br>Size Address | Start |    |    | Powe | rPC I | Byte | Lane | s  |    |    |    | PC | l Byt | e Lar | nes |    |    |
|--------------------------------|-------|----|----|------|-------|------|------|----|----|----|----|----|-------|-------|-----|----|----|
|                                | 0     | 1  | 2  | 3    | 4     | 5    | 6    | 7  | 7  | 6  | 5  | 4  | 3     | 2     | 1   | 0  |    |
| Seven                          | 000   | D0 | D1 | D2   | D3    | D4   | D5   | D6 |    |    | D6 | D5 | D4    | D3    | D2  | D1 | D0 |
| bytes                          | 001   |    | D1 | D2   | D3    | D4   | D5   | D6 | D7 | D7 | D6 | D5 | D4    | D3    | D2  | D1 |    |
| Double                         | 000   | D0 | D1 | D2   | D3    | D4   | D5   | D6 | D7 | D7 | D6 | D5 | D4    | D3    | D2  | D1 | D0 |

Table 56: PowerSpan II Big-endian Mode Byte Lane Mapping

### 10.4.2 Little-endian Mode

When operating in little-endian mode, PowerSpan II uses a data invariant scheme for mapping PowerPC byte lanes. Data invariance preserves the relative byte significance of a structure in both PCI and PowerPC spaces, but translates the byte addressing.

In order to access PCI device registers from the processor bus in little-endian mode, there are certain addressing rules which must be followed. In PowerSpan II when little-endian mode is selected, no address swapping takes place (refer to Table 57 on page 222). This means that the MSB on the processor bus goes to the MSB on PCI. However, the MSB on processor bus is the low address and MSB on PCI is the high address.

#### 10.4.2.1 4 Byte Transactions

When performing 4 byte transactions to the PCI bus in little-endian mode the intended address must XOR the address with 0x4. This creates the address for PCI which is used in the transaction.

In little-endian mode for 4 byte transfers, the following changes must be made:

- change a register on PCI at offset 0x0 using address 0x4
- change a register on PCI at offset 0x4 using address 0x0
- change a register on PCI at offset 0x8 using address 0xC
- change a register on PCI at offset 0xC using address 0x8

These rules enable the transactions to reach the intended targets without manual code changes.

PowerSpan II byte lane mappings for little-endian mode support are illustrated in Table 57 on page 222.

| Transfer  | Start   |    | I  | Powe | rPC | Byte | Lane | s  |    |    |    | PC | CI Byt | e Lar | nes |    |    |
|-----------|---------|----|----|------|-----|------|------|----|----|----|----|----|--------|-------|-----|----|----|
| Size      | Address | 0  | 1  | 2    | 3   | 4    | 5    | 6  | 7  | 7  | 6  | 5  | 4      | 3     | 2   | 1  | 0  |
| Byte      | 000     | D0 |    |      |     |      |      |    |    | D0 |    |    |        |       |     |    |    |
|           | 001     |    | D1 |      |     |      |      |    |    |    | D1 |    |        |       |     |    |    |
|           | 010     |    |    | D2   |     |      |      |    |    |    |    | D2 |        |       |     |    |    |
|           | 011     |    |    |      | D3  |      |      |    |    |    |    |    | D3     |       |     |    |    |
|           | 100     |    |    |      |     | D4   |      |    |    |    |    |    |        | D4    |     |    |    |
|           | 101     |    |    |      |     |      | D5   |    |    |    |    |    |        |       | D5  |    |    |
|           | 110     |    |    |      |     |      |      | D6 |    |    |    |    |        |       |     | D6 |    |
|           | 111     |    |    |      |     |      |      |    | D7 |    |    |    |        |       |     |    | D7 |
| Two       | 000     | D0 | D1 |      |     |      |      |    |    | D0 | D1 |    |        |       |     |    |    |
| bytes     | 001     |    | D1 | D2   |     |      |      |    |    |    | D1 | D2 |        |       |     |    |    |
|           | 010     |    |    | D2   | D3  |      |      |    |    |    |    | D2 | D3     |       |     |    |    |
|           | 100     |    |    |      |     | D4   | D5   |    |    |    |    |    |        | D4    | D5  |    |    |
|           | 101     |    |    |      |     |      | D5   | D6 |    |    |    |    |        |       | D5  | D6 |    |
|           | 110     |    |    |      |     |      |      | D6 | D7 |    |    |    |        |       |     | D6 | D7 |
| Tri-byte  | 000     | D0 | D1 | D2   |     |      |      |    |    | D0 | D1 | D2 |        |       |     |    |    |
|           | 001     |    | D1 | D2   | D3  |      |      |    |    |    | D1 | D2 | D3     |       |     |    |    |
|           | 100     |    |    |      |     | D4   | D5   | D6 |    |    |    |    |        | D4    | D5  | D6 |    |
|           | 101     |    |    |      |     |      | D5   | D6 | D7 |    |    |    |        |       | D5  | D6 | D7 |
| Word      | 000     | D0 | D1 | D2   | D3  |      |      |    |    | D0 | D1 | D2 | D3     |       |     |    |    |
|           | 100     |    |    |      |     | D4   | D5   | D6 | D7 |    |    |    |        | D4    | D5  | D6 | D7 |
| Five      | 000     | D0 | D1 | D2   | D3  | D4   |      |    |    | D0 | D1 | D2 | D3     | D4    |     |    |    |
| bytes     | 011     |    |    |      | D3  | D4   | D5   | D6 | D7 |    |    |    | D3     | D4    | D5  | D6 | D7 |
| Six bytes | 000     | D0 | D1 | D2   | D3  | D4   | D5   |    |    | D0 | D1 | D2 | D3     | D4    | D5  |    |    |
|           | 010     |    |    | D2   | D3  | D4   | D5   | D6 | D7 |    |    | D2 | D3     | D4    | D5  | D6 | D7 |

## Table 57: PowerSpan II Little-endian Mode Byte Lane Mapping

| Transfer | Start   |    |    | Powe | rPC | Byte | Lane | s  |    |    |    | PC | CI Byt | e Lar | nes |    |    |
|----------|---------|----|----|------|-----|------|------|----|----|----|----|----|--------|-------|-----|----|----|
| Size     | Address | 0  | 1  | 2    | 3   | 4    | 5    | 6  | 7  | 7  | 6  | 5  | 4      | 3     | 2   | 1  | 0  |
| Seven    | 000     | D0 | D1 | D2   | D3  | D4   | D5   | D6 |    | D0 | D1 | D2 | D3     | D4    | D5  | D6 |    |
| bytes    | 001     |    | D1 | D2   | D3  | D4   | D5   | D6 | D7 |    | D1 | D2 | D3     | D4    | D5  | D6 | D7 |
| Double   | 000     | D0 | D1 | D2   | D3  | D4   | D5   | D6 | D7 | D0 | D1 | D2 | D3     | D4    | D5  | D6 | D7 |

Table 57: PowerSpan II Little-endian Mode Byte Lane Mapping

## 10.4.3 PowerPC Little-endian Mode

In PowerPC little-endian mode, the PB Master swaps byte lanes according to Table 57 and munges outgoing addresses PB\_A[29:31] according to Table 54. Address munging does not occur for burst and extended cycles.

In PowerPC little-endian mode, the PB Master is restricted to transferring naturally aligned quantities. External PCI masters or the PowerSpan II's DMA channels can request transactions that are not naturally aligned. The PB Master breaks up these requests into single byte transactions on the processor bus, with a performance penalty.

The PB Slave asserts PB\_TEA\_ in response to a transaction that is not naturally aligned. These cases are as follows:

- $PB_TSIZ = 3, 5, 6, 7$  bytes
- PB\_TSIZ = 2 bytes and PB\_A[31] = 1

For DMA transactions between the processor (60x) bus and the PCI-1 bus, the END bit in the DMAx\_TCR registers (page 369) must be set to 11. For all other PowerPC little-endian transfers, the END bit must be set to 01.

## 10.4.4 True Little-endian Mode

When operating in true little-endian mode, PowerSpan II uses a data invariant scheme for mapping PowerPC byte lanes. Data invariance preserves the relative byte significance of a structure in both PCI and PowerPC spaces, but translates the byte addressing.

In order to access PCI device registers from the processor bus in true little-endian mode, there are certain addressing rules which must be followed. In PowerSpan II when true little-endian mode is selected, no address swapping takes place (refer to Table 58). This means that the MSB on the processor bus goes to the MSB on PCI. However, the MSB on processor bus is the low address and MSB on PCI is the high address.

True little-endian mode cannot be used with the 4 byte read implementation in the PowerSpan II design. The MEM\_IO bit must be set to 0 when the END field is set to 11. Refer to "Reads" on page 55 and "Reads" on page 117 for a detailed explanation of the 4 byte read through the PCI Interfaces and PB Interface.



The 4 byte read implementation can be used with the other types of endian conversion.

|                  | Starting<br>Address |    |    |      |      |        |       |    | Pow | erSpar | n II PC | I Addre | ss   |    |
|------------------|---------------------|----|----|------|------|--------|-------|----|-----|--------|---------|---------|------|----|
|                  | (Munged)            |    |    | Powe | erPC | Byte I | Lanes | 5  |     |        |         | A[      | 1:0] |    |
| Transfer<br>Size | PB_A<br>[29:31]     | 0  | 1  | 2    | 3    | 4      | 5     | 6  | 7   | A[2]   | 11      | 10      | 01   | 00 |
| Byte             | 000                 | D0 |    |      |      |        |       |    |     | 0      | D0      |         |      |    |
|                  | 001                 |    | D1 |      |      |        |       |    |     | 0      |         | D1      |      |    |
|                  | 010                 |    |    | D2   |      |        |       |    |     | 0      |         |         | D2   |    |
|                  | 011                 |    |    |      | D3   |        |       |    |     | 0      |         |         |      | D3 |
|                  | 100                 |    |    |      |      | D4     |       |    |     | 1      | D4      |         |      |    |
|                  | 101                 |    |    |      |      |        | D5    |    |     | 1      |         | D5      |      |    |
|                  | 110                 |    |    |      |      |        |       | D6 |     | 1      |         |         | D6   |    |
|                  | 111                 |    |    |      |      |        |       |    | D7  | 1      |         |         |      | D7 |
| Two bytes        | 000                 | D0 | D1 |      |      |        |       |    |     | 0      | D0      | D1      |      |    |
|                  | 010                 |    |    | D2   | D3   |        |       |    |     | 0      |         |         | D2   | D3 |
|                  | 100                 |    |    |      |      | D4     | D5    |    |     | 1      | D4      | D5      |      |    |
|                  | 110                 |    |    |      |      |        |       | D6 | D7  | 1      |         |         | D6   | D7 |
| Tri bytes        | 000                 | D0 | D1 | D2   |      |        |       |    |     | 0      | D0      | D1      | D2   |    |
|                  | 001                 |    | D1 | D2   | D3   |        |       |    |     | 0      |         | D1      | D2   | D3 |
|                  | 100                 |    |    |      |      | D4     | D5    | D6 |     | 1      | D4      | D5      | D6   |    |
|                  | 101                 |    |    |      |      |        | D5    | D6 | D7  | 1      |         | D5      | D6   | D7 |
| Word             | 000                 | D0 | D1 | D2   | D3   |        |       |    |     | 0      | D0      | D1      | D2   | D3 |
|                  | 100                 |    |    |      |      | D4     | D5    | D6 | D7  | 1      | D4      | D5      | D6   | D7 |
| Five Bytes       | 000                 | D0 | D1 | D2   | D3   | D4     |       |    |     | 0      | D0      | D1      | D2   | D3 |
|                  |                     |    |    |      |      |        |       |    |     | 1      | D4      |         |      |    |
|                  | 011                 |    |    |      | D3   | D4     | D5    | D6 | D7  | 0      |         |         |      | D3 |
|                  |                     |    |    |      |      |        |       |    |     | 1      | D4      | D5      | D6   | D7 |

#### Table 58: PowerSpan II True Little-Endian Byte Lane Mappings

|                  | Starting            |    |    |      |      |        |      |    |    | Pow  | erSpar | n II PC | I Addre | ess |
|------------------|---------------------|----|----|------|------|--------|------|----|----|------|--------|---------|---------|-----|
|                  | Address<br>(Munged) |    |    | Powe | erPC | Byte I | anes | 5  |    |      |        | Α[      | 1:0]    |     |
| Transfer<br>Size | PB_A<br>[29:31]     | 0  | 1  | 2    | 3    | 4      | 5    | 6  | 7  | A[2] | 11     | 10      | 01      | 00  |
| Six Bytes        | 000                 | D0 | D1 | D2   | D3   | D4     | D5   |    |    | 0    | D0     | D1      | D2      | D3  |
|                  |                     |    |    |      |      |        |      |    |    | 1    | D4     | D5      |         |     |
|                  | 010                 |    |    | D2   | D3   | D4     | D5   | D6 | D7 | 0    |        |         | D2      | D3  |
|                  |                     |    |    |      |      |        |      |    |    | 1    | D4     | D5      | D6      | D7  |
| Seven            | 000                 | D0 | D1 | D2   | D3   | D4     | D5   | D6 |    | 0    | D0     | D1      | D2      | D3  |
| Bytes            |                     |    |    |      |      |        |      |    |    | 1    | D4     | D5      | D6      |     |
|                  | 001                 |    | D1 | D2   | D3   | D4     | D5   | D6 | D7 | 0    |        | D1      | D2      | D3  |
|                  |                     |    |    |      |      |        |      |    |    | 1    | D4     | D5      | D6      | D7  |
| Double           | 000                 | D0 | D1 | D2   | D3   | D4     | D5   | D6 | D7 | 0    | D0     | D1      | D2      | D3  |
|                  |                     |    |    |      |      |        |      |    |    | 1    | D4     | D5      | D6      | D7  |

#### Table 58: PowerSpan II True Little-Endian Byte Lane Mappings



## **11. Signals and Pinout**

This chapter describes the Processor Bus (PB) Interface, Single PCI PowerSpan II and Dual PCI PowerSpan II signals. Signals the differ between the Single PCI PowerSpan II and Dual PCI PowerSpan II are identified in the signal tables. The following topics are discussed:

• "Signal Description" on page 227

## 11.1 Signal Description

This section organizes the PowerSpan II signals along the following functional groups:

- Processor Bus
- PCI-1
- PCI-2
- Miscellaneous
- Test

The Dual PCI PowerSpan II contains all five of these signal groupings.

The Single PCI PowerSpan II device does not implement the PCI-2 signal group.

## 11.1.1 Signal Types

Signals are classified according to the types defined in Table 59.

#### Table 59: Signal Type Definitions

| Signal type              | Signal type definition                                                                                 |
|--------------------------|--------------------------------------------------------------------------------------------------------|
| Input                    | Standard input only signal.                                                                            |
| Output                   | Standard output only signal.                                                                           |
| Tristate output          | Standard tristate output only signal.                                                                  |
| Open drain               | Open drain output that allows multiple devices to share as a wire-<br>OR                               |
| Tristate bidirectional   | Tristate input/output signal.                                                                          |
| Bidirectional open drain | Open drain input/output which allows multiple devices to share as a wire or when it is used as output. |



All arbitration signals — REQ# and GNT# — must be weakly pulledup when using the PowerSpan II's arbiters. This is true for all of PowerSpan II's arbiters: Processor Bus, PCI-1 and PCI-2.

## 11.1.2 Processor Bus Signals

This section describes PowerSpan II PB Interface signals used to interface to the PowerPC 603/740/750 or the MPC8260. Signals in this group are 3.3V LVTTL compatible. The signals are not 5V tolerant.

Table 60 summarizes the signals in this grouping. Signals with electrical characteristics different from the remainder of the group are placed at the end of the table.

| Pin Name   | Pin Type                  | Reset State | Recommended<br>Termination | Description                                                                                                                                                                                 |
|------------|---------------------------|-------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_AACK_   | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor           | Address Acknowledge: A<br>processor bus slave asserts<br>this signal to indicate that it<br>identified the address<br>tenure. Assertion of this<br>signal terminates the<br>address tenure. |
| PB_ABB_    | Tristate output           | Hi-Z        | Pull-up resistor           | Address Bus Busy:<br>Indicates ownership of the<br>processor address bus.                                                                                                                   |
| PB_AP[0:3] | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor           | Address Parity: The<br>processor address bus<br>master drives this signal to<br>indicate the parity of the<br>address bus.                                                                  |
| PB_ARTRY_  | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor           | Address Retry: Assertion<br>of this signal indicates that<br>the bus transaction must be<br>retried by the processor bus<br>master.                                                         |

Table 60: Processor Bus Signals

Table 60: Processor Bus Signals

| Pin Name    | Pin Type                  | Reset State | Recommended<br>Termination  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------|-------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_A[0:31]  | Tristate<br>bidirectional | Hi-Z        | No requirement <sup>a</sup> | Address Bus: Address for<br>the current bus cycle. It is<br>driven by PowerSpan II<br>when it is the 603 bus<br>master. At all other times it<br>is an input to PowerSpan II.                                                                                                                                                                                                                                                                         |
| PB_BG[1]_   | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor            | Address Bus Grant: This<br>is an input when an external<br>arbiter is used and an<br>output when the internal<br>arbiter is used. As input it is<br>used by an external arbiter<br>to grant the processor<br>address bus to PowerSpan<br>II. As output it is used by the<br>internal arbiter to grant the<br>processor address bus to<br>an external bus master. This<br>pin must be weakly pulled<br>high.                                           |
| PB_BG[2:3]_ | Tristate output           | Hi-Z        | Pull-up resistor            | Address Bus Grant: It is<br>used by the internal arbiter<br>to grant the processor<br>address bus to the external<br>bus masters. These pins<br>must be weakly pulled high.                                                                                                                                                                                                                                                                           |
| PB_BR[1]_   | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor            | Address Bus Request:<br>This is an output when an<br>external arbiter is used and<br>an input when an internal<br>arbiter is used. As output it<br>indicates that PowerSpan II<br>requests the ownership of<br>the processor address bus.<br>As input an external master<br>should assert this signal to<br>request the ownership of<br>the processor address bus<br>from PowerSpan II's internal<br>arbiter. This pin must be<br>weakly pulled high. |

| Pin Name    | Pin Type        | Reset State | Recommended<br>Termination | Description                                                                                                                                                                                               |
|-------------|-----------------|-------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_BR[2:3]_ | Input           | Hi-Z        | Pull-up resistor           | Address Bus Request:<br>These are inputs only. They<br>are used by external<br>masters to request the<br>processor address bus from<br>the internal arbiter. These<br>pins must be weakly pulled<br>high. |
| PB_CI_      | Tristate output | Hi-Z        | Pull-up resistor           | <b>Cache Inhibit:</b> It is used for<br>L2 cache control. It<br>indicates whether the<br>transaction should be<br>cached or not.                                                                          |
| PB_CLK      | Input           | -           | -                          | Processor Bus Clock: All<br>devices intended to<br>interface with the bus<br>processor side of the<br>PowerSpan II must be<br>synchronized to this clock.<br>The PB_CLK can operate<br>up to 100 MHz.     |
| PB_DBB_     | Tristate output | Hi-Z        | Pull-up resistor           | Data Bus Busy: Indicates<br>the ownership of the data<br>bus. The master who owns<br>the processor data bus<br>asserts this signal.                                                                       |

 Table 60: Processor Bus Signals

| Table 60: Processor B | us Signals |
|-----------------------|------------|
|-----------------------|------------|

| Pin Name   | Pin Type                  | Reset State | Recommended<br>Termination | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|---------------------------|-------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_DBG[1]_ | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor           | Data Bus Grant: This is an<br>input when an external<br>arbiter is used and an<br>output when the internal<br>arbiter is used. As input it is<br>used by an external arbiter<br>to grant the processor data<br>bus to PowerSpan II. As<br>output it is used by the<br>internal arbiter to grant the<br>processor data bus to an<br>external bus master. This<br>pin must be weakly pulled<br>high. |

 Table 60: Processor Bus Signals

| Pin Name     | Pin Type                  | Reset State | Recommended<br>Termination  | Description                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------|-------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_DBG[2:3]_ | Tristate output           | Hi-Z        | Pull-up resistor            | Data Bus Grant: This is an<br>output only. It is used by the<br>internal arbiter to grant the<br>processor data bus to<br>external bus masters.<br>These pins must be weakly<br>pulled high.                                                                                                |
| PB_DP[0:7]   | Tristate<br>bidirectional | Hi-Z        | No requirement <sup>a</sup> | <b>Data Parity:</b> The processor<br>data bus slave drives on<br>reads, master drives on<br>write to indicate the parity of<br>the data bus.                                                                                                                                                |
| PB_DVAL_     | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor            | <b>Data Valid:</b> Indicates if the data beat is valid on PB_D[0:63].                                                                                                                                                                                                                       |
| PB_D[0:63]   | Tristate<br>bidirectional | Hi-Z        | No requirement <sup>a</sup> | Data Bus                                                                                                                                                                                                                                                                                    |
| PB_FAST      | Input                     | -           | Power-up option             | <b>PLL Configuration:</b> If the signal is pulled low, it configures the PB Interface PLL to operate with input frequencies between 25 and 50 MHz. If the signal is pulled high, it configures the PB Interface PLL to operate with input frequencies above 50 MHz to a maximum of 100 MHz. |

Table 60: Processor Bus Signals

| Pin Name    | Pin Type                                         | Reset State                                                            | Recommended<br>Termination | Description                                                                                                                                                                                                                                                                                                                                                    |
|-------------|--------------------------------------------------|------------------------------------------------------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB_GBL_     | Tristate output                                  | Hi-Z                                                                   | Pull-up resistor           | <b>Global:</b> Indicates that the transfer is coherent and it should be snooped by bus masters.                                                                                                                                                                                                                                                                |
| PB_RSTCONF_ | Input<br>(Schmitt trigger)                       | -                                                                      | -                          | Reset Configuration:<br>Asserted by MPC8260<br>master to indicate to<br>PowerSpan II to load power-<br>up options. This pin must be<br>pulled high if the<br>multiplexed system pin<br>mechanism is used to load<br>the power-up options.                                                                                                                      |
| PB_RST_     | Bidirectional<br>open drain<br>(Schmitt trigger) | Low<br>(if<br>PB_RST_DIR=1,<br>otherwise the<br>signal is an<br>input) | Pull-up resistor           | <b>Reset:</b> Asynchronous<br>active low reset. This is<br>connected to HRESET_ pin<br>of the MPC8260                                                                                                                                                                                                                                                          |
| PB_RST_DIR  | Input                                            | -                                                                      | Power-up option            | Processor Bus Reset<br>Direction                                                                                                                                                                                                                                                                                                                               |
| PB_TA_      | Tristate<br>bidirectional                        | Hi-Z                                                                   | Pull-up resistor           | Transfer Acknowledge:<br>Indicates that a data beat is<br>valid on the data bus. For<br>single beat transfers, it<br>indicates the termination of<br>the transfer. For burst<br>transfers, it will be asserted<br>four times to indicate the<br>transfer of four data beats<br>with the last assertion<br>indicating the termination of<br>the burst transfer. |

Table 60: Processor Bus Signals

| Pin Name     | Pin Type                  | Reset State | Recommended<br>Termination                       | Description                                                                                                                 |
|--------------|---------------------------|-------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| PB_TBST_     | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor                                 | Transfer Burst: The bus<br>master asserts this pin to<br>indicate that the current<br>transaction is a burst<br>transaction |
| PB_TEA_      | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor                                 | Transfer Error<br>Acknowledge: Indicates a<br>bus error.                                                                    |
| PB_TSIZ[0:3] | Tristate<br>bidirectional | Hi-Z        | Pull-down<br>resistor on<br>TSIZ[0] <sup>b</sup> | <b>Transfer Size:</b> Indicates the number of bytes to be transferred during a bus cycle.                                   |
| PB_TS_       | Tristate<br>bidirectional | Hi-Z        | Pull-up resistor                                 | <b>Transfer Start:</b> Indicates the beginning of a new address bus tenure.                                                 |
| PB_TT[0:4]   | Tristate<br>bidirectional | Hi-Z        | No requirement <sup>a</sup>                      | <b>Transfer Type:</b> The bus<br>master drives these pins to<br>specify the type of the<br>transaction.                     |
| PB_VDDA      | Supply                    | -           | -                                                | <b>PB Analog VDD:</b> Voltage<br>supply pin to the analog<br>circuits in the PB Phase<br>Locked Loop (nominally<br>2.5V).   |
| PB_DVDD      | Supply                    | -           | -                                                | <b>PB Digital VDD:</b> Voltage<br>supply pin to the digital<br>circuits in the PB Phase<br>Locked Loop (nominally<br>2.5V). |
| PB_DVSS      | Ground                    | -           | -                                                | <b>PB Digital VSS:</b> Ground<br>pin to the digital circuits in<br>the PB Phase Locked Loop.                                |
| PB_AVSS      | Ground                    | -           | -                                                | <b>PB Analog VSS:</b> Ground<br>pin to the digital circuits in<br>the PB Phase Locked Loop.                                 |

- a. Pull-up resistors are not required on the processor bus address (PB\_A[0:31]) and data (PB\_D[0:63]) signals to guarantee functional operation of the PowerSpan II. However, adding resistors to the address and data signals minimizes the current drawn by the PowerSpan II's tristated buffers when the bus is in an idle condition. The system designer must decide whether to add these resistors to the address and data bus.
- b. A pull-up resistor must be added to the signal if a external master that does not support MPC8260 extended cycles is in the system. If this type of external master is in the system, TSIZ[0] must be disconnected and a pull-down resistor must be used on the signal. Refer to E. "Typical Applications" on page 481 for a description and illustration of this type of system.

## 11.1.3 PCI-1 Signals

This section describes PowerSpan II signals used to interface to PCI-1. Signals in this group are compatible with both 3V and 5V signaling environments — as defined by the *PCI 2.2 Specification*.

Table 61 summarizes the signals in this grouping. Signals with electrical characteristics different from the remainder of the group are placed at the end of the table.

| Pin Name     | Pin Type                  | Description                                                                                                                                                                                                                                                                                                                    |
|--------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1_AD [63:0] | Tristate<br>bidirectional | <b>PCI-1 Address/Data Bus:</b> Address and data are multiplexed over these pins providing a 64-bit address/data bus. <sup>b</sup>                                                                                                                                                                                              |
| P1_ACK64#    | Tristate<br>bidirectional | <b>PCI-1 Acknowledge 64-bit Transaction:</b> Active low signal asserted by a target to indicate its willingness to participate in a 64-bit transaction. Driven by the target; sampled by the master. Rescinded by the target at the end of the transaction.                                                                    |
| P1_CBE[7:0]# | Tristate<br>bidirectional | <b>PCI-1 Bus Command and Byte Enable Lines:</b> Command and byte enable information is multiplexed over all eight CBE lines.                                                                                                                                                                                                   |
| P1_DEVSEL#   | Tristate<br>bidirectional | <b>PCI-1 Device Select:</b> An active low indication from an agent that is the target of the current transaction. Driven by the target; sampled by the master. Rescinded by the target at the end of the transaction.                                                                                                          |
| P1_FRAME#    | Tristate<br>bidirectional | <b>PCI-1 Cycle Frame for PCI Bus:</b> An active low indication from the current bus master of the beginning and end of a transaction. Driven by the bus master; sampled by the selected target. Rescinded by the bus master at the end of the transaction.                                                                     |
| P1_GNT[1]#   | Tristate<br>bidirectional | <b>PCI-1 Grant:</b> This is an input when an external arbiter is used and an output when the internal arbiter is used. As input it is used by the external arbiter to grant the bus to PowerSpan II. As output it is used by the internal arbiter to grant the bus to an external master. This pin must be weakly pulled high. |

#### Table 61: PCI-1 Signals<sup>a</sup>

## Table 61: PCI-1 Signals<sup>a</sup>

| Pin Name          | Pin Type                  | Description                                                                                                                                                                                                                                                                                    |
|-------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1_GNT<br>[4:2]#  | Tristate output           | <b>PCI-1 Grant:</b> These are outputs only. They are used by the PCI-1 internal arbiter to grant the bus to external masters.                                                                                                                                                                  |
| PCI_GNT<br>[7:5]# | Tristate output           | <b>PCI-1 Grant:</b> These outputs may be driven by the PCI-1 or PCI-2 internal arbiter to grant the bus to external masters. They are assigned to PCI-1 or PCI-2 by software. These pins should be weakly pulled high in a system.                                                             |
| P1_IDSEL          | Input                     | <b>PCI-1 Initialization Device Select:</b> Used as a chip select during Configuration read and write transactions.                                                                                                                                                                             |
| P1_INTA#          | Bidirectional open drain  | <b>PCI-1 Interrupt A:</b> An active low level sensitive indication of an interrupt. Asynchronous to P1_CLK.                                                                                                                                                                                    |
| P1_IRDY#          | Tristate<br>bidirectional | <b>PCI-1 Initiator Ready:</b> An active low indication of the current bus master's ability to complete the current dataphase. Driven by the master; sampled by the selected target.                                                                                                            |
| P1_PAR            | Tristate<br>bidirectional | <b>PCI-1 Parity:</b> Carries even parity across P1_AD[31:0] and P1_C/<br>BE[3:0]. Driven by the master for the address and write<br>dataphases. Driven by the target for read dataphases.                                                                                                      |
| P1_PAR64          | Tristate<br>bidirectional | <b>PCI-1 Parity Upper Dword:</b> Carries even parity across P1_AD[63:32] and P1_CBE[7:4]. Driven by the master for address and write dataphases. Driven by the target for read dataphases.                                                                                                     |
| P1_CLK            | Input                     | <b>PCI-1 Clock: Clock input for the PCI-1 Interface:</b> P1_CLK operates between 25 and 66MHz.                                                                                                                                                                                                 |
| P1_M66EN          | Input                     | <b>PCI-1 66 MHz Enable:</b> When pulled low, configures the PCI-1 PLL for operation between 25 and 33 MHz. When pulled high, configures the PCI-1 Interface PLL for operation above 33 MHz to a maximum of 66 MHz.                                                                             |
| P1_PERR#          | Tristate<br>bidirectional | <b>PCI-1 Parity Error:</b> An active low indication of a data parity error. Driven by the target receiving data. Rescinded by that agent at the end of the transaction.                                                                                                                        |
| P1_REQ[1]#        | Tristate<br>bidirectional | <b>PCI-1 Bus Request:</b> This is an output when an external arbiter is used and an input when the PCI-1 internal arbiter is used. As input it is used by an external master to request the bus. As output it is used by PowerSpan II to request the bus. This pin must be weakly pulled high. |
| P1_REQ[4:2]#      | Input                     | <b>PCI-1 Bus Request:</b> These are inputs only. They can be used by external masters to request the bus through the PCI-1 arbiter. These pins should be weakly pulled high in a system.                                                                                                       |

#### Table 61: PCI-1 Signals<sup>a</sup>

| Pin Name          | Pin Type                  | Description                                                                                                                                                                                                                    |
|-------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI_REQ<br>[7:5]# | Input                     | <b>PCI-1 Bus Request:</b> These inputs are used by external masters to request the bus from the PCI-1 or PCI-2 arbiter. They are assigned to PCI-1 or PCI-2 by software. These pins must be weakly pulled high in a system.    |
| P1_REQ64#         | Tristate<br>bidirectional | <b>PCI-1 Request 64-bit Transfer:</b> An active low indication from the current master of its choice to perform 64-bit transactions. Rescinded by the bus master at the end of the transaction.                                |
| P1_RST#           | Tristate<br>bidirectional | PCI-1 Reset: Asynchronous active low reset for PCI-1 Interface                                                                                                                                                                 |
| P1_SERR#          | Open drain                | <b>PCI-1 System Error:</b> An active low indication of address parity error.                                                                                                                                                   |
| P1_STOP#          | Tristate<br>bidirectional | <b>PCI-1 Stop:</b> An active low indication from the target of its desire to stop the current transition. Sampled by the master. Rescinded by the target at the end of the transaction.                                        |
| P1_TRDY#          | Tristate<br>bidirectional | <b>PCI-1 Target Ready:</b> An active low indication of the current target's ability to complete the dataphase. Driven by the target; sampled by the current bus master. Rescinded by the target at the end of the transaction. |
| P1_64EN#          | Input                     | <b>PCI-1 64-bit Enable:</b> An active low indication that a CompactPCI Hot Swap board is in a 64-bit slot. This signal must be pulled high in a non-Hot Swap environment.                                                      |
| P1_RST_DIR        | Input<br>(LVTTL)          | PCI-1 Bus Reset Direction                                                                                                                                                                                                      |
| P1_VDDA           | Supply                    | <b>PCI-1 Analog VDD:</b> Voltage supply pin to the analog circuits in the PCI-1 Phase Locked Loop (nominally 2.5V).                                                                                                            |
| P1_DVDD           | Supply                    | <b>PCI-1 Digital VDD:</b> Voltage supply pin to the digital circuits in the PCI-1 Phase Locked Loop (nominally 2.5V).                                                                                                          |
| P1_DVSS           | Ground                    | <b>PCI-1 Digital VSS:</b> Ground pin to the digital circuits in the PCI-1 Phase Locked Loop.                                                                                                                                   |
| P1_AVSS           | Ground                    | <b>PCI-1 Analog VSS:</b> Ground pin to the digital circuits in the PCI-1 Phase Locked Loop.                                                                                                                                    |

a. Refer to the *PCI Local Bus Specification* for reset states and recommended terminations of these PCI signals.

b. To use the PowerSpan II Dual PCI in a 32-bit environment, add a pull-up resistor to P1\_AD[32:63].

## 11.1.4 PCI-2 Signals

This section describes PowerSpan II signals used to interface to PCI-2. Signals in this group are compatible with both 3V and 5V signaling environments — as defined by the *PCI 2.2 Specification*.



These signals are not implemented in the Single PCI PowerSpan II.

Table 62 below summarizes the signals in this grouping. Signals with electrical characteristics different from the remainder of the group are placed at the end of the table.

#### Table 62: PCI-2 Signals<sup>a</sup>

| Pin Name         | Pin Type                  | Description                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P2_AD[31:0]      | Tristate<br>bidirectional | <b>PCI-2 Address/Data Bus:</b> Address and data are multiplexed over these pins providing a 32-bit address/data bus.                                                                                                                                                                                                                                                  |
| P2_CBE[3:0]#     | Tristate<br>bidirectional | <b>PCI-2 Bus Command and Byte Enable Lines:</b> Command and byte enable information is multiplexed over all four CBE lines.                                                                                                                                                                                                                                           |
| P2_DEVSEL#       | Tristate<br>bidirectional | <b>PCI-2 Device Select:</b> An active low indication from an agent that is the target of the current transaction. Driven by the target; sampled by the master. Rescinded by the target at the end of the transaction.                                                                                                                                                 |
| P2_FRAME#        | Tristate<br>bidirectional | <b>PCI-2 Cycle Frame for PCI Bus:</b> An active low indication from the current bus master of the beginning and end of a transaction. Driven by the bus master, sampled by the selected target. Rescinded by the bus master at the end of the transaction.                                                                                                            |
| P2_GNT[1]#       | Tristate<br>bidirectional | <b>PCI-2 Grant:</b> This is an input when an external arbiter is used and<br>an output when the PCI-2 internal arbiter is used. As input it is<br>used by the external arbiter to grant the bus to PowerSpan II. As<br>output it is used by the PCI-2 internal arbiter to grant the bus to an<br>external master.<br>This pin must be weakly pulled high in a system. |
| P2_GNT<br>[4:2]# | Tristate output           | <b>PCI-2 Grant:</b> These are outputs only. They are used by the PCI-2 internal arbiter to grant the bus to external masters. These pins must be weakly pulled high in a system.                                                                                                                                                                                      |
| P2_IDSEL         | Input                     | <b>PCI-2 Initialization Device Select:</b> Used as a chip select during <i>Configuration</i> read and write transactions                                                                                                                                                                                                                                              |
| P2_INTA#         | Bidirectional open drain  | <b>PCI -2 Interrupt A:</b> An active low level sensitive indication of an interrupt. Asynchronous to P2_CLK                                                                                                                                                                                                                                                           |

#### Table 62: PCI-2 Signals<sup>a</sup>

| Pin Name    | Pin Type                  | Description                                                                                                                                                                                                                                                                                              |
|-------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P2_IRDY#    | Tristate<br>bidirectional | <b>PCI-2 Initiator Ready:</b> An active low indication of the current bus master's ability to complete the current dataphase. Driven by the master; sampled by the selected target.                                                                                                                      |
| P2_PAR      | Tristate<br>bidirectional | <b>PCI-2 Parity:</b> Carries even parity across P2_AD[31:0] and P2_C/<br>BE[3:0]. Driven by the master for the address and write<br>dataphases. Driven by the target for read dataphases.                                                                                                                |
| P2_CLK      | Input                     | <b>PCI-2 Clock:</b> Clock input for the PCI-2 Interface. P2_CLK operates between 25 and 66MHz.                                                                                                                                                                                                           |
| P2_M66EN    | Input                     | <b>PCI-2 66 MHz Enable:</b> When pulled low, configures the PCI-2 PLL for operation between 25 and 33 MHz. When pulled high, configures the PCI-2 Interface PLL for operation above 33 MHz to a maximum of 66 MHz.                                                                                       |
| P2_PERR#    | Tristate<br>bidirectional | <b>PCI-2 Parity Error:</b> An active low indication of a data parity error. Driven by the target receiving data. Rescinded by that agent at the end of the transaction.                                                                                                                                  |
| P2_REQ[1]   | Tristate<br>bidirectional | <b>PCI-2 Bus Request:</b> This is an output when an external arbiter is used and an input when the PCI-2 Interface internal arbiter is used. As input it is used by an external master to request the bus. As output it is used by PowerSpan II to request the bus. This pin must be weakly pulled high. |
| P2_REQ[4:2] | Input                     | <b>PCI-2 Bus Request:</b> These are inputs only. They can be used by external masters to request the bus from the PCI-2 arbiter. These pins must be weakly pulled high in a system.                                                                                                                      |
| P2_RST#     | Tristate<br>bidirectional | PCI-2 Reset: Asynchronous active low reset for PCI-2 Interface.                                                                                                                                                                                                                                          |
| P2_SERR#    | Open drain                | <b>PCI-2 System Error:</b> An active low indication of address parity error.                                                                                                                                                                                                                             |
| P2_STOP#    | Tristate<br>bidirectional | <b>PCI-2 Stop:</b> An active low indication from the target of its desire to stop the current transition. Sampled by the master. Rescinded by the target at the end of the transaction.                                                                                                                  |
| P2_TRDY#    | Tristate<br>bidirectional | <b>PCI-2 Target Ready:</b> An active low indication of the current target's ability to complete the dataphase. Driven by the target; sampled by the current bus master. Rescinded by the target at the end of the transaction.                                                                           |
|             |                           |                                                                                                                                                                                                                                                                                                          |

#### Table 62: PCI-2 Signals<sup>a</sup>

| Pin Name   | Pin Type         | Description                                                                                                           |
|------------|------------------|-----------------------------------------------------------------------------------------------------------------------|
| P2_RST_DIR | Input<br>(LVTTL) | PCI-2 Bus Reset Direction                                                                                             |
| P2_VDDA    | Supply           | <b>PCI-2 Analog VDD:</b> Voltage supply pin to the analog circuits in the PCI-2 Phase Locked Loop (nominally 2.5V).   |
| P2_DVDD    | Supply           | <b>PCI-2 Digital VDD:</b> Voltage supply pin to the digital circuits in the PCI-1 Phase Locked Loop (nominally 2.5V). |
| P2_DVSS    | Ground           | <b>PCI-2 Digital VSS:</b> Ground pin to the digital circuits in the PCI-1 Phase Locked Loop.                          |
| P2_AVSS    | Ground           | <b>PCI-2 Analog VSS:</b> Ground pin to the digital circuits in the PCI-1 Phase Locked Loop.                           |

a. Refer to the PCI Local Bus Specification for reset states and recommended terminations of these PCI signals.

## 11.1.5 Miscellaneous Signals

Table 63 below lists PowerSpan II signals which are not necessarily dedicated to thePB, PCI-1 or PCI-2 Interfaces. They have a variety of electrical capabilities.

| Table 63: | <b>Miscellaneous</b> | Signals |
|-----------|----------------------|---------|
|-----------|----------------------|---------|

| Pin Name  | Pin Type                                                                   | Reset State | Recommended<br>Termination                                                                                                                     | Description                                                                                                                                                                                                                |
|-----------|----------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT[5:0]_ | Bidirectional<br>open drain<br>(5V tolerant<br>LVTTL)<br>(Schmitt trigger) | Hi-Z        | Pull-up resistor                                                                                                                               | Interrupt: General purpose interrupt pins                                                                                                                                                                                  |
| ENUM#     | Open drain<br>output<br>(PCI)                                              | Hi-Z        | Pull-up resistor if<br>the application is<br>a system host.<br>Otherwise there<br>is no resistor<br>requirement on<br>the signal.              | <b>System Enumeration:</b> Used<br>to notify system host that a<br>board has been freshly<br>inserted or extracted from the<br>system.                                                                                     |
| ES        | Input<br>(5V tolerant<br>LVTTL)<br>(Schmitt trigger)                       | -           | Pull-down<br>resistor in non-<br>Hot Swap<br>environment <sup>a</sup>                                                                          | <b>Ejector Switch:</b> Indicates the status of Hot Swap board ejector switch. A logic high value indicates the switch is closed and it is in operation mode. This signal must be pulled low in a non-Hot Swap environment. |
| LED#      | Open drain<br>output<br>(5V tolerant<br>LVTTL)                             | Low         | Pull-up resistor if<br>the application is<br>a system host.<br>Otherwise there<br>is no resistor<br>requirement on<br>the signal. <sup>a</sup> | <b>LED:</b> Controls the Hot Swap status LED.                                                                                                                                                                              |

Table 63: Miscellaneous Signals

| Pin Name | Pin Type                                               | Reset State | Recommended<br>Termination                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|--------------------------------------------------------|-------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HEALTHY# | Input<br>(5 V tolerant<br>LVTTL)<br>(Schmitt trigger)  | -           | Pull-down<br>resistor in non-<br>Hot Swap<br>environment <sup>a</sup> | <b>Board Healthy:</b> In a Hot<br>Swap environment, indicates<br>the board is ready to be<br>released from reset and<br>become an active agent on<br>PCI. Negation of this signal<br>resets all PowerSpan II<br>resources, including PLL's.<br>Additionally, all PowerSpan II<br>outputs are tristated when<br>this pin is negated; inputs and<br>bidirects are inhibited. This<br>signal must be pulled low in a<br>non-Hot Swap application. |
| PO_RST_  | Input<br>(5 V tolerant<br>LVTTL)<br>(Schmitt trigger)  | -           | -                                                                     | <b>Power On Reset:</b> Assertion<br>of this signal resets all<br>PowerSpan II resources,<br>including PLL's.                                                                                                                                                                                                                                                                                                                                   |
| I2C_SCLK | Open drain<br>output<br>(5 V tolerant<br>LVTTL)        | Hi-Z        | Pull-up resistor                                                      | Serial Clock: EEPROM<br>Serial clock. This pin must be<br>pulled high even if an<br>EEPROM is not installed on<br>the board.                                                                                                                                                                                                                                                                                                                   |
| I2C_SDA  | Bidirectional<br>open drain<br>(5 V tolerant<br>LVTTL) | Hi-Z        | Pull-up resistor                                                      | Serial Data: EPROM Serial<br>data line. This pin must be<br>pulled high even if an<br>EEPROM is not installed on<br>the board.                                                                                                                                                                                                                                                                                                                 |
|          |                                                        |             |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Vdd CORE | Supply                                                 | -           | -                                                                     | Core Vdd: Nominally 2.5V                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Vdd I/O  | Supply                                                 | -           | -                                                                     | IO Vdd: Nominally 3.3V                                                                                                                                                                                                                                                                                                                                                                                                                         |
| VSS      | Supply                                                 | -           | -                                                                     | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                         |

a. Refer to the CompactPCI Hot Swap Specification for information on these signals.

## 11.1.6 Test Signals

Table 64 lists PowerSpan II signals used to support silicon or board level testing.

#### Table 64: Test Signals

| Pin Name | Pin Type                                                                                                                                                                                          | Reset State                     | Recommended<br>Termination | Description                                                                                                         |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------|
| PI_TEST1 | Input                                                                                                                                                                                             | Internal pull-<br>down resistor | Pull-down<br>resistor      | PLL Test 1: Internal PLL<br>test signal. This is for<br>internal Tundra use.                                        |
| PI_TEST2 | Input                                                                                                                                                                                             | Internal pull-<br>down resistor | Pull-down<br>resistor      | <b>PLL Test 2:</b> Internal PLL<br>test signal. This is for<br>internal Tundra use.                                 |
| P2_TEST1 | Input<br>Note: This signal<br>is present in both<br>the Single PCI<br>PowerSpan II<br>and the Dual PCI<br>PowerSpan II.<br>The signal is<br>used for both<br>PCI-1 and PCI-2<br>internal testing. | Internal pull-<br>down resistor | Pull-down<br>resistor      | PLL Test 1: Internal PLL<br>test signal. This is for<br>internal Tundra use.                                        |
| P2_TEST2 | Input                                                                                                                                                                                             | Internal pull-<br>down resistor | Pull-down<br>resistor      | <b>PLL Test 2:</b> Internal PLL<br>test signal. This is for<br>internal Tundra use.                                 |
| PB_TEST1 | Input                                                                                                                                                                                             | Internal pull-<br>down resistor | Pull-down<br>resistor      | PLL Test 1: Internal PLL<br>test signal. This is for<br>internal Tundra use.                                        |
| PB_TEST2 | Input                                                                                                                                                                                             | Internal pull-<br>down resistor | Pull-down<br>resistor      | PLL Test 2: Internal PLL<br>test signal. This is for<br>internal Tundra use.                                        |
| тск      | Input<br>(LVTTL)                                                                                                                                                                                  | Hi-Z                            | -                          | <b>Test Clock (JTAG):</b> Used to clock state information and data into and out of the device during boundary scan. |

#### Table 64: Test Signals

| Pin Name | Pin Type                              | Reset State                     | Recommended<br>Termination                                                                                                                  | Description                                                                                                                                                                                                                                                                                                                                                  |
|----------|---------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMS      | Input<br>(LVTTL)                      | Internal pull-up<br>resistor    | -                                                                                                                                           | Test Mode Select (JTAG):<br>Used to control the state of<br>the Test Access Port<br>controller                                                                                                                                                                                                                                                               |
| TDI      | Input<br>(LVTTL)                      | Internal pull-up<br>resistor    | -                                                                                                                                           | <b>Test Data Input (JTAG):</b><br>Used (in conjunction with<br>TCK) to shift data and<br>instructions into the Test<br>Access Port (TAP) in a<br>serial bit stream.                                                                                                                                                                                          |
| TDO      | Tristate output<br>(LVTTL)            | Hi-Z                            | -                                                                                                                                           | <b>Test Data Output (JTAG):</b><br>Used (in conjunction with<br>TCK) to shift data and<br>instructions into the Test<br>Access Port (TAP) in a<br>serial bit stream.                                                                                                                                                                                         |
| TRST_    | Input<br>(LVTTL)<br>(Schmitt trigger) | Internal pull-up<br>resistor    | Pull-down<br>resistor if JTAG<br>is not used in the<br>system.<br>Otherwise the<br>signal must be<br>toggled with the<br>PO_RST_<br>signal. | Test Reset (JTAG):<br>Asynchronous reset for the<br>JTAG controller. This pin<br>must be asserted during<br>the power-up reset<br>sequence to ensure that the<br>Boundary Scan Register<br>elements are configured for<br>normal system operation.<br>Customers must assert<br>TRST _concurrently with<br>PO_RST_ as part of the<br>power-up reset sequence. |
| TE       | Input                                 | Internal pull-<br>down resistor | Pull-down<br>resistor                                                                                                                       | <b>Test Enable:</b> Enables<br>manufacturing test. Tundra<br>recommends that system<br>designers pull this signal<br>low.                                                                                                                                                                                                                                    |

# **11.2Dual PCI PowerSpan II Pinout**11.2.1Dual PCI PowerSpan II 480 HSBGA

Figure 24 illustrates the top, side, and bottom views of the PowerSpan II package.

#### Table 65: Package Characteristics

| Feature             | Description                  |  |
|---------------------|------------------------------|--|
| Package Type        | 480 HSBGA                    |  |
| Package Body Size   | 37.5mm                       |  |
| JEDEC Specification | JEDEC MO-151 Variation BAT-1 |  |

Detail A

0.56 REF.

#### Figure 24: 480 HSBGA



#### 11.2.1.1 **Package Notes**

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M - 1994
- Conforms to JEDEC MO-151 Variation BAT-1 3.

## 11.2.2 480 HSBGA Pin Information

The following table shows the PowerSpan II 480 HSBGA, 1.27 mm package, pin information. This package is backwards compatible with the original PowerSpan's 480 HPBGA device.

| A1. VSS_IO      | G25. VDD25       | AC25. VDD25       |
|-----------------|------------------|-------------------|
| A2. VSS_IO      | G26. P1_AD[9]    | AC26. P2_TEST1    |
| A3. PB_A[12]    | G27. PCI_GNT[5]_ | AC27. P2_AD[9]    |
| A4. PB_A[14]    | G28. P1_GNT[4]_  | AC28. P2_AD[8]    |
| A5. PB_A[16]    | G29. VSS_IO      | AC29. VSS_IO      |
| A6. PB_A[18]    | H1. INT[4]_      | AD1. PB_D[60]     |
| A7. VSS_IO      | H2. PB_A[0]      | AD2. PB_D[52]     |
| A8. PB_A[21]    | H3. PB_A[1]      | AD3. PB_D[44]     |
| A9. PB_A[24]    | H4. PB_BR2_      | AD4. JT_TRST_     |
| A10. PB_A[27]   | H5. VDD25        | AD5. VDD25        |
| A11. PB_A[31]   | H25. VDD25       | AD25. VDD25       |
| A12. VSS_IO     | H26. VSS         | AD26. PCI_GNT[7]_ |
| A13. P1_AD[34]  | H27. P1_AD[12]   | AD27. P2_AD[12]   |
| A14. P1_AD[38]  | H28. P1_AD[11]   | AD28. P2_AD[11]   |
| A15. P1_AD[41]  | H29. P1_AD[10]   | AD29. P2_AD[10]   |
| A16. VSS_IO     | J1. PB_TT[1]     | AE1. PB_D[20]     |
| A17. P1_AD[48]  | J2. HEALTHY_     | AE2. PB_TEST1     |
| A18. VSS_IO     | J3. PB_TT[2]     | AE3. PB_D[12]     |
| A19. P1_AD[53]  | J4. PB_TT[3]     | AE4. PB_BG2_      |
| A20. P1_AD[56]  | J5. VSS          | AE5. PB_AVSS      |
| A21. P1_AD[59]  | J25. VSS         | AE6. PB_DVDD      |
| A22. P1_AD[62]  | J26. VSS         | AE7. VDD25        |
| A23. VSS_IO     | J27. P1_INTA_    | AE8. VDD25        |
| A24. P1_CBE[6]_ | J28. PCI_GNT[6]_ | AE9. VSS          |
| A25. P1_VDDA    | J29. P1_AD[13]   | AE10. VDD33       |
| A26. P1_REQ64_  | K1. PB_AACK_     | AE11. VDD33       |
|                 |                  |                   |

| A27. P1_AD[0]   | K2. PB_TT[4]    | AE12. VDD33     |
|-----------------|-----------------|-----------------|
| A28. VSS_IO     | K3. VSS         | AE13. VSS       |
| A29. VSS_IO     | K4. PB_TT[0]    | AE14. VDD25     |
| B1. VSS_IO      | K5. VDD33       | AE15. VDD25     |
| B2. VSS_IO      | K25. VDD33      | AE16. VDD25     |
| B3. PB_A[13]    | K26. P1_PAR     | AE17. VSS       |
| B4. PB_A[15]    | K27. P1_CBE[1]_ | AE18. VDD33     |
| B5. VSS_IO      | K28. P1_AD[15]  | AE19. VDD33     |
| B6. JT_TMS      | K29. P1_AD[14]  | AE20. VDD33     |
| B7. P1_RST_DIR  | L1. PB_ARTRY_   | AE21. VSS       |
| B8. PB_A[22]    | L2. PB_TSIZ[3]  | AE22. VDD25     |
| B9. PB_A[26]    | L3. PB_BG1_     | AE23. VDD25     |
| B10. PB_A[28]   | L4. PB_BR3_     | AE24. P2_DVDD   |
| B11. PB_CI_     | L5. VDD33       | AE25. P2_AVSS   |
| B12. P1_AD[32]  | L25. VDD33      | AE26. P2_AD[14] |
| B13. P1_AD[35]  | L26. P1_TRDY_   | AE27. P2_AD[13] |
| B14. VSS_IO     | L27. P1_DEVSEL_ | AE28. P2_TEST2  |
| B15. P1_AD[42]  | L28. P1_STOP_   | AE29. P2_IDSEL  |
| B16. P1_AD[45]  | L29. P1_PERR_   | AF1. PB_D[36]   |
| B17. P1_AD[49]  | M1. VSS_IO      | AF2. PB_D[28]   |
| B18. P1_AD[50]  | M2. PB_TSIZ[2]  | AF3. INT[3]_    |
| B19. P1_AD[54]  | M3. PB_TSIZ[1]  | AF4. PB_DVSS    |
| B20. P1_AD[57]  | M4. PB_TS_      | AF5. PB_CLK     |
| B21. P1_IDSEL   | M5. VDD33       | AF6. INT[1]_    |
| B22. P1_AD[63]  | M25. VDD33      | AF7. VSS        |
| B23. P1_CBE[4]_ | M26. P1_CBE[2]_ | AF8. PB_VDDA    |
| B24. P1_CBE[7]_ | M27. P1_FRAME_  | AF9. PB_D[26]   |
| B25. P1_TEST2   | M28. P1_IRDY_   | AF10. PB_D[57]  |
| B26. P1_ACK64_  | M29. VSS_IO     | AF11. INT[0]_   |
|                 |                 |                 |

| B27. P1_CLK     | N1. PB_AP[3]    | AF12. PB_D[25]    |
|-----------------|-----------------|-------------------|
| B28. VSS_IO     | N2. PB_TSIZ[0]  | AF13. PB_D[1]     |
| B29. VSS_IO     | N3. I2C_SCLK    | AF14. PB_FAST     |
| C1. PB_A[11]    | N4. PB_TBST_    | AF15. PB_D[24]    |
| C2. TE          | N5. VSS         | AF16. PB_DP[7]    |
| C3. VSS         | N25. VSS        | AF17. PB_DP[4]    |
| C4. JT_TCK      | N26. P1_AD[19]  | AF18. PB_DP[1]    |
| C5. PB_A[17]    | N27. P1_AD[18]  | AF19. P2_RST_     |
| C6. PB_A[19]    | N28. P1_AD[17]  | AF20. P2_AD[28]   |
| C7. PB_DBG2_    | N29. P1_AD[16]  | AF21. P2_AD[24]   |
| C8. PB_A[23]    | P1. VSS_IO      | AF22. VSS         |
| C9. PB_A[25]    | P2. PB_AP[1]    | AF23. P2_AD[19]   |
| C10. PB_A[29]   | P3. PB_AP[2]    | AF24. P2_SERR_    |
| C11. PB_DBG1_   | P4. I2C_SDA     | AF25. P2_CLK      |
| C12. P1_AD[33]  | P5. VDD25       | AF26. P2_DVSS     |
| C13. P1_AD[36]  | P25. VDD25      | AF27. P2_INTA_    |
| C14. P1_AD[39]  | P26. P1_AD[22]  | AF28. P2_CBE[1]_  |
| C15. P1_AD[43]  | P27. P1_AD[21]  | AF29. P2_AD[15]   |
| C16. P1_AD[46]  | P28. VSS_IO     | AG1. PB_D[43]     |
| C17. P1_SERR_   | P29. P1_AD[20]  | AG2. PB_D[35]     |
| C18. P1_AD[51]  | R1. PB_TA_      | AG3. VSS          |
| C19. P1_AD[55]  | R2. PB_DVAL_    | AG4. INT[2]_      |
| C20. P1_REQ[4]_ | R3. PB_TEA_     | AG5. PB_D[3]      |
| C21. P1_AD[60]  | R4. PB_AP[0]    | AG6. PB_D[11]     |
| C22. P1_PAR64   | R5. VDD25       | AG7. PB_D[42]     |
| C23. P1_CBE[5]_ | R25. VDD25      | AG8. PB_D[58]     |
| C24. P1_REQ1_   | R26. P1_AD[25]  | AG9. PB_D[18]     |
| C25. P1_GNT1_   | R27. P1_AD[24]  | AG10. PB_ABB_     |
| C26. P1_64EN_   | R28. P1_CBE[3]_ | AG11. PB_RSTCONF_ |
|                 |                 |                   |

| C27. VSS        | R29. P1_AD[23]  | AG12. PB_D[17]   |
|-----------------|-----------------|------------------|
| C28. P1_AD[2]   | T1. PB_D[15]    | AG13. PB_RST_    |
| C29. P1_AD[1]   | T2. VSS_IO      | AG14. PB_D[40]   |
| D1. PB_A[8]     | T3. PB_D[30]    | AG15. PB_D[16]   |
| D2. PB_A[9]     | T4. PB_D[39]    | AG16. PB_DP[6]   |
| D3. PB_A[10]    | T5. VDD25       | AG17. PB_DP[3]   |
| D4. VSS         | T25. VDD25      | AG18. PB_DP[0]   |
| D5. JT_TDI      | T26. P1_AD[28]  | AG19. P2_AD[31]  |
| D6. JT_TDO      | T27. P1_AD[27]  | AG20. P2_AD[27]  |
| D7. PB_A[20]    | T28. P1_AD[26]  | AG21. P2_CBE[3]_ |
| D8. VSS         | T29. VSS_IO     | AG22. P2_AD[22]  |
| D9. VSS         | U1. LED_        | AG23. P2_AD[18]  |
| D10. PB_A[30]   | U2. PB_D[7]     | AG24. P2_AD[17]  |
| D11. PB_BR1_    | U3. PB_D[22]    | AG25. P2_FRAME_  |
| D12. PB_GBL_    | U4. PB_D[47]    | AG26. P2_REQ[2]_ |
| D13. P1_AD[37]  | U5. VSS         | AG27. VSS        |
| D14. P1_AD[40]  | U25. VSS        | AG28. P2_REQ[3]_ |
| D15. P1_AD[44]  | U26. P1_AD[31]  | AG29. P2_PAR     |
| D16. P1_AD[47]  | U27. VSS        | AH1. VSS_IO      |
| D17. P1_M66EN   | U28. P1_AD[30]  | AH2. VSS_IO      |
| D18. P1_AD[52]  | U29. P1_AD[29]  | AH3. NC          |
| D19. P1_REQ[3]_ | V1. VSS_IO      | AH4. PB_D[59]    |
| D20. P1_AD[58]  | V2. PB_D[6]     | AH5. PB_TEST2    |
| D21. P1_AD[61]  | V3. PB_D[55]    | AH6. PB_D[19]    |
| D22. ENUM_      | V4. PB_D[23]    | AH7. PB_D[50]    |
| D23. P1_TEST1   | V5. VDD33       | AH8. PB_D[34]    |
| D24. P1_GNT[2]_ | V25. VDD33      | AH9. VSS_IO      |
| D25. P1_GNT[3]_ | V26. P2_GNT[3]_ | AH10. PB_D[49]   |
| D26. P1_DVSS    | V27. P2_GNT[4]_ | AH11. PB_D[41]   |
|                 |                 |                  |

| D27. P1_REQ[2]_  | V28. P1_RST_     | AH12. PB_D[9]   |
|------------------|------------------|-----------------|
| D28. P1_AD[4]    | V29. VSS_IO      | AH13. PB_D[56]  |
| D29. P1_AD[3]    | W1. PB_D[31]     | AH14. PB_D[32]  |
| E1. PB_DBG3_     | W2. PB_D[62]     | AH15. PB_D[8]   |
| E2. VSS_IO       | W3. PB_D[54]     | AH16. VSS_IO    |
| E3. PB_A[7]      | W4. PB_D[46]     | AH17. PB_DP[2]  |
| E4. ES           | W5. VDD33        | AH18. PB_D[63]  |
| E5. VSS          | W25. VDD33       | AH19. P2_AD[30] |
| E6. VDD25        | W26. P2_AD[0]    | AH20. P2_AD[26] |
| E7. VDD25        | W27. P2_REQ1_    | AH21. VSS_IO    |
| E8. VDD25        | W28. P2_GNT1_    | AH22. P2_AD[21] |
| E9. VSS          | W29. P2_GNT[2]_  | AH23. P2_VDDA   |
| E10. VDD33       | Y1. PB_D[21]     | AH24. P2_AD[16] |
| E11. VDD33       | Y2. PB_D[38]     | AH25. VSS_IO    |
| E12. VDD33       | Y3. PB_D[14]     | AH26. P2_TRDY_  |
| E13. VSS         | Y4. PB_D[53]     | AH27. P2_STOP_  |
| E14. VDD25       | Y5. VDD33        | AH28. VSS_IO    |
| E15. VDD25       | Y25. VDD33       | AH29. VSS_IO    |
| E16. VDD25       | Y26. P2_AD[3]    | AJ1. VSS_IO     |
| E17. VSS         | Y27. PCI_REQ[7]_ | AJ2. VSS_IO     |
| E18. VDD33       | Y28. P2_AD[2]    | AJ3. PB_D[51]   |
| E19. VDD33       | Y29. P2_AD[1]    | AJ4. PB_D[4]    |
| E20. VDD33       | AA1. PB_D[37]    | AJ5. PB_DBB_    |
| E21. VSS         | AA2. NC          | AJ6. PB_D[27]   |
| E22. VDD25       | AA3. PB_D[29]    | AJ7. VSS_IO     |
| E23. VDD25       | AA4. VSS         | AJ8. PB_D[10]   |
| E24. P1_DVDD     | AA5. VSS         | AJ9. PB_D[2]    |
| E25. P1_AVSS     | AA25. VSS        | AJ10. PO_RST_   |
| E26. PCI_REQ[5]_ | AA26. P2_AD[5]   | AJ11. PB_D[33]  |
|                  |                  |                 |

| E27. P1_AD[6]    | AA27. P2_AD[4]   | AJ12. VSS_IO     |
|------------------|------------------|------------------|
| E28. VSS_IO      | AA28. VSS_IO     | AJ13. PB_D[48]   |
| E29. P1_AD[5]    | AA29. P2_M66EN   | AJ14. VSS_IO     |
| F1. PB_A[4]      | AB1. PB_D[5]     | AJ15. PB_D[0]    |
| F2. PB_A[5]      | AB2. PB_D[61]    | AJ16. PB_DP[5]   |
| F3. PB_A[6]      | AB3. PB_D[45]    | AJ17. P2_RST_DIR |
| F4. PB_RST_DIR   | AB4. VSS         | AJ18. VSS_IO     |
| F5. VDD25        | AB5. VDD25       | AJ19. P2_AD[29]  |
| F25. VDD25       | AB25. VDD25      | AJ20. P2_AD[25]  |
| F26. PCI_REQ[6]_ | AB26. P2_REQ[4]_ | AJ21. P2_AD[23]  |
| F27. P1_AD[8]    | AB27. P2_CBE[0]_ | AJ22. P2_AD[20]  |
| F28. P1_CBE[0]_  | AB28. P2_AD[7]   | AJ23. VSS_IO     |
| F29. P1_AD[7]    | AB29. P2_AD[6]   | AJ24. P2_CBE[2]_ |
| G1. VSS_IO       | AC1. VSS_IO      | AJ25. P2_IRDY_   |
| G2. PB_A[2]      | AC2. PB_BG3_     | AJ26. P2_DEVSEL_ |
| G3. PB_A[3]      | AC3. INT[5]_     | AJ27. P2_PERR_   |
| G4. VSS          | AC4. PB_D[13]    | AJ28. VSS_IO     |
| G5. VDD25        | AC5. VDD25       | AJ29. VSS_IO     |

### 11.2.3 Dual PCI PowerSpan II 504 HSBGA

Figure 25 illustrates the top, side, and bottom views of the PowerSpan II package.

### Table 66: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 504 HSBGA                    |
| Package Body Size   | 27mm                         |
| JEDEC Specification | JEDEC MO-151 Variation AAL-1 |

Detail A

\_\_\_\_\_0,15 C

0.56 REF.

// 0.15 C

### Figure 25: 504 HSBGA



#### 11.2.3.1 **Package Notes**

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M - 1994
- 3. Conforms to JEDEC MO-151 Variation AAL-1

### 11.2.4 504 HSBGA Pin Information

The following table shows the PowerSpan II 504 HSBG, 1.00 mm package, pin information.

| A3. JT_TDO      | H21. VDD25      | W21. VDD25       |
|-----------------|-----------------|------------------|
| A4. PB_A[19]    | H22. VDD25      | W22. VDD25       |
| A5. JT_TMS      | H23. P1_CBE[0]_ | W23. P2_IDSEL    |
| A6. PB_A[21]    | H24. P1_INTA_   | W24. P2_AD[5]    |
| A7. PB_A[24]    | H25. P1_AD[15]  | W25. PCI_REQ[7]_ |
| A8. PB_CI_      | H26. P1_CBE[2]_ | W26. P2_REQ[1]_  |
| A9. P1_AD[33]   | J1. PB_ARTRY_   | Y1. PB_D[53]     |
| A10. P1_AD[32]  | J2. PB_BR3_     | Y2. PB_D[61]     |
| A11. P1_AD[35]  | J3. INT[4]_     | Y3. PB_D[60]     |
| A12. P1_AD[40]  | J4. PB_BR2_     | Y4. JT_TRST_     |
| A13. P1_AD[42]  | J5. VDD25       | Y5. PB_D[35]     |
| A14. P1_AD[43]  | J6. VDD25       | Y6. VDD33        |
| A15. P1_AD[45]  | J21. VDD25      | Y21. VDD33       |
| A16. P1_SERR_   | J22. VDD25      | Y22. P2_PAR      |
| A17. P1_AD[52]  | J23. P1_GNT[4]_ | Y23. P2_AD[15]   |
| A18. P1_AD[53]  | J24. P1_AD[13]  | Y24. P2_AD[8]    |
| A19. P1_AD[56]  | J25. P1_DEVSEL_ | Y25. P2_AD[6]    |
| A20. P1_AD[58]  | J26. P1_IRDY_   | Y26. P2_M66EN    |
| A21. P1_AD[61]  | K1. PB_TS_      | AA1. PB_D[45]    |
| A22. P1_CBE[7]_ | K2. PB_TSIZ[3]  | AA2. INT[5]_     |
| A23. P1_GNT[2]_ | K3. PB_TT[1]    | AA3. PB_D[20]    |
| A24. P1_ACK64_  | K4. PB_TT[2]    | AA4. PB_D[28]    |
| B2. VSS_IO      | K5. VDD33       | AA5. PB_BG2_     |
| B3. VSS_IO      | K6. VDD33       | AA6. PB_DVDD     |
| B4. PB_A[15]    | K21. VDD33      | AA7. VDD33       |
| B5. PB_A[20]    | K22. VDD33      | AA8. VDD25       |
|                 |                 |                  |

| B6. PB_A[23]    | K23. PCI_GNT[6]_ | AA9. VDD25       |
|-----------------|------------------|------------------|
| B7. PB_A[25]    | K24. P1_TRDY_    | AA10. VDD33      |
| B8. PB_A[29]    | K25. P1_FRAME_   | AA11. VDD33      |
| B9. PB_DBG1_    | K26. P1_AD[19]   | AA12. VSS        |
| B10. PB_GBL_    | L1. I2C_SCLK     | AA13. VSS        |
| B11. P1_AD[36]  | L2. PB_TBST_     | AA14. VSS        |
| B12. P1_AD[34]  | L3. PB_BG1_      | AA15. VSS        |
| B13. P1_AD[41]  | L4. PB_TT[4]     | AA16. VDD33      |
| B14. P1_AD[44]  | L5. VDD33        | AA17. VDD33      |
| B15. P1_AD[49]  | L6. VDD33        | AA18. VDD25      |
| B16. P1_M66EN   | L11. VSS_IO      | AA19. VDD25      |
| B17. P1_AD[54]  | L12. VSS_IO      | AA20. VDD33      |
| B18. P1_REQ[3]_ | L13. VSS_IO      | AA21. P2_DVDD    |
| B19. P1_AD[59]  | L14. VSS_IO      | AA22. P2_INTA_   |
| B20. P1_AD[63]  | L15. VSS_IO      | AA23. P2_AD[13]  |
| B21. P1_CBE[6]_ | L16. VSS_IO      | AA24. P2_AD[9]   |
| B22. P1_REQ64_  | L21. VDD33       | AA25. P2_CBE[0]_ |
| B23. P1_64EN_   | L22. VDD33       | AA26. P2_AD[7]   |
| B24. VSS_IO     | L23. P1_AD[14]   | AB1. PB_D[13]    |
| B25. VSS_IO     | L24. P1_PERR_    | AB2. PB_D[12]    |
| C1. PB_A[9]     | L25. P1_AD[16]   | AB3. INT[3]_     |
| C2. VSS_IO      | L26. P1_AD[22]   | AB4. PB_TEST1    |
| C3. VSS         | M1. PB_AP[1]     | AB5. VSS_IO      |
| C4. PB_A[13]    | M2. PB_AP[3]     | AB6. INT[2]_     |
| C5. PB_A[12]    | M3. PB_TSIZ[1]   | AB7. PB_TEST2    |
| C6. PB_DBG2_    | M4. PB_TSIZ[0]   | AB8. VDD25       |
| C7. P1_RST_DIR  | M5. PB_TSIZ[2]   | AB9. VDD25       |
| C8. PB_A[22]    | M6. VSS          | AB10. VDD33      |
| C9. PB_A[30]    | M11. VSS_IO      | AB11. VDD33      |
|                 |                  |                  |

| C10. PB_A[28]   | M12. VSS_IO      | AB12. PB_D[49]   |
|-----------------|------------------|------------------|
| C11. PB_A[31]   | M13. VSS_IO      | AB13. VSS        |
| C12. P1_AD[37]  | M14. VSS_IO      | AB14. VSS        |
| C13. P1_AD[39]  | M15. VSS_IO      | AB15. P2_CBE[3]_ |
| C14. P1_AD[47]  | M16. VSS_IO      | AB16. VDD33      |
| C15. P1_AD[50]  | M21. VSS         | AB17. VDD33      |
| C16. P1_AD[55]  | M22. P1_STOP_    | AB18. VDD25      |
| C17. P1_REQ[4]_ | M23. P1_AD[17]   | AB19. VDD25      |
| C18. P1_AD[62]  | M24. P1_AD[18]   | AB20. P2_REQ[3]_ |
| C19. P1_PAR64   | M25. P1_AD[21]   | AB21. P2_TEST1   |
| C20. P1_CBE[4]_ | M26. P1_AD[23]   | AB22. VSS_IO     |
| C21. P1_CBE[5]_ | N1. PB_DVAL_     | AB23. P2_TEST2   |
| C22. P1_CLK     | N2. PB_TA_       | AB24. P2_AD[14]  |
| C23. P1_AVSS    | N3. PB_AP[2]     | AB25. P2_AD[12]  |
| C24. P1_VDDA    | N4. I2C_SDA      | AB26. P2_AD[10]  |
| C25. VSS_IO     | N5. VSS          | AC1. PB_D[36]    |
| C26. P1_AD[4]   | N6. VSS          | AC2. VSS_IO      |
| D1. PB_A[6]     | N11. VSS_IO      | AC3. VSS_IO      |
| D2. PB_A[11]    | N12. VSS_IO      | AC4. VSS_IO      |
| D3. TE          | N13. VSS_IO      | AC5. PB_DVSS     |
| D4. VSS         | N14. VSS_IO      | AC6. INT[1]_     |
| D5. JT_TDI      | N15. VSS_IO      | AC7. PB_D[3]     |
| D6. PB_A[17]    | N16. VSS_IO      | AC8. PB_D[11]    |
| D7. PB_A[14]    | N21. VSS         | AC9. PB_D[42]    |
| D8. PB_A[16]    | N22. VSS         | AC10. PB_D[10]   |
| D9. PB_A[18]    | N23. PCI_REQ[5]_ | AC11. PO_RST_    |
| D10. PB_A[26]   | N24. P1_AD[20]   | AC12. PB_D[25]   |
| D11. PB_A[27]   | N25. P1_CBE[3]_  | AC13. PB_D[40]   |
| D12. P1_AD[38]  | N26. P1_AD[24]   | AC14. PB_DP[5]   |
|                 |                  |                  |

| D13. P1_AD[46]  | P1. PB_TEA_      | AC15. PB_DP[4]   |
|-----------------|------------------|------------------|
| D14. P1_AD[48]  | P2. PB_D[15]     | AC16. P2_AD[26]  |
| D15. P1_AD[51]  | P3. PB_D[39]     | AC17. P2_AD[21]  |
| D16. P1_AD[57]  | P4. PB_AP[0]     | AC18. P2_IRDY_   |
| D17. P1_AD[60]  | P5. VSS          | AC19. P2_DEVSEL_ |
| D18. ENUM_      | P6. VSS          | AC20. P2_TRDY_   |
| D19. P1_REQ[1]_ | P11. VSS_IO      | AC21. P2_PERR_   |
| D20. P1_GNT[1]_ | P12. VSS_IO      | AC22. P2_DVSS    |
| D21. P1_GNT[3]_ | P13. VSS_IO      | AC23. VSS_IO     |
| D22. P1_DVSS    | P14. VSS_IO      | AC24. VSS_IO     |
| D23. VSS_IO     | P15. VSS_IO      | AC25. VSS_IO     |
| D24. VSS_IO     | P16. VSS_IO      | AC26. P2_AD[11]  |
| D25. VSS_IO     | P21. VSS         | AD1. PB_D[43]    |
| D26. P1_AD[8]   | P22. VSS         | AD2. VSS_IO      |
| E1. PB_A[3]     | P23. P1_AD[28]   | AD3. PB_VDDA     |
| E2. PB_RST_DIR  | P24. PCI_GNT[7]_ | AD4. PB_AVSS     |
| E3. PB_A[10]    | P25. PCI_REQ[6]_ | AD5. PB_CLK      |
| E4. ES          | P26. P1_AD[25]   | AD6. PB_D[19]    |
| E5. VSS         | R1. PB_D[30]     | AD7. PB_D[50]    |
| E6. VSS         | R2. LED_         | AD8. PB_D[26]    |
| E7. JT_TCK      | R3. PB_D[6]      | AD9. PB_D[57]    |
| E8. VDD25       | R4. PB_D[47]     | AD10. INT[0]_    |
| E9. VDD25       | R5. PB_D[37]     | AD11. PB_D[33]   |
| E10. VDD33      | R6. VSS          | AD12. PB_RST_    |
| E11. VDD33      | R11. VSS_IO      | AD13. PB_D[32]   |
| E12. PB_BR1_    | R12. VSS_IO      | AD14. P2_RST_DIR |
| E13. VSS        | R13. VSS_IO      | AD15. PB_D[63]   |
| E14. VSS        | R14. VSS_IO      | AD16. P2_AD[31]  |
| E15. P1_IDSEL   | R15. VSS_IO      | AD17. P2_AD[27]  |
|                 |                  |                  |

| E16. VDD33    | R16. VSS_IO      | AD18. P2_AD[20]  |
|---------------|------------------|------------------|
| E17. VDD33    | R21. VSS         | AD19. P2_CBE[2]_ |
| E18. VDD25    | R22. P2_AD[1]    | AD20. P2_AD[18]  |
| E19. VDD25    | R23. P1_AD[29]   | AD21. P2_AD[19]  |
| E20. P1_TEST2 | R24. P1_AD[31]   | AD22. P2_CLK     |
| E21. P1_TEST1 | R25. P1_AD[27]   | AD23. P2_AVSS    |
| E22. VSS_IO   | R26. PCI_GNT[5]_ | AD24. P2_VDDA    |
| E23. P1_AD[0] | T1. PB_D[7]      | AD25. VSS_IO     |
| E24. P1_AD[2] | T2. PB_D[22]     | AD26. P2_CBE[1]_ |
| E25. P1_AD[9] | T3. PB_D[62]     | AE2. VSS_IO      |
| E26. P1_AD[7] | T4. PB_D[21]     | AE3. VSS_IO      |
| F1. PB_A[0]   | T5. VDD33        | AE4. PB_D[51]    |
| F2. PB_A[2]   | T6. VDD33        | AE5. PB_D[4]     |
| F3. PB_DBG3_  | T11. VSS_IO      | AE6. PB_D[58]    |
| F4. PB_A[7]   | T12. VSS_IO      | AE7. PB_D[18]    |
| F5. VSS       | T13. VSS_IO      | AE8. PB_ABB_     |
| F6. VDD33     | T14. VSS_IO      | AE9. PB_RSTCONF_ |
| F7. VDD33     | T15. VSS_IO      | AE10. PB_D[17]   |
| F8. VDD25     | T16. VSS_IO      | AE11. PB_D[56]   |
| F9. VDD25     | T21. VDD33       | AE12. PB_FAST    |
| F10. VDD33    | T22. VDD33       | AE13. PB_D[16]   |
| F11. VDD33    | T23. P2_AD[0]    | AE14. PB_DP[6]   |
| F12. VSS      | T24. P2_GNT[2]_  | AE15. PB_DP[2]   |
| F13. VSS      | T25. P1_AD[30]   | AE16. PB_DP[0]   |
| F14. VSS      | T26. P1_AD[26]   | AE17. P2_AD[30]  |
| F15. VSS      | U1. PB_D[55]     | AE18. P2_RST_    |
| F16. VDD33    | U2. PB_D[31]     | AE19. P2_AD[23]  |
| F17. VDD33    | U3. PB_D[38]     | AE20. P2_AD[24]  |
| F18. VDD25    | U4. PB_D[5]      | AE21. P2_AD[16]  |
|               |                  |                  |

| F19. VDD25      | U5. VDD33       | AE22. P2_SERR_   |
|-----------------|-----------------|------------------|
| F20. VDD33      | U6. VDD33       | AE23. P2_REQ[2]_ |
| F21. P1_DVDD    | U21. VDD33      | AE24. VSS_IO     |
| F22. P1_REQ[2]_ | U22. VDD33      | AE25. VSS_IO     |
| F23. P1_AD[1]   | U23. P2_AD[4]   | AF3. PB_D[59]    |
| F24. P1_AD[5]   | U24. P2_AD[2]   | AF4. PB_DBB_     |
| F25. P1_AD[11]  | U25. P2_GNT[3]_ | AF5. PB_D[27]    |
| F26. P1_AD[10]  | U26. P1_RST_    | AF6. PB_D[34]    |
| G1. HEALTHY_    | V1. PB_D[23]    | AF7. PB_D[2]     |
| G2. PB_TT[3]    | V2. PB_D[46]    | AF8. PB_D[41]    |
| G3. PB_A[4]     | V3. PB_D[29]    | AF9. PB_D[9]     |
| G4. PB_A[8]     | V4. PB_D[52]    | AF10. PB_D[1]    |
| G5. VSS         | V5. VDD25       | AF11. PB_D[48]   |
| G6. VDD33       | V6. VDD25       | AF12. PB_D[24]   |
| G21. VDD33      | V21. VDD25      | AF13. PB_D[8]    |
| G22. P1_AD[6]   | V22. VDD25      | AF14. PB_D[0]    |
| G23. P1_AD[3]   | V23. P2_REQ[4]_ | AF15. PB_DP[7]   |
| G24. P1_AD[12]  | V24. P2_AD[3]   | AF16. PB_DP[3]   |
| G25. P1_PAR     | V25. P2_GNT[1]_ | AF17. PB_DP[1]   |
| G26. P1_CBE[1]_ | V26. P2_GNT[4]_ | AF18. P2_AD[29]  |
| H1. PB_AACK_    | W1. PB_D[54]    | AF19. P2_AD[25]  |
| H2. PB_TT[0]    | W2. PB_D[14]    | AF20. P2_AD[28]  |
| H3. PB_A[1]     | W3. PB_BG3_     | AF21. P2_AD[22]  |
| H4. PB_A[5]     | W4. PB_D[44]    | AF22. P2_AD[17]  |
| H5. VDD25       | W5. VDD25       | AF23. P2_FRAME_  |
| H6. VDD25       | W6. VDD25       | AF24. P2_STOP_   |

### 11.3 Single PCI PowerSpan II Pin Information

The PowerSpan II Single PCI device is offered in two packages. The 484 PBGA package is offered with a 23 mm body size and 1.00 mm ball pitch. The 420 HSBGA package is offered with a 35 mm body size and 1.27 mm ball pitch. The 35 mm body size is the same as the original PowerSpan package offering.

### 11.3.1 Single PCI PowerSpan II 420 HSBGA

Figure 26 illustrates the top, side, and bottom views of the PowerSpan II package.

### Table 67: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 420 HSBGA                    |
| Package Body Size   | 35mm                         |
| JEDEC Specification | JEDEC MO-151 Variation BAT-1 |



#### Figure 26: 420 HSBGA

### 11.3.1.1 Package Notes

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M 1994
- 3. Conforms to JEDEC MS-034 Variation BAR-1

### 11.3.2 420 HSBGA Pin Information

The following table shows the PowerSpan II 420 HSBGA, 1.27 mm package, pin information. This package is backwards compatible with the original PowerSpan's 420 HPBGA device.

| A1. VSS_IO      | G1. PB_TT[3]     | AA1. VSS_IO   |
|-----------------|------------------|---------------|
| A2. VSS_IO      | G2. PB_A[1]      | AA2. PB_D[36] |
| A3. JT_TDI      | G3. PB_A[5]      | AA3. PB_D[28] |
| A4. JT_TDO      | G4. PB_A[3]      | AA4. PB_D[12] |
| A5. JT_TCK      | G5. VDD33        | AA5. VDD33    |
| A6. VSS_IO      | G22. VDD33       | AA22. VDD33   |
| A7. PB_A[30]    | G23. P1_AD[6]    | AA23. VSS     |
| A8. P1_RST_DIR  | G24. P1_AD[1]    | AA24. VSS     |
| A9. VSS_IO      | G25. P1_AD[4]    | AA25. VSS_IO  |
| A10. PB_DBG1_   | G26. P1_AD[3]    | AA26. VSS_IO  |
| A11. VSS_IO     | H1. PB_BR3_      | AB1. INT[5]_  |
| A12. P1_AD[34]  | H2. PB_TT[2]     | AB2. PB_D[44] |
| A13. P1_AD[40]  | H3. PB_A[4]      | AB3. PB_D[43] |
| A14. P1_AD[44]  | H4. PB_A[2]      | AB4. PB_D[35] |
| A15. P1_AD[47]  | H5. VDD33        | AB5. VSS      |
| A16. VSS_IO     | H22. VDD33       | AB6. VDD33    |
| A17. P1_AD[50]  | H23. P1_AD[8]    | AB7. VDD33    |
| A18. P1_AD[51]  | H24. P1_AD[9]    | AB8. VDD33    |
| A19. P1_REQ[4]_ | H25. PCI_GNT[5]_ | AB9. VSS      |
| A20. P1_AD[59]  | H26. P1_TEST2    | AB10. PB_DVDD |
| A21. VSS_IO     | J1. HEALTHY_     | AB11. VDD25   |
| A22. P1_VDDA    | J2. VSS_IO       | AB12. VDD25   |
| A23. P1_CBE[7]_ | J3. PB_A[0]      | AB13. VSS_IO  |
| A24. P1_GNT[3]_ | J4. INT[4]_      | AB14. VSS_IO  |
| A25. P1_CLK     | J5. VSS          | AB15. VDD25   |
| A26. VSS_IO     | J22. VSS         | AB16. VDD25   |

| B1. TE          | J23. P1_CBE[0]_  | AB17. VDD25       |
|-----------------|------------------|-------------------|
| B2. VSS_IO      | J24. P1_AD[7]    | AB18. VSS         |
| B3. PB_A[13]    | J25. P1_GNT[4]_  | AB19. VDD33       |
| B4. PB_A[19]    | J26. PCI_GNT[6]_ | AB20. VDD33       |
| B5. PB_A[20]    | K1. PB_AACK_     | AB21. VDD33       |
| B6. PB_A[18]    | K2. PB_TT[4]     | AB22. VSS         |
| B7. PB_A[21]    | K3. PB_TT[0]     | AB23. PCI_GNT[7]_ |
| B8. PB_A[26]    | K4. PB_TT[1]     | AB24. VSS_IO      |
| B9. PB_DBG2_    | K5. VDD25        | AB25. VSS_IO      |
| B10. PB_BR1_    | K22. P1_DVDD     | AB26. NC          |
| B11. P1_AD[33]  | K23. P1_AD[12]   | AC1. JT_TRST_     |
| B12. P1_AD[32]  | K24. P1_AD[11]   | AC2. PB_D[53]     |
| B13. P1_AD[39]  | K25. P1_AD[10]   | AC3. PB_TEA_      |
| B14. P1_AD[41]  | K26. P1_AD[13]   | AC4. PB_AVSS      |
| B15. P1_AD[48]  | L1. VSS_IO       | AC5. NC           |
| B16. P1_AD[49]  | L2. PB_ARTRY_    | AC6. PB_D[3]      |
| B17. P1_AD[52]  | L3. PB_TSIZ[3]   | AC7. LED_         |
| B18. P1_REQ[3]_ | L4. PB_BG1_      | AC8. VSS          |
| B19. P1_AD[56]  | L5. VDD25        | AC9. PB_D[19]     |
| B20. P1_IDSEL   | L22. VDD25       | AC10. PB_D[27]    |
| B21. ENUM_      | L23. P1_INTA_    | AC11. PB_D[18]    |
| B22. NC         | L24. P1_PAR      | AC12. PB_D[57]    |
| B23. P1_GNT[1]_ | L25. P1_CBE[1]_  | AC13. PB_D[41]    |
| B24. P1_64EN_   | L26. VSS_IO      | AC14. PB_D[1]     |
| B25. VSS_IO     | M1. PB_TS_       | AC15. PB_FAST     |
| B26. VSS_IO     | M2. PB_TSIZ[1]   | AC16. PB_D[24]    |
| C1. PB_RST_DIR  | M3. PB_TBST_     | AC17. PB_DP[6]    |
| C2. PB_A[10]    | M4. PB_TSIZ[2]   | AC18. PB_DP[3]    |
| C3. VSS_IO      | M5. VDD25        | AC19. PB_D[63]    |
|                 |                  |                   |

| C4. PB_A[17]     | M22. VDD25      | AC20. PB_DP[5]  |
|------------------|-----------------|-----------------|
| C5. PB_A[15]     | M23. P1_AD[15]  | AC21. VSS       |
| C6. PB_A[16]     | M24. P1_AD[14]  | AC22. PB_D[8]   |
| C7. PB_A[22]     | M25. P1_AD[5]   | AC23. VSS       |
| C8. PB_A[25]     | M26. P1_AD[2]   | AC24. VSS_IO    |
| C9. PB_A[29]     | N1. I2C_SCLK    | AC25. P1_RST_   |
| C10. PB_A[27]    | N2. PB_TSIZ[0]  | AC26. P1_AD[31] |
| C11. PB_GBL_     | N3. PB_AP[3]    | AD1. INT[3]_    |
| C12. P1_AD[37]   | N4. PB_AP[2]    | AD2. PB_D[37]   |
| C13. VSS_IO      | N5. VSS_IO      | AD3. PB_DVSS    |
| C14. NC          | N22. VSS_IO     | AD4. PB_D[31]   |
| C15. P1_SERR_    | N23. P1_FRAME_  | AD5. PB_D[38]   |
| C16. P1_AD[53]   | N24. P1_CBE[2]_ | AD6. PB_D[14]   |
| C17. P1_AD[57]   | N25. P1_PERR_   | AD7. PB_D[11]   |
| C18. P1_AD[60]   | N26. P1_STOP_   | AD8. PB_D[51]   |
| C19. P1_AD[61]   | P1. PB_AP[1]    | AD9. PB_D[42]   |
| C20. P1_CBE[6]_  | P2. NC          | AD10. PB_D[50]  |
| C21. P1_CBE[5]_  | P3. PB_TA_      | AD11. PB_D[34]  |
| C22. P1_REQ[1]_  | P4. PB_AP[0]    | AD12. PB_D[2]   |
| C23. P1_AD[46]   | P5. VSS_IO      | AD13. PB_D[33]  |
| C24. VSS_IO      | P22. VSS_IO     | AD14. PB_D[9]   |
| C25. PB_CI_      | P23. P1_AD[17]  | AD15. PB_D[48]  |
| C26. PCI_REQ[5]_ | P24. P1_AD[18]  | AD16. P2_TEST1  |
| D1. PB_A[8]      | P25. P1_AD[19]  | AD17. PB_DP[7]  |
| D2. PB_A[11]     | P26. P1_IRDY_   | AD18. PB_DP[2]  |
| D3. PB_A[7]      | R1. VSS_IO      | AD19. PB_DP[4]  |
| D4. VSS          | R2. PB_D[47]    | AD20. PB_DP[1]  |
| D5. PB_A[12]     | R3. PB_D[22]    | AD21. PB_D[0]   |
| D6. PB_A[14]     | R4. PB_D[7]     | AD22. VSS       |
|                  |                 |                 |

| D7. JT_TMS      | R5. VDD25       | AD23. VSS_IO      |
|-----------------|-----------------|-------------------|
| D8. PB_A[23]    | R22. VDD25      | AD24. VSS_IO      |
| D9. PB_A[24]    | R23. P1_TEST1   | AD25. NC          |
| D10. PB_A[28]   | R24. P1_AD[21]  | AD26. VSS_IO      |
| D11. PB_A[31]   | R25. P1_AD[22]  | AE1. VSS_IO       |
| D12. P1_AD[35]  | R26. P1_AD[16]  | AE2. VSS_IO       |
| D13. P1_AD[43]  | T1. VSS_IO      | AE3. INT[2]_      |
| D14. P1_AD[45]  | T2. PB_D[6]     | AE4. PB_D[39]     |
| D15. P1_M66EN   | T3. PB_D[55]    | AE5. PB_DBB_      |
| D16. P1_AD[54]  | T4. PB_D[23]    | AE6. NC           |
| D17. P1_AD[58]  | T5. VDD25       | AE7. PB_D[15]     |
| D18. P1_AD[63]  | T22. VDD25      | AE8. PB_D[59]     |
| D19. P1_PAR64   | T23. P1_AD[24]  | AE9. PB_VDDA      |
| D20. P1_CBE[4]_ | T24. P1_CBE[3]_ | AE10. PB_D[58]    |
| D21. VSS        | T25. P1_AD[20]  | AE11. PB_D[10]    |
| D22. P1_GNT[2]_ | T26. VSS_IO     | AE12. VSS_IO      |
| D23. P1_AVSS    | U1. PB_D[30]    | AE13. PB_RSTCONF_ |
| D24. P1_AD[42]  | U2. PB_D[54]    | AE14. PB_D[17]    |
| D25. P1_AD[36]  | U3. PB_D[46]    | AE15. PB_D[56]    |
| D26. P1_REQ[2]_ | U4. PB_D[21]    | AE16. PB_D[40]    |
| E1. PB_DBG3_    | U5. VDD25       | AE17. NC          |
| E2. VSS_IO      | U22. VDD25      | AE18. NC          |
| E3. PB_A[9]     | U23. NC         | AE19. VSS_IO      |
| E4. ES          | U24. P1_AD[23]  | AE20. PB_DP[0]    |
| E5. VSS         | U25. P1_AD[25]  | AE21. PB_D[32]    |
| E6. VDD33       | U26. VSS_IO     | AE22. VSS_IO      |
| E7. VDD33       | V1. PB_BG3_     | AE23. VSS_IO      |
| E8. VDD33       | V2. NC          | AE24. VSS_IO      |
| E9. VSS         | V3. PB_D[29]    | AE25. VSS_IO      |
|                 |                 |                   |

| E10. VDD25       | V4. PB_D[5]      | AE26. NC       |
|------------------|------------------|----------------|
| E11. VDD25       | V5. VSS          | AF1. VSS_IO    |
| E12. VDD25       | V22. VSS         | AF2. PB_BG2_   |
| E13. VSS_IO      | V23. P1_AD[27]   | AF3. INT[1]_   |
| E14. VSS_IO      | V24. P1_AD[26]   | AF4. PB_D[61]  |
| E15. VDD25       | V25. VSS_IO      | AF5. PB_CLK    |
| E16. VDD25       | V26. VSS_IO      | AF6. VSS_IO    |
| E17. VDD25       | W1. PB_D[62]     | AF7. PB_DVAL_  |
| E18. VSS         | W2. PB_TEST2     | AF8. PB_ABB_   |
| E19. VDD33       | W3. PB_D[45]     | AF9. I2C_SDA   |
| E20. VDD33       | W4. PB_D[60]     | AF10. PB_D[26] |
| E21. VDD33       | W5. VDD33        | AF11. VSS_IO   |
| E22. P1_DVSS     | W22. VDD33       | AF12. PB_D[49] |
| E23. P1_AD[62]   | W23. P1_AD[30]   | AF13. PO_RST_  |
| E24. P1_AD[38]   | W24. P1_AD[29]   | AF14. PB_D[25] |
| E25. P1_AD[55]   | W25. P1_AD[28]   | AF15. PB_RST_  |
| E26. PCI_REQ[6]_ | W26. PCI_REQ[7]_ | AF16. VSS_IO   |
| F1. VSS_IO       | Y1. PB_D[52]     | AF17. PB_D[16] |
| F2. PB_BR2_      | Y2. PB_D[20]     | AF18. INT[0]_  |
| F3. NC           | Y3. PB_TEST1     | AF19. VSS_IO   |
| F4. PB_A[6]      | Y4. PB_D[13]     | AF20. PB_D[4]  |
| F5. VDD33        | Y5. VDD33        | AF21. VSS_IO   |
| F22. VDD33       | Y22. VDD33       | AF22. NC       |
| F23. P1_ACK64_   | Y23. VSS         | AF23. NC       |
| F24. P1_AD[0]    | Y24. P1_DEVSEL_  | AF24. NC       |
| F25. P1_REQ64_   | Y25. P1_TRDY_    | AF25. VSS_IO   |
| F26. VSS_IO      | Y26. VSS_IO      | AF26. VSS_IO   |
|                  |                  |                |

### 11.3.3 Single PCI PowerSpan II 484 HSBGA

Figure 27 illustrates the top, side, and bottom views of the PowerSpan II package.

### Table 68: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 484 HSBGA                    |
| Package Body Size   | 23mm                         |
| JEDEC Specification | JEDEC MS-034 Variation AAJ-1 |

### Figure 27: 484 PBGA



### 11.3.3.1 Package Notes

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M 1994
- 3. Conforms to JEDEC MS-034 Variation AAJ-1

### 11.3.3.2 484 PBGA Pin Information

The following table shows the PowerSpan II 484 PBGA, 1.00 mm package, pin information.

| A1. PB_A[6]    | H9. VSS_IO       | R17. VDD33     |
|----------------|------------------|----------------|
| A2. PB_A[13]   | H10. VSS_IO      | R18. VDD25     |
| A3. TE         | H11. VSS_IO      | R19. P1_AD[22] |
| A4. JT_TMS     | H12. VSS_IO      | R20. P1_AD[17] |
| A5. PB_A[20]   | H13. VSS_IO      | R21. P1_AD[5]  |
| A6. JT_TCK     | H14. VSS_IO      | R22. P1_PERR_  |
| A7. PB_A[24]   | H15. VSS_IO      | T1. PB_TEST2   |
| A8. PB_A[30]   | H16. VSS         | T2. PB_D[21]   |
| A9. PB_A[27]   | H17. VDD33       | T3. PB_D[52]   |
| A10. PB_DBG2_  | H18. VDD25       | T4. JT_TRST_   |
| A11. PB_GBL_   | H19. PCI_REQ[5]_ | T5. VDD25      |
| A12. P1_AD[34] | H20. P1_AD[0]    | T6. VDD33      |
| A13. P1_AD[32] | H21. P1_REQ64_   | T7. VSS        |
| A14. P1_AD[40] | H22. P1_AD[8]    | T8. VSS        |
| A15. P1_AD[48] | J1. PB_TSIZ[2]   | T9. VSS        |
| A16. P1_AD[53] | J2. PB_TBST_     | T10. VSS       |
| A17. P1_AD[52] | J3. PB_ARTRY_    | T11. VSS       |
| A18. P1_AD[58] | J4. PB_BG1_      | T12. VSS       |
| A19. P1_AD[60] | J5. VDD25        | T13. VSS       |
| A20. P1_PAR64  | J6. VDD33        | T14. VSS       |
| A21. ENUM_     | J7. VSS          | T15. VSS       |
| A22. VSS_IO    | J8. VSS_IO       | T16. VSS       |
| B1. PB_RST_DIR | J9. VSS_IO       | T17. VDD33     |
| B2. ES         | J10. VSS_IO      | T18. VDD25     |
| B3. PB_A[14]   | J11. VSS_IO      | T19. P1_AD[25] |
| B4. PB_A[12]   | J12. VSS_IO      | T20. P1_AD[18] |

| B5. JT_TDO      | J13. VSS_IO      | T21. P1_STOP_    |
|-----------------|------------------|------------------|
| B6. PB_A[22]    | J14. VSS_IO      | T22. P1_AD[19]   |
| B7. PB_A[21]    | J15. VSS_IO      | U1. PB_D[20]     |
| B8. PB_A[28]    | J16. VSS         | U2. PB_D[45]     |
| B9. PB_A[31]    | J17. VDD33       | U3. PB_D[36]     |
| B10. PB_BR1_    | J18. VDD25       | U4. PB_D[43]     |
| B11. P1_AD[35]  | J19. PCI_REQ[6]_ | U5. VDD25        |
| B12. P1_AD[37]  | J20. P1_CBE[0]_  | U6. VDD33        |
| B13. P1_AD[43]  | J21. P1_AD[4]    | U7. VDD33        |
| B14. P1_AD[39]  | J22. P1_AD[9]    | U8. VDD33        |
| B15. P1_AD[47]  | K1. PB_AP[2]     | U9. VDD33        |
| B16. P1_AD[49]  | K2. PB_AP[3]     | U10. VDD33       |
| B17. P1_AD[57]  | K3. PB_TSIZ[0]   | U11. VDD33       |
| B18. P1_AD[56]  | K4. PB_AACK_     | U12. VDD33       |
| B19. P1_CBE[6]_ | K5. VDD25        | U13. VDD33       |
| B20. P1_AD[59]  | K6. VDD33        | U14. VDD33       |
| B21. VSS_IO     | K7. VSS          | U15. VDD33       |
| B22. P1_VDDA    | K8. VSS_IO       | U16. VDD33       |
| C1. PB_A[11]    | K9. VSS_IO       | U17. VDD33       |
| C2. PB_BR2_     | K10. VSS_IO      | U18. VDD25       |
| C3. VSS_IO      | K11. VSS_IO      | U19. PCI_REQ[7]_ |
| C4. JT_TDI      | K12. VSS_IO      | U20. P1_AD[21]   |
| C5. PB_A[15]    | K13. VSS_IO      | U21. P1_AD[16]   |
| C6. PB_A[16]    | K14. VSS_IO      | U22. P1_IRDY_    |
| C7. PB_A[18]    | K15. VSS_IO      | V1. PB_D[5]      |
| C8. PB_A[25]    | K16. VSS         | V2. INT[5]_      |
| C9. P1_RST_DIR  | K17. VDD33       | V3. PB_D[44]     |
| C10. PB_DBG1_   | K18. VDD25       | V4. PB_D[37]     |
| C11. P1_AD[33]  | K19. P1_AD[1]    | V5. PB_TEA_      |
|                 |                  |                  |

| C12. P1_AD[41]  | K20. P1_AD[7]    | V6. PB_D[35]    |
|-----------------|------------------|-----------------|
| C13. P1_AD[44]  | K21. P1_AD[12]   | V7. VDD25       |
| C14. P1_SERR_   | K22. P1_AD[3]    | V8. VDD25       |
| C15. P1_AD[50]  | L1. I2C_SCLK     | V9. VDD25       |
| C16. P1_AD[51]  | L2. PB_AP[1]     | V10. VDD25      |
| C17. P1_REQ[3]_ | L3. PB_TSIZ[1]   | V11. VDD25      |
| C18. P1_AD[63]  | L4. PB_TS_       | V12. VDD25      |
| C19. P1_AD[61]  | L5. VDD25        | V13. VDD25      |
| C20. VSS_IO     | L6. VDD33        | V14. VDD25      |
| C21. P1_DVSS    | L7. VSS          | V15. VDD25      |
| C22. P1_AVSS    | L8. VSS_IO       | V16. VDD25      |
| D1. PB_A[2]     | L9. VSS_IO       | V17. VDD25      |
| D2. PB_A[8]     | L10. VSS_IO      | V18. VDD25      |
| D3. PB_DBG3_    | L11. VSS_IO      | V19. P1_DEVSEL_ |
| D4. VSS_IO      | L12. VSS_IO      | V20. P1_CBE[3]_ |
| D5. PB_A[10]    | L13. VSS_IO      | V21. P1_AD[20]  |
| D6. PB_A[17]    | L14. VSS_IO      | V22. P1_TEST1   |
| D7. PB_A[19]    | L15. VSS_IO      | W1. PB_D[60]    |
| D8. PB_A[23]    | L16. VSS         | W2. PB_D[53]    |
| D9. PB_A[26]    | L17. VDD33       | W3. PB_D[13]    |
| D10. PB_A[29]   | L18. VDD25       | W4. VSS_IO      |
| D11. VDD25      | L19. VDD25       | W5. PB_BG2_     |
| D12. P1_AD[45]  | L20. P1_TEST2    | W6. INT[1]_     |
| D13. P1_M66EN   | L21. P1_INTA_    | W7. INT[2]_     |
| D14. P1_AD[54]  | L22. PCI_GNT[5]_ | W8. PB_D[61]    |
| D15. P1_REQ[4]_ | M1. PB_D[47]     | W9. PB_D[42]    |
| D16. P1_IDSEL   | M2. PB_TA_       | W10. PB_D[59]   |
| D17. P1_CBE[7]_ | M3. PB_AP[0]     | W11. PB_D[18]   |
| D18. P1_CBE[5]_ | M4. VDD25        | W12. VDD25      |
|                 |                  |                 |

| D19. VSS_IO     | M5. VDD25       | W13. PB_D[48]    |
|-----------------|-----------------|------------------|
| D20. P1_CLK     | M6. VDD33       | W14. PB_D[56]    |
| D21. P1_DVDD    | M7. VSS         | W15. PB_DP[2]    |
| D22. PB_CI_     | M8. VSS_IO      | W16. PB_D[63]    |
| E1. INT[4]_     | M9. VSS_IO      | W17. PB_D[8]     |
| E2. PB_A[1]     | M10. VSS_IO     | W18. PCI_GNT[7]_ |
| E3. PB_A[5]     | M11. VSS_IO     | W19. VDD25       |
| E4. PB_A[7]     | M12. VSS_IO     | W20. P1_AD[27]   |
| E5. VSS_IO      | M13. VSS_IO     | W21. P1_AD[26]   |
| E6. VDD25       | M14. VSS_IO     | W22. P1_AD[24]   |
| E7. VDD25       | M15. VSS_IO     | Y1. PB_D[12]     |
| E8. VDD25       | M16. VSS        | Y2. PB_D[28]     |
| E9. VDD25       | M17. VDD33      | Y3. VSS_IO       |
| E10. VDD25      | M18. VDD25      | Y4. PB_DVSS      |
| E11. VDD25      | M19. P1_AD[10]  | Y5. PB_D[31]     |
| E12. VDD25      | M20. P1_AD[13]  | Y6. PB_D[3]      |
| E13. VDD25      | M21. P1_AD[11]  | Y7. PB_D[11]     |
| E14. VDD25      | M22. P1_GNT[4]_ | Y8. PB_D[51]     |
| E15. VDD25      | N1. PB_D[7]     | Y9. PB_D[27]     |
| E16. VDD25      | N2. PB_D[6]     | Y10. PB_D[10]    |
| E17. VDD25      | N3. PB_D[22]    | Y11. PB_D[58]    |
| E18. P1_CBE[4]_ | N4. PB_D[46]    | Y12. PB_D[41]    |
| E19. P1_GNT[1]_ | N5. VDD25       | Y13. PB_RSTCONF_ |
| E20. P1_AD[46]  | N6. VDD33       | Y14. PB_D[1]     |
| E21. P1_AD[42]  | N7. VSS         | Y15. P2_TEST1    |
| E22. P1_ACK64_  | N8. VSS_IO      | Y16. PB_D[16]    |
| F1. PB_A[0]     | N9. VSS_IO      | Y17. PB_DP[3]    |
| F2. PB_TT[2]    | N10. VSS_IO     | Y18. PB_DP[0]    |
| F3. PB_A[4]     | N11. VSS_IO     | Y19. PB_DP[1]    |
|                 |                 |                  |

| F4. PB_A[9]     | N12. VSS_IO      | Y20. P1_TRDY_   |
|-----------------|------------------|-----------------|
| F5. VDD25       | N13. VSS_IO      | Y21. P1_AD[23]  |
| F6. VSS_IO      | N14. VSS_IO      | Y22. P1_AD[28]  |
| F7. VDD33       | N15. VSS_IO      | AA1. INT[3]_    |
| F8. VDD33       | N16. VSS         | AA2. VSS_IO     |
| F9. VDD33       | N17. VDD33       | AA3. PB_AVSS    |
| F10. VDD33      | N18. VDD25       | AA4. PB_CLK     |
| F11. VDD33      | N19. P1_CBE[2]_  | AA5. PB_D[38]   |
| F12. VDD33      | N20. PCI_GNT[6]_ | AA6. PB_D[14]   |
| F13. VDD33      | N21. P1_AD[15]   | AA7. PB_DVAL_   |
| F14. VDD33      | N22. P1_PAR      | AA8. PB_ABB_    |
| F15. VDD33      | P1. PB_D[30]     | AA9. PB_D[50]   |
| F16. VDD33      | P2. PB_D[55]     | AA10. PB_D[34]  |
| F17. VDD33      | P3. PB_D[54]     | AA11. PB_D[2]   |
| F18. P1_REQ[1]_ | P4. PB_D[23]     | AA12. PB_D[49]  |
| F19. P1_GNT[2]_ | P5. VDD25        | AA13. PO_RST_   |
| F20. P1_AD[62]  | P6. VDD33        | AA14. PB_D[17]  |
| F21. P1_AD[36]  | P7. VSS          | AA15. PB_RST_   |
| F22. P1_AD[38]  | P8. VSS_IO       | AA16. PB_D[40]  |
| G1. PB_TT[1]    | P9. VSS_IO       | AA17. INT[0]_   |
| G2. PB_TT[0]    | P10. VSS_IO      | AA18. PB_DP[4]  |
| G3. PB_BR3_     | P11. VSS_IO      | AA19. PB_DP[5]  |
| G4. PB_A[3]     | P12. VSS_IO      | AA20. PB_D[32]  |
| G5. VDD25       | P13. VSS_IO      | AA21. P1_AD[30] |
| G6. VDD33       | P14. VSS_IO      | AA22. P1_AD[29] |
| G7. VSS_IO      | P15. VSS_IO      | AB1. VSS_IO     |
| G8. VSS         | P16. VSS         | AB2. PB_VDDA    |
| G9. VSS         | P17. VDD33       | AB3. PB_DVDD    |
| G10. VSS        | P18. VDD25       | AB4. PB_D[39]   |
|                 |                  |                 |

| G11. VSS        | P19. P1_AD[2]   | AB5. PB_DBB_    |
|-----------------|-----------------|-----------------|
| G12. VSS        | P20. P1_CBE[1]_ | AB6. LED_       |
| G13. VSS        | P21. P1_FRAME_  | AB7. PB_D[15]   |
| G14. VSS        | P22. P1_AD[14]  | AB8. PB_D[19]   |
| G15. VSS        | R1. PB_D[62]    | AB9. I2C_SDA    |
| G16. VSS        | R2. PB_BG3_     | AB10. PB_D[26]  |
| G17. VDD33      | R3. PB_D[29]    | AB11. PB_D[57]  |
| G18. P1_GNT[3]_ | R4. PB_TEST1    | AB12. PB_D[33]  |
| G19. P1_64EN_   | R5. VDD25       | AB13. PB_D[25]  |
| G20. P1_AD[6]   | R6. VDD33       | AB14. PB_D[9]   |
| G21. P1_AD[55]  | R7. VSS         | AB15. PB_FAST   |
| G22. P1_REQ[2]_ | R8. VSS_IO      | AB16. PB_D[24]  |
| H1. PB_TT[4]    | R9. VSS_IO      | AB17. PB_DP[7]  |
| H2. PB_TSIZ[3]  | R10. VSS_IO     | AB18. PB_DP[6]  |
| H3. HEALTHY_    | R11. VSS_IO     | AB19. PB_D[4]   |
| H4. PB_TT[3]    | R12. VSS_IO     | AB20. PB_D[0]   |
| H5. VDD25       | R13. VSS_IO     | AB21. P1_RST_   |
| H6. VDD33       | R14. VSS_IO     | AB22. P1_AD[31] |
| H7. VSS         | R15. VSS_IO     |                 |
| H8. VSS_IO      | R16. VSS        |                 |
|                 |                 |                 |



## **12. Electrical and Signal Characteristics**

This chapter describes the electrical characteristics of the PowerSpan II device. It also details the pin-outs of both the Single PCI PowerSpan II and Dual PCI PowerSpan II. The following topics are discussed:

- "Electrical Characteristics" on page 277
- "Power Dissipation" on page 279
- "Operating Conditions" on page 280

## **12.1 Electrical Characteristics**

PowerSpan II's electrical characteristics are defined by PCI electrical characteristics and non-PCI electrical characteristics.

### 12.1.1 PCI Electrical Characteristics

PowerSpan II's PCI interfaces are electrically compatible with the 3.3V and the 5.0V signaling interfaces as defined by the *PCI 2.2 Specification*.

PowerSpan II supports the *CompactPCI Hot Swap Specification Revision 2.0* and is classified as Hot Swap Silicon. PowerSpan II is compliant with the *PCI Local Bus Specification Revision 2.2* regarding device accessibility after release of LOCAL\_PCI\_RST\_ through Initially Retrying. Optionally devices can choose to Initially Not Respond after release.

### 12.1.2 Non-PCI Electrical Characteristics

The following table, Table 69, specifies the required DC characteristics of all non-PCI PowerSpan II signal pins.

| Symbol                       | Parameter                                        | Condition                                     | Min   | Max                   | Units |
|------------------------------|--------------------------------------------------|-----------------------------------------------|-------|-----------------------|-------|
| VIL                          | Input low voltage                                | $V_{OUT} \ge V_{OH}(min)$ or                  | - 0.3 | 0.8                   | V     |
| V <sub>IH</sub>              | Input high voltage<br>(5 V tolerant<br>LVTTL)    | $V_{OUT} \le V_{OL}(max)$                     | 2.0   | V <sub>DD</sub> + 0.3 | V     |
| lin                          | Input leakage<br>Current                         | $V_{IN} = 0 V \text{ or } V_{IN} = V_{DD}$    |       | 5                     | μA    |
| lin                          | Input leakage<br>Current<br>(internal pull-up)   | $V_{IN} = 0 V \text{ or } V_{IN} = V_{DD}$    | -2.0  | -100                  | μA    |
| lin                          | Input leakage<br>Current<br>(internal pull-down) | $V_{IN} = 0 V \text{ or } V_{IN} = V_{DD}$    | 2.0   | 100                   | μA    |
| V <sub>OH</sub> <sup>b</sup> | Output high voltage                              | V <sub>DD</sub> = min, I <sub>OH</sub> = -2mA | 2.4   |                       | V     |
| V <sub>OL</sub> b            | Output low voltage                               | V <sub>DD</sub> = min, I <sub>OH</sub> = 2mA  |       | 0.4                   | V     |
| C <sub>IN</sub>              | Input Capacitance                                |                                               |       | 10                    | pF    |
| l <sub>OL</sub> c            | Output Low Current<br>(65 ohm output)            | V <sub>OL</sub> =1.5V                         | 25    | 100                   | mA    |

Table 69: HBGA Electrical Characteristics (non-PCI)<sup>a</sup>

a. Non-PCI DC Electrical Characteristics (Ta= -40°C to  $85^{\circ}$ C)

b. These electrical characteristics comply with JESD8B Interface Standard for Nominal 3 V/3.3 V Supply Digital Integrated Circuits

c. CompactPCI Hot Swap LED pin

## 12.2 Power Dissipation

Table 70 shows the Single PCI PowerSpan II power dissipation..

| Processor<br>Bus Clock | PCI-1 Clock | Maximum |
|------------------------|-------------|---------|
| 50 MHz                 | 33 MHz      | 1.2 W   |
| 66 MHz                 | 33 MHz      | 1.3 W   |
| 100 MHz                | 66 MHz      | 2.3 W   |

### Table 70: Single PCI PowerSpan II Power Dissipation

Table 71 shows the Dual PCI PowerSpan II power dissipation

| Processor<br>Bus Clock | PCI-1 Clock | PCI-2 Clock | Maximum |
|------------------------|-------------|-------------|---------|
| 50 MHz                 | 33 MHz      | 25 MHz      | 1.2 W   |
| 66 MHz                 | 33 MHz      | 33 MHz      | 1.3 W   |
| 100 MHz                | 66 MHz      | 66 MHz      | 2.3 W   |

## 12.3 Operating Conditions

### 12.3.1 Recommended Operating Conditions

The following table, Table 72, specifies the recommended operating conditions of the PowerSpan II.

| Symbol   | Parameter                | Min  | Мах  | Units                  |
|----------|--------------------------|------|------|------------------------|
| Vdd I/O  | I/O DC Supply<br>Voltage | 3.15 | 3.45 | V                      |
| Vdd Core | Core Supply<br>Voltage   | 2.38 | 2.63 | V                      |
| Px_VDDA  | PLL Supply<br>Voltage    | 2.38 | 2.63 | V                      |
| Та       | Ambient<br>Temperature   | -40  | +85  | ℃                      |
| Н        | Humidity                 | 0    | 80   | % Relative<br>Humidity |

**Table 72: Operating and Storage Conditions** 

### 12.3.2 Handling and Storage Specifications

After encapsulation cure cavity down assemblies are JESD22-A112 Moisture Sensitivity Category 3. From that point on, parts are to be handled to the following criteria:

1. From encapsulation cure to BGA/PGA attach, Class 3 modules can be exposed for a maximum cumulative time of eight days to an environment of no more than 30 OC and/or 60% RH. If this condition is exceeded, modules are to be baked at

125 O C +/- 10 OC for 24 hours minimum or at other qualified bake parameters.

- 2. Modules shall be placed in an ESD carrier. Each module shall be orientated in the same way. When preparing for shipment to stock location, modules are to be baked at 125 O C +/- 10 O C for 24 hours minimum or at other qualified bake parameters. Modules are to be sealed within 24 hours for Class 3 modules in a moisture barrier ESD bag with desiccant. This bakeout procedure can be repeated once to remain in compliance.
- 3. Failure to comply with this requirement can result in die to die pad, encapsulant to soldermask or encapsulant to die delamination during reflow.

### 12.3.3 Absolute Maximum Ratings

The following table, Table 73, specifies the absolute maximum ratings of PowerSpan II.

| Symbol                  | Parameter                                | Limits            | Units |
|-------------------------|------------------------------------------|-------------------|-------|
| Vdd Core <sup>a b</sup> | Core Supply<br>Voltage                   | -0.3 to 2.7       | V     |
| Vdd I/O <sup>a c</sup>  | I/O Supply Voltage                       | -0.3 to 3.6       | V     |
| Px_VDDA <sup>a b</sup>  | PLL Supply Voltage                       | -0.3 to 2.7       | V     |
| Vin <sup>a d e</sup>    | DC Input Voltage<br>(LVTTL)              | -0.3 to Vdd + 0.3 | V     |
| Vin <sup>a d e</sup>    | DC Input Voltage<br>(5 V tolerant LVTTL) | -0.6 to 5.5       | V     |
| Tstg                    | Storage<br>Temperature                   | -65 to 150        | ℃     |

### Table 73: Absolute Maximum Ratings

a. Functional operation at the maximums is not guaranteed. Stress beyond those listed can affect device reliability or cause permanent damage to PowerSpan II.

- b. Vdd Core/ Px\_VDDA must not exceed Vdd I/O by more than 0.4 V. This includes during power-on reset.
- c. Vdd I/O must not exceed Vdd Core/ Px\_VDDA by more than 1.6 V. This includes during power-on reset.
- d. These limits only apply to overshoot and undershoot. Cell functionality is not implied.
- e. Vin must not exceed Vdd I/O by more than 2.5 V at any time. This includes during power-on reset.



# **13. Register Descriptions**

This chapter describes the registers used in PowerSpan II. It describes the register settings and bits which enable PowerSpan II features and functionality. The following topics are discussed:

- "Register Access" on page 283
- "Register Reset" on page 295
- "Configuration and IACK Cycle Generation" on page 295
- "Register Descriptions" on page 298

### 13.1 Register Access

The PowerSpan II registers can be accessed from both PCI and the processor bus. PowerSpan II allows reads to its registers from all of its bus interfaces at the same time. However, writes may occur from only one bus interface at a time.

### 13.1.1 Register Map

The 4 Kbytes of PowerSpan II Control and Status Registers (PCSR) are used for PCI Control and Status Registers (CSRs), and for overall PowerSpan II operation. The PCSR space is functionally divided into two areas: the PCI CSR space and the PowerSpan II PCSR space. PSCR space is accessible from the Processor Bus, PCI-1 or PCI-2 interfaces.

Table 74 is a detailed memory map for PCSR space and shows the PowerSpan II register map for the Dual PCI PowerSpan II. PowerSpan II is available as both the Single PCI PowerSpan II and Dual PCI PowerSpan II.

All registers that are based on standards — for example, required PCI registers — are in italics. The shaded registers under PCI-1 Configuration and PCI-2 Configuration registers exist only if the associated PCI Interface is configured as the Primary Interface. A interface is configured as Primary using a power-up option (see "Resets, Clocks and Power-up Options" on page 201 for more information). The PCI Interface that is designated as Primary has added functionality which includes CompactPCI Hot Swap support, Vital Product Data support and an I<sup>2</sup>C Interface. Refer to "PCI Interface" on page 43 for more information on Primary Interface functionality.

| Offset<br>(HEX) | Register Mnemonic             | Register Name                                             | Page     |  |
|-----------------|-------------------------------|-----------------------------------------------------------|----------|--|
| PCI-1 Co        | PCI-1 Configuration Registers |                                                           |          |  |
| 000             | P1_ID                         | PCI-1 ID Register                                         | page 300 |  |
| 004             | P1_CSR                        | PCI-1 Control and Status Register                         | page 301 |  |
| 008             | P1_CLASS                      | PCI-1 Class Register                                      | page 305 |  |
| 00C             | P1_MISC0                      | PCI-1 Miscellaneous 0 Register                            | page 307 |  |
| 010             | P1_BSI2O                      | PCI-1 I <sub>2</sub> O Target Image Base Address Register | page 309 |  |
| 014             | P1_BSREG                      | PCI-1 Register Image Base Address Register                | page 311 |  |
| 018             | P1_BST0                       | PCI-1 Target Image 0 Base Address Register                | page 312 |  |
| 01C             | P1_BST1                       | PCI-1 Target Image 1 Base Address Register                | page 312 |  |
| 020             | P1_BST2                       | PCI-1 Target Image 2 Base Address Register                | page 312 |  |
| 024             | P1_BST3                       | PCI-1 Target Image 3 Base Address Register                | page 312 |  |
| 028             | PCI Unimplemented             |                                                           |          |  |
| 02C             | P1_SID                        | PCI-1 Subsystem ID Register                               | page 313 |  |
| 030             | PCI Unimplemented             |                                                           |          |  |
| 034             | P1_CAP                        | PCI-1 Capability Pointer Register                         | page 314 |  |
| 038             | PCI Unimplemented             |                                                           |          |  |
| 03C             | P1_MISC1                      | PCI-1 Miscellaneous 1 Register                            | page 315 |  |
| 040-0E0         | PCI Unimplemented             |                                                           |          |  |
| 0E4             | P1_HS_CSR                     | PCI-1 Compact PCI Hot Swap Control and Status<br>Register | page 317 |  |

Table 74: PowerSpan II Register Map

| Offset<br>(HEX) | Register Mnemonic    | Register Name                                                     | Page     |
|-----------------|----------------------|-------------------------------------------------------------------|----------|
| 0E8             | P1_VPDC              | PCI-1 Vital Product Data Capability Register                      | page 319 |
| 0EC             | P1_VPDD              | PCI-1 Vital Product Data Register                                 | page 321 |
| 0F0-0FC         | PCI Unimplemented    |                                                                   |          |
| PCI-1 Reg       | gisters              |                                                                   |          |
| 100             | P1_TI0_CTL           | PCI-1 Target Image 0 Control Register                             | page 322 |
| 104             | P1_TI0_TADDR         | PCI-1 Target Image 0 Translation Address Register                 | page 328 |
| 108-10C         | PowerSpan II Reserve | ed                                                                |          |
| 110             | P1_TI1_CTL           | PCI-1 Target Image 1 Control Register                             | page 322 |
| 114             | P1_TI1_TADDR         | PCI-1 Target Image 1 Translation Address Register                 | page 328 |
| 118-11C         | PowerSpan II Reserve | ed                                                                |          |
| 120             | P1_TI2_CTL           | PCI-1 Target Image 2 Control Register                             | page 322 |
| 124             | P1_TI2_TADDR         | PCI-1 Target Image 2 Translation Address Register                 | page 328 |
| 128-12C         | PowerSpan II Reserve | ed                                                                |          |
| 130             | P1_TI3_CTL           | PCI-1 Target Image 3 Control Register                             | page 322 |
| 134             | P1_TI3_TADDR         | PCI-1 Target Image 3 Translation Address Register                 | page 328 |
| 138-140         | PowerSpan II Reserve | ed                                                                |          |
| 144             | P1_CONF_INFO         | PCI-1 to PCI-2 Configuration Cycle Information Register           | page 330 |
| 148             | P1_CONF_DATA         | PCI-1 to PCI-2 Configuration Cycle Data Register                  | page 333 |
| 14C             | P1_IACK              | PCI-1 to PCI-2 Interrupt Acknowledge Cycle<br>Generation Register | page 334 |
| 150             | P1_ERRCS             | PCI-1 Bus Error Control and Status Register                       | page 335 |
| 154             | P1_AERR              | PCI-1 Address Error Log Register                                  | page 336 |
| 158-15C         | PowerSpan II Reserve |                                                                   |          |
| 160             | P1_MISC_CSR          | PCI-1 Miscellaneous Control and Status Register                   | page 337 |
| 164             | P1_ARB_CTRL          | PCI-1 Bus Arbiter Control Register                                | page 339 |
| 168-1FC         | PowerSpan II Reserve |                                                                   |          |

Table 74: PowerSpan II Register Map

| Table 74: PowerSpan | II Register Map |
|---------------------|-----------------|
|---------------------|-----------------|

| Offset<br>(HEX) | Register Mnemonic    | Register Name                                               | Page     |
|-----------------|----------------------|-------------------------------------------------------------|----------|
| Processo        |                      |                                                             |          |
| 200             | PB_SI0_CTL           | Processor Bus Slave Image 0 Control Register                | page 342 |
| 204             | PB_SI0_TADDR         | Processor Bus Slave Image 0 Translation Address<br>Register | page 348 |
| 208             | PB_SI0_BADDR         | Processor Bus Slave Image 0 Base Address Register           | page 350 |
| 20C             | PowerSpan II Reserve | ed                                                          |          |
| 210             | PB_SI1_CTL           | Processor Bus Slave Image 1 Control Register                | page 342 |
| 214             | PB_SI1_TADDR         | Processor Bus Slave Image 1 Translation Address<br>Register | page 348 |
| 218             | PB_SI1_BADDR         | Processor Bus Slave Image 1 Base Address Register           | page 350 |
| 21C             | PowerSpan II Reserve | ed                                                          |          |
| 220             | PB_SI2_CTL           | Processor Bus Slave Image 2 Control Register                | page 342 |
| 224             | PB_SI2_TADDR         | Processor Bus Slave Image 2 Translation Address<br>Register | page 348 |
| 228             | PB_SI2_BADDR         | Processor Bus Slave Image 2 Base Address Register           | page 350 |
| 22C             | PowerSpan II Reserve | ed                                                          |          |
| 230             | PB_SI3_CTL           | Processor Bus Slave Image 3 Control Register                | page 342 |
| 234             | PB_SI3_TADDR         | Processor Bus Slave Image 3 Translation Address<br>Register | page 348 |
| 238             | PB_SI3_BADDR         | Processor Bus Slave Image 3 Base Address Register           | page 350 |
| 23C             | PowerSpan II Reserve |                                                             |          |
| 240             | PB_SI4_CTL           | Processor Bus Slave Image 4 Control Register                | page 342 |
| 244             | PB_SI4_TADDR         | Processor Bus Slave Image 4 Translation Address<br>Register | page 348 |
| 248             | PB_SI4_BADDR         | Processor Bus Slave Image 4 Base Address Register           | page 350 |
| 24C             | PowerSpan II Reserve |                                                             |          |
| 250             | PB_SI5_CTL           | Processor Bus Slave Image 5 Control Register                | page 342 |

| Offset<br>(HEX) | Register Mnemonic    | Register Name                                                          | Page     |
|-----------------|----------------------|------------------------------------------------------------------------|----------|
| 254             | PB_SI5_TADDR         | Processor Bus Slave Image 5 Translation Address<br>Register            | page 348 |
| 258             | PB_SI5_BADDR         | Processor Bus Slave Image 5 Base Address Register                      | page 350 |
| 25C             | PowerSpan II Reserve | ed                                                                     |          |
| 260             | PB_SI6_CTL           | Processor Bus Slave Image 6 Control Register                           | page 342 |
| 264             | PB_SI6_TADDR         | Processor Bus Slave Image 6 Translation Address<br>Register            | page 348 |
| 268             | PB_SI6_BADDR         | Processor Bus Slave Image 6 Base Address Register                      | page 350 |
| 26C             | PowerSpan II Reserve | ed                                                                     |          |
| 270             | PB_SI7_CTL           | Processor Bus Slave Image 7 Control Register                           | page 342 |
| 274             | PB_SI7_TADDR         | Processor Bus Slave Image 7 Translation Address<br>Register            | page 348 |
| 278             | PB_SI7_BADDR         | Processor Bus Slave Image 7 Base Address Register                      | page 350 |
| 27C             | PowerSpan II Reserve | ed                                                                     |          |
| 280             | PB_REG_BADDR         | Processor Bus Register Image Base Address<br>Register                  | page 351 |
| 284-28C         | PowerSpan II Reserve | ed                                                                     |          |
| 290             | PB_CONF_INFO         | Processor Bus PCI Configuration Cycle Information Register             | page 352 |
| 294             | PB_CONF_DATA         | Processor Bus PCI Configuration Cycle Data<br>Register                 | page 355 |
| 298-29C         | PowerSpan II Reserve |                                                                        |          |
| 2A0             | PB_P1_IACK           | Processor Bus to PCI-1 Interrupt Acknowledge Cycle Generation Register | page 356 |
| 2A4             | PB_P2_IACK           | Processor Bus to PCI-2 Interrupt Acknowledge Cycle Generation Register | page 357 |
| 2A8-<br>2AC     | PowerSpan II Reserve |                                                                        |          |
| 2B0             | PB_ERRCS             | Processor Bus Error Control and Status Register                        | page 359 |
| 2B4             | PB_AERR              | Processor Bus Address Error Log Register                               | page 360 |

Table 74: PowerSpan II Register Map

| Table 74: PowerSpan | II Register Map |
|---------------------|-----------------|
|---------------------|-----------------|

| Offset<br>(HEX) | Register Mnemonic     | Register Name                                           | Page     |  |
|-----------------|-----------------------|---------------------------------------------------------|----------|--|
| 2B8-<br>2BC     | PowerSpan II Reserve  | ed                                                      |          |  |
| 2C0             | PB_MISC_CSR           | Processor Bus Miscellaneous Control and Status Register | page 361 |  |
| 2C4-<br>2CC     | PowerSpan II Reserve  | ed                                                      |          |  |
| 2D0             | PB_ARB_CTRL           | Processor Bus Arbiter Control Register                  | page 364 |  |
| 2D4-<br>2FC     | PowerSpan II Reserve  | ed                                                      |          |  |
| DMA Reg         | isters                |                                                         |          |  |
| 300             | PowerSpan II Reserve  | ed                                                      |          |  |
| 304             | DMA0_SRC_ADDR         | DMA 0 Source Address Register                           | page 367 |  |
| 308             | PowerSpan II Reserve  | ed                                                      |          |  |
| 30C             | DMA0_DST_ADDR         | DMA 0 Destination Address Register                      | page 368 |  |
| 310             | PowerSpan II Reserve  | ed                                                      |          |  |
| 314             | DMA0_TCR              | DMA 0 Transfer Control Register                         | page 369 |  |
| 318             | PowerSpan II Reserve  | ed                                                      |          |  |
| 31C             | DMA0_CPP              | DMA 0 Command Packet Pointer Register                   | page 371 |  |
| 320             | DMA0_GCSR             | DMA 0 General Control Register                          | page 372 |  |
| 324             | DMA0_ATTR             | DMA 0 Attributes Register                               | page 376 |  |
| 328-330         | PowerSpan II Reserve  | ed                                                      |          |  |
| 334             | DMA1_SRC_ADDR         | DMA 1 Source Address Register                           | page 367 |  |
| 338             | PowerSpan II Reserved |                                                         |          |  |
| 33C             | DMA1_DST_ADDR         | DMA 1 Destination Address Register                      | page 368 |  |
| 340             | PowerSpan II Reserved |                                                         |          |  |
| 344             | DMA1_TCR              | DMA 1 Transfer Control Register                         | page 369 |  |
| 348             | PowerSpan II Reserve  | ed                                                      |          |  |
| 34C             | DMA1_CPP              | DMA 1 Command Packet Pointer Register                   | page 371 |  |

| Offset<br>(HEX) | Register Mnemonic    | Register Name                             | Page     |
|-----------------|----------------------|-------------------------------------------|----------|
| 350             | DMA1_GCSR            | DMA 1 General Control and Status Register | page 372 |
| 354             | DMA1_ATTR            | DMA 1 Attributes Register                 | page 376 |
| 358-360         | PowerSpan II Reserve | ed                                        |          |
| 364             | DMA2_SRC_ADDR        | DMA 2 Source Address Register             | page 367 |
| 368             | PowerSpan II Reserve | ed                                        |          |
| 36C             | DMA2_DST_ADDR        | DMA 2 Destination Address Register        | page 368 |
| 370             | PowerSpan II Reserve | ed                                        |          |
| 374             | DMA2_TCR             | DMA 2 Transfer Control Register           | page 369 |
| 378             | PowerSpan II Reserve | ed                                        |          |
| 37C             | DMA2_CPP             | DMA 2 Command Packet Pointer Register     | page 371 |
| 380             | DMA2_GCSR            | DMA 2 General Control and Status Register | page 372 |
| 384             | DMA2_ATTR            | DMA 2 Attributes Register                 | page 376 |
| 388-390         | PowerSpan II Reserve | ed                                        |          |
| 394             | DMA3_SRC_ADDR        | DMA 3 Source Address Register             | page 367 |
| 398             | PowerSpan II Reserve | ed                                        |          |
| 39C             | DMA3_DST_ADDR        | DMA 3 Destination Address Register        | page 368 |
| 3A0             | PowerSpan II Reserve | ed                                        |          |
| 3A4             | DMA3_TCR             | DMA 3 Transfer Control Register           | page 369 |
| 3A8             | PowerSpan II Reserve | ed                                        |          |
| 3AC             | DMA3_CPP             | DMA 3 Command Packet Pointer Register     | page 371 |
| 3B0             | DMA3_GCSR            | DMA 3 General Control and Status Register | page 372 |
| 3B4             | DMA3_ATTR            | DMA 3 Attributes Register                 | page 376 |
| 3B8-3FC         | PowerSpan II Reserve | ed                                        |          |
| Miscellar       | eous Registers       |                                           |          |
| 400             | MISC_CSR             | Miscellaneous Control and Status Register | page 378 |
| 404             | CLOCK_CTL            | Clock Control Register                    | page 381 |

Table 74: PowerSpan II Register Map

| Table 74: F | PowerSpan II | <b>Register</b> M | lap |
|-------------|--------------|-------------------|-----|
|-------------|--------------|-------------------|-----|

| Offset<br>(HEX) | Register Mnemonic    | Register Name                                          | Page     |
|-----------------|----------------------|--------------------------------------------------------|----------|
| 408             | I2C_CSR              | I <sup>2</sup> C Interface Control and Status Register | page 383 |
| 40C             | RST_CSR              | Reset Control and Status Register                      | page 385 |
| 410             | ISR0                 | Interrupt Status Register 0                            | page 388 |
| 414             | ISR1                 | Interrupt Status Register 1                            | page 390 |
| 418             | IER0                 | Interrupt Enable Register 0                            | page 393 |
| 41C             | IER1                 | Interrupt Enable Register 1                            | page 395 |
| 420             | IMR_MBOX             | Interrupt Map Register: Mailbox                        | page 398 |
| 424             | IMR_DB               | Interrupt Map Register: Doorbell                       | page 400 |
| 428             | IMR_DMA              | Interrupt Map Register: DMA                            | page 401 |
| 42C             | IMR_HW               | Interrupt Map Register: Hardware                       | page 402 |
| 430             | IMR_P1               | Interrupt Map Register: PCI-1                          | page 404 |
| 434             | IMR_P2               | Interrupt Map Register: PCI-2                          | page 405 |
| 438             | IMR_PB               | Interrupt Map Register: Processor Bus                  | page 406 |
| 43C             | IMR2_PB              | Interrupt Map Register Two: Processor Bus              | page 408 |
| 440             | IMR_MISC             | Interrupt Map Register: Miscellaneous                  | page 409 |
| 444             | IDR                  | Interrupt Direction Register                           | page 410 |
| 448-44C         | PowerSpan II Reserve | ed                                                     |          |
| 450             | MBOX0                | Mailbox 0 Register                                     | page 412 |
| 454             | MBOX1                | Mailbox 1 Register                                     | page 412 |
| 458             | MBOX2                | Mailbox 2 Register                                     | page 412 |
| 45C             | MBOX3                | Mailbox 3 Register                                     | page 412 |
| 460             | MBOX4                | Mailbox 4 Register                                     | page 412 |
| 464             | MBOX5                | Mailbox 5 Register                                     | page 412 |
| 468             | MBOX6                | Mailbox 6 Register                                     | page 412 |
| 46C             | MBOX7                | Mailbox 7 Register                                     | page 412 |
| 470             | SEMA0                | Semaphore 0 Register                                   | page 413 |

| Offset<br>(HEX)        | Register Mnemonic    | Register Name                                                         | Page     |
|------------------------|----------------------|-----------------------------------------------------------------------|----------|
| 474                    | SEMA1                | Semaphore 1 Register                                                  | page 414 |
| 478-4FC                | PowerSpan II Reserve | ed                                                                    |          |
| I <sub>2</sub> O Regis | sters                |                                                                       |          |
| 500                    | PCI_TI2O_CTL         | PCI I <sub>2</sub> O Target Image Control Register                    | page 415 |
| 504                    | PCI_TI2O_TADDR       | PCI I <sub>2</sub> O Target Image Translation Address Register        | page 420 |
| 508                    | I2O_CSR              | I <sub>2</sub> O Control and Status Register                          | page 421 |
| 50C                    | I2O_QUEUE_BS         | I <sub>2</sub> O Queue Base Address Register                          | page 423 |
| 510                    | IFL_BOT              | I <sub>2</sub> O Inbound Free List Bottom Pointer Register            | page 425 |
| 514                    | IFL_TOP              | I <sub>2</sub> O Inbound Free List Top Pointer Register               | page 426 |
| 518                    | IFL_TOP_INC          | I <sub>2</sub> O Inbound Free List Top Pointer Increment Register     | page 427 |
| 51C                    | IPL_BOT              | I <sub>2</sub> O Inbound Post List Bottom Pointer Register            | page 428 |
| 520                    | IPL_BOT_INC          | I <sub>2</sub> O Inbound Post List Bottom Pointer Increment Register  | page 429 |
| 524                    | IPL_TOP              | I <sub>2</sub> O Inbound Post List Top Pointer Register               | page 430 |
| 528                    | OFL_BOT              | I <sub>2</sub> O Outbound Free List Bottom Pointer Register           | page 431 |
| 52C                    | OFL_BOT_INC          | I <sub>2</sub> O Outbound Free List Bottom Pointer Increment Register | page 432 |
| 530                    | OFL_TOP              | I <sub>2</sub> O Outbound Free List Top Pointer Register              | page 433 |
| 534                    | OPL_BOT              | I <sub>2</sub> O Outbound Post List Bottom Pointer Register           | page 434 |
| 538                    | OPL_TOP              | I <sub>2</sub> O Outbound Post List Top Pointer Register              | page 435 |
| 53C                    | OPL_TOP_INC          | I <sub>2</sub> O Outbound Post List Top Pointer Increment Register    | page 436 |
| 540                    | HOST_OIO             | I <sub>2</sub> O Host Outbound Index Offset Register                  | page 437 |
| 544                    | HOST_OIA             | I <sub>2</sub> O Host Outbound Index Alias Register                   | page 438 |
| 548                    | IOP_OI               | I <sub>2</sub> O IOP Outbound Index Register                          | page 439 |
| 54C                    | IOP_OI_INC           | I <sub>2</sub> O IOP Outbound Index Increment Register                | page 440 |
| 550-7FC                | PowerSpan II Reserve | ed                                                                    |          |

Table 74: PowerSpan II Register Map

| Table 74: PowerSpan | II Register Map |
|---------------------|-----------------|
|---------------------|-----------------|

| Offset<br>(HEX) | Register Mnemonic     | Register Name                                             | Page           |  |  |
|-----------------|-----------------------|-----------------------------------------------------------|----------------|--|--|
| PCI-2 Co        | nfiguration Registers | (Dual PCI PowerSpan II)                                   |                |  |  |
| 800             | P2_ID                 | PCI-2 ID Register                                         | page 441       |  |  |
| 804             | P2_CSR                | PCI-2 Control and Status Register                         | page 442       |  |  |
| 808             | P2_CLASS              | PCI-2 Class Register                                      | refer to PCI-1 |  |  |
| 80C             | P2_MISC0              | PCI-2 Miscellaneous 0 Register                            | refer to PCI-1 |  |  |
| 810             | P2_BSI2O              | PCI-2 I <sub>2</sub> O Target Image Base Address Register | refer to PCI-1 |  |  |
| 814             | P2_BSREG              | PCI-2 Register Image Base Address Register                | refer to PCI-1 |  |  |
| 818             | P2_BST0               | PCI-2 Target Image 0 Base Address Register                | refer to PCI-1 |  |  |
| 81C             | P2_BST1               | PCI-2 Target Image 1 Base Address Register                | refer to PCI-1 |  |  |
| 820             | P2_BST2               | PCI-2 Target Image 2 Base Address Register                | refer to PCI-1 |  |  |
| 824             | P2_BST3               | PCI-2 Target Image 3 Base Address Register                | refer to PCI-1 |  |  |
| 828             | PCI Unimplemented     |                                                           |                |  |  |
| 82C             | P2_SID                | PCI-2 Subsystem ID Register                               | refer to PCI-1 |  |  |
| 830             | PCI Unimplemented     |                                                           |                |  |  |
| 834             | P2_CAP                | PCI-2 Capability Pointer Register                         | refer to PCI-1 |  |  |
| 838             | PCI Unimplemented     |                                                           |                |  |  |
| 83C             | P2_MISC1              | PCI-2 Miscellaneous 1 Register                            | refer to PCI-1 |  |  |
| 840-8E0         | PCI Unimplemented     |                                                           |                |  |  |
| 8E4             | P2_HS_CSR             | PCI-2 Compact PCI Hot Swap Control and Status<br>Register | refer to PCI-1 |  |  |
| 8E8             | P2_VPDC               | PCI-2 Vital Product Data Capability Register              | refer to PCI-1 |  |  |
| 8EC             | P2_VPDD               | PCI-2 Vital Product Data Register                         | refer to PCI-1 |  |  |
| 8F0-8FC         | 8FC PCI Unimplemented |                                                           |                |  |  |
| PCI-2 Reg       | gisters (Dual PCI Pow | erSpan II)                                                |                |  |  |
| 900             | P2_TI0_CTL            | PCI-2 Target Image 0 Control Register                     | refer to PCI-1 |  |  |
| 904             | P2_TI0_TADDR          | PCI-2 Target Image 0 Translation Address Register         | refer to PCI-1 |  |  |

| Offset<br>(HEX) | Register Mnemonic Register Name |                                                                   | Page           |
|-----------------|---------------------------------|-------------------------------------------------------------------|----------------|
| 908-90C         | PowerSpan II Reserve            | ed                                                                |                |
| 910             | P2_TI1_CTL                      | PCI-2 Target Image 1 Control Register                             | refer to PCI-1 |
| 914             | P2_TI1_TADDR                    | PCI-2 Target Image 1 Translation Address Register                 | refer to PCI-1 |
| 918-91C         | PowerSpan II Reserve            | ed                                                                |                |
| 920             | P2_TI2_CTL                      | PCI-2 Target Image 2 Control Register                             | refer to PCI-1 |
| 924             | P2_TI2_TADDR                    | PCI-2 Target Image 2 Translation Address Register                 | refer to PCI-1 |
| 928-92C         | PowerSpan II Reserve            | ed                                                                |                |
| 930             | P2_TI3_CTL                      | PCI-2 Target Image 3 Control Register                             | refer to PCI-1 |
| 934             | P2_TI3_TADDR                    | PCI-2 Target Image 3 Translation Address Register                 | refer to PCI-1 |
| 938-940         | PowerSpan II Reserve            | ed                                                                |                |
| 944             | P2_CONF_INFO                    | PCI-2 to PCI 1 Configuration Cycle Information<br>Register        | refer to PCI-1 |
| 948             | P2_CONF_DATA                    | PCI-2 to PCI 1 Configuration Cycle Data Register                  | refer to PCI-1 |
| 94C             | P2_IACK                         | PCI-2 to PCI 1 Interrupt Acknowledge Cycle<br>Generation Register | refer to PCI-1 |
| 950             | P2_ERRCS                        | PCI-2 Bus Error Control and Status Register                       | refer to PCI-1 |
| 954             | P2_AERR                         | PCI-2 Address Error Log Register                                  | refer to PCI-1 |
| 958-95C         | PowerSpan II Reserve            |                                                                   |                |
| 960             | P2_MISC_CSR                     | PCI-2 Miscellaneous Control and Status Register                   | refer to PCI-1 |
| 964             | P2_ARB_CTRL                     | PCI-2 Bus Arbiter Control Register                                | refer to PCI-1 |
| 968-FFC         | PowerSpan II Reserve            |                                                                   |                |

Table 74: PowerSpan II Register Map

# 13.1.2 Access from PCI

The PCI-1 Register Image Base Address Register specifies the 4-Kbyte aligned base address for the PowerSpan II Control and Status Registers (PCSRs) in PCI Memory Space. The base address for PCSR space is enabled by:

- 1. Setting the BSREG\_BAR\_EN bit in the P1\_MISC\_CS
- 2. Writing to the P1\_BSREG register either with a PCI Configuration write access or by writing to it from the Processor Bus (PB).

Once enabled, the PCSR space can be accessed in PCI Memory Space with singlebeat 32-bit accesses.

# 13.1.3 Access from the Processor Bus

The PB\_REG\_BADDR register specifies the 4-Kbyte aligned base address for PCSR space on the processor bus. This register is programmed through any register interface or through EEPROM. Register accesses through the Processor Bus Interface can be big-endian or PowerPC little-endian (see "Processor Bus and PowerSpan II Register Transfers" on page 215). The endian conversion for register accesses from the Processor Bus Interface is controlled with the END bit in the PB\_REG\_BADDR Register. The default mode is big-endian.

The reset state for the base address for PCSR space on the processor bus is 0x3000\_0000. Refer to Table 112 for more information.

# 13.1.4 Access from Multiple Interfaces

PowerSpan II allows reads to its registers from all of its bus interfaces at the same time. However, writes may occur from only one bus interface at a time. This prevents data corruption if two or more interfaces try to write to the same register simultaneously.



Register writes to "write 1 to set/clear" status bits may not be reflected by an immediate register read.

PowerSpan II uses an internal round robin arbitration mechanism for register access from the different bus interfaces. Register writes are retried until the interface doing the write has successfully arbitrated for register access.



Register accesses from all interfaces are retried during EEPROM load.

Each PowerSpan II PCI Target has a Px Lockout (Px\_LOCKOUT) bit in the "Miscellaneous Control and Status Register" on page 378 (MISC\_CSR). While a lockout bit is set, the corresponding PCI Target retries all Configuration Type 0 transactions. When the Base Address registers have been configured, memory transactions are claimed, but they are retried until the lockout bit is cleared. By default the Px\_LOCKOUT bits are set. The lockout bits can either be cleared by EEPROM load, or by an access from the Processor Bus Interface. The lockout bits are automatically cleared by PowerSpan II when the PWRUP\_BOOT bit in the "Processor Bus Arbiter Control Register" on page 364 is set to PCI.

# 13.2 Register Reset

The PCSR space is divided into four reset domains:

- PCI-1 CSR space
- PCI-2 CSR space
- Processor Bus Interface registers
- Device Specific registers

See "Reset Response" on page 203 for a detailed description of register reset partitioning.

When an EEPROM is detected by PowerSpan II's I<sup>2</sup>C Interface after reset, certain registers are initialized with the contents of the EEPROM. See "I2C/EEPROM" on page 153 for details on which register fields are loaded through EEPROM.

# 13.3 Configuration and IACK Cycle Generation

PowerSpan II has registers that must be programmed in order for a PCI master to generate configuration (Type 1 or 0) and IACK transactions on the alternate PCI Interface and for the processor bus to generate configuration (Type 1 or 0) and IACK transactions on either PCI bus.

# 13.3.1 From PCI-to-PCI

The following PowerSpan II registers are used by a PCI master to generate configuration (Type 1 or 0) and IACK transactions on the alternate PCI Interface:

- Px\_CONF\_INFO/Px\_CONF\_DATA
- Px\_IACK

## 13.3.1.1 PCI Configuration Data

Generating a Configuration transaction on PCI requires the programming of the "PCI 1 to PCI-2 Configuration Cycle Information Register" on page 330 (Px\_CONF\_INFO) in order set-up the address of the Configuration cycle. The PCI transaction is generated when a register access occurs on the "PCI 1 to PCI-2 Configuration Cycle Data Register" on page 333 (Px\_CONF\_DATA).

When a register write is performed to Px\_CONF\_DATA, the address and data parameters in Px\_CONF\_DATA are used to generate a configuration transaction on the alternate PCI bus.

When a register read is performed to Px\_CONF\_DATA, the read is retried while a configuration read transaction is generated on the alternate PCI bus. The address for the read transaction is defined by Px\_CONF\_INFO. While the data is being retrieved, register accesses to Px\_CONF\_DATA is retried.

The Px\_CONF\_INFO and Px\_CONF\_DATA registers must be treated as shared resources for applications that require more than one agent to generate configuration transactions on PCI. A semaphore is used to control access.

## 13.3.1.2 Interrupt Acknowledge Generation

The Px\_IACK register is used to generate IACK reads on the alternate PCI bus. If a register read is performed to Px\_IACK, then the read is retried while an IACK cycle is generated on the alternate PCI bus. The address for the IACK cycle is taken directly from the originating PCI bus.

The Px\_IACK register must be treated as shared resources for applications that require more than one agent to generate IACK transactions on PCI. A semaphore is used to control access.



Writes to Px\_IACK have no effect.

# **13.3.2** From the Processor Bus to PCI

The following PowerSpan II registers are used to generate Configuration (Type 1 or 0) and IACK transactions going from the Processor Bus Interface to either of the PCI Interfaces:

- PB\_CONF\_INFO/PB\_CONF\_DATA
- PB\_Px\_IACK

## 13.3.2.1 Processor Bus Configuration Data

Generating a Configuration transaction on PCI requires the programming of the "Processor Bus PCI Configuration Cycle Information Register" on page 352 (PB\_CONF\_INFO) to set-up the address of the Configuration cycle. The DEST bit selects the PCI bus for the configuration access. The PCI transaction is generated when the user performs a register access to the "Processor Bus Configuration Cycle Data Register" on page 355 (PB\_CONF\_DATA).

When a register write is performed to PB\_CONF\_DATA, the address and data parameters in PB\_CONF\_DATA are used to generate a Configuration transaction on the selected PCI bus.

The Processor Bus Slave response to the read of PB\_CONF\_DATA is dependent on the state the Address Retry Enable (ARTRY\_EN) bit of the "Processor Bus Miscellaneous Control and Status Register" on page 361. If ARTRY\_EN is disabled, the Processor Bus slave claims the read of PB\_CONF\_DATA. The Processor Bus slave only asserts PB\_TA\_ to complete the transaction when the read data is returned from PCI. If ARTRY\_EN is enabled, the read of PB\_CONF\_DATA will be retried immediately. Subsequent register accesses to PB\_CONF\_DATA will be retried until the data is returned from PCI.

## 13.3.2.2 Interrupt Acknowledge Generation

The PB\_Px\_IACK registers are used to generate IACK reads on the PCI interfaces. The address for the IACK cycle is taken directly from the processor bus.

The Processor Bus slave response to the read of PB\_Px\_IACK is dependent on the state of the Address Retry Enable (ARTRY\_EN) bit of the "Processor Bus Miscellaneous Control and Status Register" on page 361. If ARTRY\_EN is disabled, the Processor Bus slave claims the read of PB\_Px\_IACK. The Processor Bus slave only asserts PB\_TA\_ to complete the transaction when the read data is returned from PCI. If ARTRY\_EN is enabled, the read of PB\_Px\_IACK is retried immediately. Subsequent register accesses to PB\_Px\_IACK are retried until the data is returned from PCI.

Applications that require more than one agent to generate IACK transactions on PCI must use a semaphore to control PB\_P1\_IACK and PB\_P2\_IACK.



Writes to PB\_Px\_IACK have no effect.

# 13.4

# 4 Bit Ordering and Endian Ordering

The register tables in "Register Descriptions" on page 298 provide bit ordering in both PCI little-endian and PowerPC big-endian. The register table from the "PCI 1 Control and Status Register" on page 301 is repeated here. The "PCI Bits" in the left hand column give the addressing of the register bits when the register is accessed from the PCI bus in little-endian mode. The "PB Bits" in the far right hand column give the addressing of the register bits when the register is accessed from the PCI bus in little-endian mode. The "PB Bits" in the far right hand column give the addressing of the register bits when the register is accessed from the Processor Bus in big-endian mode.

| PCI<br>Bits |                                  |            |       | Fund       | ction |     |      |       | PB<br>Bits |
|-------------|----------------------------------|------------|-------|------------|-------|-----|------|-------|------------|
| 31-24       | D_PE                             | S_<br>SERR | R_MA  | R_TA       | S_TA  | DEV | /SEL | MDP_D | 0-7        |
| 23-16       | TFBBC 0 DEV66 CAP_L PCI Reserved |            |       | 8-15       |       |     |      |       |            |
| 15-08       | PCI Reserved MFBBC SERR_<br>EN   |            |       | 16-23      |       |     |      |       |            |
| 07-00       | WAIT                             | PERES<br>P | VGAPS | MWI_<br>EN | SC    | BM  | MS   | IOS   | 24-31      |

Please consult "Endian Mapping" on page 213 for a full endian discussion.



Throughout the manual, register fields are given assuming PCI littleendian bit ordering. The user must consult the register table to obtain the corresponding PowerPC big-endian bit ordering.

# 13.5 Register Descriptions

In the following detailed descriptions of each register, the shaded register bits are different for the Dual PCI PowerSpan II and Single PCI PowerSpan II

 Table 75 describes the abbreviations used in the register descriptions.

Table 75: Abbreviations used in Register Descriptions

| Abbreviation       | Description                                                              |
|--------------------|--------------------------------------------------------------------------|
| G_RST              | General Reset (Active when either PB_RST, P1_RST, or P2_RST is asserted) |
| PB_RST             | Processor Bus Reset                                                      |
| P1_RST             | PCI-1 (P1) Reset                                                         |
| P2_RST             | PCI-2 (P2) Reset                                                         |
| Px_RST             | PCI-1 or PCI-2 Reset                                                     |
| PRI_RST            | Primary PCI Reset                                                        |
| R/W                | Read/Write                                                               |
| R                  | Read Only                                                                |
| R/Write 1 to Clear | Read/Write 1 to Clear                                                    |

| Abbreviation               | Description                                                        |
|----------------------------|--------------------------------------------------------------------|
| Write 1 to Set             | Read 0/Write 1 to Set (Writing a 1 triggers an event)              |
| R/WPB                      | Read Only from PCI, Read/Write from Processor Bus                  |
| 0<br>EEPROM                | Reset value is 0. Register bit may be loaded by EEPROM after reset |
| 1<br>EEPROM                | Reset value is 1. Register bit may be loaded by EEPROM after reset |
| PWRUP                      | Register bit loaded as a power-up option                           |
| PCI Reserved               | Do not write. Read back 0                                          |
| PCI Unimplemented          | Do not write. Read back 0                                          |
| PowerSpan II<br>Reserved   | Do not write. Read back undefined                                  |
| Reserved                   | Do not write. Read back undefined                                  |
| Single PCI<br>PowerSpan II | Single PCI PowerSpan II (PCI-1 and Processor Bus)                  |

 Table 75: Abbreviations used in Register Descriptions

# 13.5.1 PCI-1 ID Register

This register is Read Only from PCI-1 and Read/Write from the Processor Bus Interface.

# Table 76: PCI 1 ID Register

| Registe     | r Name: P1_ID | Register Offse | t: 0x000   |
|-------------|---------------|----------------|------------|
| PCI<br>Bits | Fun           | ction          | PB<br>Bits |
| 31-24       | D             | ID             | 0-7        |
| 23-16       | D             | ID             | 8-15       |
| 15-08       | V             | ID             | 16-23      |
| 07-00       | V             | ID             | 24-31      |

## P1\_ID Description

| Name      | Туре                                | Reset<br>By | Reset<br>State   | Function                                         |
|-----------|-------------------------------------|-------------|------------------|--------------------------------------------------|
| DID[15:0] | R/Write<br>from<br>processor<br>bus | P1_RST      | 0x8260<br>EEPROM | Device ID<br>Tundra allocated Device Identifier  |
| DID[15:0] | R/Write<br>from<br>processor<br>bus | P1_RST      | 0x8261           | Single PCI PowerSpan II                          |
| VID[15:0] | R/Write<br>from<br>processor<br>bus | P1_RST      | 0x10E3<br>EEPROM | Vendor ID<br>PCI SIG allocated Vendor Identifier |

# 13.5.2 PCI-1 Control and Status Register.

# Table 77: PCI 1 Control and Status Register

| Register Name: P1_CSR |                                |            |       |            |                   |        | Regi    | ster Offset | : 0x004    |
|-----------------------|--------------------------------|------------|-------|------------|-------------------|--------|---------|-------------|------------|
| PCI<br>Bits           | Function                       |            |       |            |                   |        |         |             | PB<br>Bits |
| 31-24                 | D_PE                           | S_<br>SERR | R_MA  | R_TA       | S_TA DEVSEL MDP_D |        |         |             | 0-7        |
| 23-16                 | TFBBC                          | 0          | DEV66 | CAP_L      |                   | PCI Re | eserved |             | 8-15       |
| 15-08                 | PCI Reserved MFBBC SERR_<br>EN |            |       |            |                   |        | 16-23   |             |            |
| 07-00                 | WAIT                           | PERES<br>P | VGAPS | MWI_<br>EN | SC                | BM     | MS      | IOS         | 24-31      |

## P1\_CSR Description

| Name   | Туре              | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                              |
|--------|-------------------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D_PE   | R/W 1 to<br>clear | P1_RST      | 0              | Detected Parity Error<br>0 = No Parity Error, 1 = Parity Error<br>This bit is set by the device whenever the Master<br>Module detects a data parity error or the Target<br>Module detects a data or address parity error.             |
| S_SERR | R/W 1 to<br>clear | P1_RST      | 0              | Signaled SERR#<br>0 = SERR# not asserted, 1 = SERR# asserted<br>The device as PCI Target sets this bit when it<br>asserts SERR# to signal an address parity error.<br>SERR_EN and PERESP must be set before<br>SERR# can be asserted. |
| R_MA   | R/W 1 to<br>clear | P1_RST      | 0              | Received Master Abort<br>0 = device did not generate Master-Abort<br>1 = device generated Master Abort<br>The device sets this bit when a transaction it<br>initiated had to be terminated with a Master-Abort.                       |

## P1\_CSR Description (Continued)

|              |                   | Reset  | Reset |                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------------------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name         | Туре              | Ву     | State | Function                                                                                                                                                                                                                                                                                                                                         |
| R_TA         | R/W 1 to<br>clear | P1_RST | 0     | Received Target Abort<br>0 = device did not detect Target-Abort<br>1 = device detected Target-Abort<br>The device sets this bit when a transaction it<br>initiated was terminated with a Target-Abort.                                                                                                                                           |
| S_TA         | R/W 1 to<br>clear | P1_RST | 0     | Signaled Target-Abort<br>0 = device Target Module did not terminate<br>transaction with Target-Abort<br>1 = device Target Module terminated transaction<br>with Target-Abort.                                                                                                                                                                    |
| DEVSEL [1:0] | R                 | P1_RST | 01    | Device Select Timing<br>The device is a medium speed device.                                                                                                                                                                                                                                                                                     |
| MDP_D        | R/W 1 to<br>clear | P1_RST | 0     | Master Data Parity 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 device sets this bit if the PERESP bit is set<br>and either (a) it is the master of the transaction in<br>which it asserts PERR#, or (b) the addressed<br>target asserts PERR# |
| TFBBC        | R                 | P1_RST | 0     | Target Fast Back to Back Capable<br>The device cannot accept fast back to back<br>transactions                                                                                                                                                                                                                                                   |
| DEV66        | R                 | P1_RST | 1     | Device 66 MHz<br>The device is a 66 MHz capable device                                                                                                                                                                                                                                                                                           |
| CAP_L        | R                 | P1_RST | PWRUP | Capabilities List<br>0 = capabilities list unsupported<br>1 = capabilities list supported                                                                                                                                                                                                                                                        |
| MFBBC        | R                 | P1_RST | 0     | Master Fast Back to Back Enable<br>The device does not generate fast back to back<br>transactions                                                                                                                                                                                                                                                |

# P1\_CSR Description (Continued)

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SERR_EN | R/W  | P1_RST      | 0              | SERR# Enable<br>0 = Disable SERR# driver<br>1 = Enable SERR# driver<br>Setting this and PERESP allows the device to<br>report address parity errors with SERR# as PCI<br>target.                                                                                                                                                                                                     |
| WAIT    | R    | P1_RST      | 0              | Wait Cycle Control<br>0 = No address/data stepping                                                                                                                                                                                                                                                                                                                                   |
| PERESP  | R/W  | P1_RST      | 0              | Parity Error Response<br>0 = Disable<br>1 = Enable<br>Controls the device's response to address and<br>data parity errors. When enabled, PERR# is<br>asserted and the MDP_D bit is set in response to<br>data parity errors. When this bit and SERR_EN are<br>set, the device reports address parity errors on<br>SERR#. This bit does not affect the device's parity<br>generation. |
| VGAPS   | R    | P1_RST      | 0              | VGA Palette Snoop<br>0 = Disable                                                                                                                                                                                                                                                                                                                                                     |
| MWI_EN  | R    | P1_RST      | 0              | Memory Write and Invalidate Enable<br>0 = Disable<br>PowerSpan II does not generate MWI transactions.                                                                                                                                                                                                                                                                                |
| SC      | R    | P1_RST      | 0              | Special Cycles<br>0 = Disable<br>The device does not respond to Special cycles as<br>a PCI target.                                                                                                                                                                                                                                                                                   |
| ВМ      | R/W  | P1_RST      | 0<br>EEPROM    | Bus Master<br>Enables the device to generate cycles as a PCI<br>Master.<br>0 = Disable, 1 = Enable                                                                                                                                                                                                                                                                                   |

| Name | Туре | Reset<br>By | Reset<br>State | Function                                                                                                  |
|------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------|
| MS   | R/W  | P1_RST      | 0<br>EEPROM    | Memory Space<br>0 = Disable, 1 = Enable<br>Enables the device to accept Memory cycles as a<br>PCI target. |
| IOS  | R    | P1_RST      | 0              | IO Space<br>0 = Disable<br>The device does not respond to I/O cycles as a<br>PCI target.                  |

P1\_CSR Description (Continued)

**CAP\_L:** The capabilities list is only supported by the Primary PCI Interface. When PCI-1 is the Primary Interface, CAP\_L in PCI-1 is set and CAP\_L in PCI-2 is cleared. The opposite is true when PCI-2 is the Primary Interface. The Primary PCI Interface is determined by the PWRUP\_PRI\_PCI power-up option.

# 13.5.3 PCI-1 Class Register

## Table 78: PCI 1 Class Register

| Registe     | r Name: P1_CLASS | Register Offset: | 0x008      |  |  |
|-------------|------------------|------------------|------------|--|--|
| PCI<br>Bits | Fund             | ction            | PB<br>Bits |  |  |
| 31-24       | ВА               | BASE             |            |  |  |
| 23-16       | SUB              |                  |            |  |  |
| 15-08       | PR               | OG               | 16-23      |  |  |
| 07-00       | R                | D                | 24-31      |  |  |

## P1\_CLASS Description

| Name      | Туре  | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                  |
|-----------|-------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BASE[7:0] | R/WPB | P1_RST      | 0x06<br>EEPROM | Base Class Code<br>0x06 = Bridge Device (default)<br>0x0E = I2O controller                                                                                                                                                                                |
| SUB[7:0]  | R/WPB | P1_RST      | 0x80<br>EEPROM | Sub Class Code<br>0x80 = Other bridge device (if BASE = 0x06)<br>0x00 = I2O Device (if BASE = 0x0E)                                                                                                                                                       |
| PROG[7:0] | R/WPB | P1_RST      | 0x00<br>EEPROM | Programming Interface<br>0x00 = Other Bridge Device (if BASE = 06)<br>0x01 = I2O Inbound and Outbound Queues<br>mapped to offsets 0x40 and 0x44 respectively, and<br>I2O Interrupt Status and Mask registers at offsets<br>0x30 and 0x34 (if BASE = 0x0E) |
| RID[7:0]  | R/WPB | P1_RST      | 0x01<br>EEPROM | Revision ID<br>PowerSpan II - 0x01                                                                                                                                                                                                                        |

**BASE[7:0]:** When PowerSpan II is an  $I_2O$  controller, this field must be programmed with 0x0E either from the Processor Bus or by EEPROM.

**SUB[7:0]:** When PowerSpan II is an  $I_2O$  controller, this field must be programmed with 0x00 either from the Processor Bus or by EEPROM.

**PROG**[7:0]: When PowerSpan II is an  $I_2O$  controller, this field must be programmed with 0x01 either from the Processor Bus or by EEPROM.

# 13.5.4 PCI-1 Miscellaneous 0 Register

# Table 79: PCI 1 Miscellaneous 0 Register

| Registe     | er Name: P1  | _MISC0             |    | Register Offset: | 0x00C |  |  |
|-------------|--------------|--------------------|----|------------------|-------|--|--|
| PCI<br>Bits |              |                    |    |                  |       |  |  |
| 31-24       | BISTC        | SBIST PCI Reserved |    | CCODE            | 0-7   |  |  |
| 23-16       | MFUNCT       | LAYOUT 8-15        |    |                  |       |  |  |
| 15-08       | LTIMER 16-23 |                    |    |                  |       |  |  |
| 07-00       |              |                    | CL | INE              | 24-31 |  |  |

## P1\_MISC0 Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                         |
|--------------|------|-------------|----------------|------------------------------------------------------------------|
| BIST         | R    | P1_RST      | 0              | BIST Capable<br>0 = device is not BIST capable                   |
| SBIST        | R    | P1_RST      | 0              | Start BIST<br>0 = device is not BIST capable                     |
| CCODE [3:0]  | R    | P1_RST      | 0              | Completion Code<br>0 = device is not BIST capable                |
| MFUNCT       | R    | P1_RST      | 0              | Multifunction Device<br>0 = device is not a multifunction device |
| LAYOUT [6:0] | R    | P1_RST      | 0              | Configuration Space Layout                                       |

#### P1\_MISC0 Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LTIMER [7:0] | R/W  | P1_RST      | 0              | Latency Timer<br>Number of PCI bus clocks before the device must<br>initiate termination of transaction as a master.<br>Resolution of one clock.                                                                                                                                                                                                                                                                               |
| CLINE[7:0]   | R/W  | P1_RST      | 0              | Cacheline Size<br>Specifies the cacheline size for this interface, in<br>number of 32-bit words. Valid settings are 4, 8, 16<br>or 32 words. Default setting is 8 words. All other<br>settings default to 8 words.<br>$0x00 = 8 \times 32$ -bit words<br>$0x04 = 4 \times 32$ bit words<br>$0x08 = 8 \times 32$ -bit words<br>$0x10 = 16 \times 32$ -bit words<br>$0x20 = 32 \times 32$ bit words<br>others = 8 x 32-bit words |

**LTIMER**[7:0]: This field specifies the value of the Latency Timer for the PCI-1 Master in units of PCI bus clocks. The latency timer provides a resolution of one PCI bus clock. This timer always has a minimum value of eight PCI bus clocks. The values 000b-111b correspond to eight clock cycles.

**CLINE**[7:0] The CLINE Size specifies the system cacheline size in units of 32-bit words. The CLINE is used by the PowerSpan II PCI Master in determining which PCI Read cycle it generates on PCI (MR, MRL, MRM). Table 80 shows the relationship between the read amount and the read command.

| Read Amount | Read Command         |
|-------------|----------------------|
| < 8 bytes   | Memory Read          |
| <= CLINE    | Memory Read Line     |
| > CLINE     | Memory Read Multiple |

# 13.5.5 PCI-1 I2O Target Image Base Address Register

This register specifies the 64 KByte aligned base address of the device's PCI  $I_2O$ Target Image in PCI Memory space. PowerSpan II only supports the  $I_2O$  Target Image on the Primary PCI Interface.

| Registe     | r Name: P | 91_BSI2O |   |      |            |            | Regi | ster Offset | : 0x010    |
|-------------|-----------|----------|---|------|------------|------------|------|-------------|------------|
| PCI<br>Bits |           |          |   | Fund | ction      |            |      |             | PB<br>Bits |
| 31-24       | BA        |          |   |      |            |            |      |             | 0-7        |
| 23-16       | BA        |          |   |      |            |            |      | 8-15        |            |
| 15-08       | 0         | 0        | 0 | 0    | 0          | 0          | 0    | 0           | 16-23      |
| 07-00       | 0         | 0        | 0 | 0    | PRFTC<br>H | TYPE SPACE |      | 24-31       |            |

## Table 81: PCI 1 I2O Target Image Base Address Register

#### P1\_BSI2O Description

| Name       | Туре  | Reset<br>By | Reset<br>State | Function                                             |
|------------|-------|-------------|----------------|------------------------------------------------------|
| BA[15:0]   | R/W   | P1_RST      | 0              | Base Address                                         |
| PRFTCH     | R/WPB | P1_RST      | 1<br>EEPROM    | Prefetchable<br>Memory is prefetchable               |
| TYPE [1:0] | R     | P1_RST      | 0              | Type<br>00 = locate anywhere in 32-bit address space |
| SPACE      | R     | P1_RST      | 0              | PCI Bus Address Space<br>0 = Memory                  |

The first 4 Kbytes of this image provides the  $I_2O$  Shell Interface Inbound and Outbound Queues and the Host Interrupt Status and Mask Registers. Cycles claimed by the PowerSpan II  $I_2O$  Target Image with offsets greater than 4 Kbytes is passed on to the Processor Bus. The control information for the PowerSpan II  $I_2O$  Target Image is fully defined in the PCI\_TI2O\_CTL and PCI\_TI2O\_TADDR registers.

A write must occur to this register before the device's  $I_2O$  Target Image is accessed through PCI Memory transactions. This write can be performed with either a PCI configuration transaction or a register access by the local processor.

A Base Address of 0x00000 is not a supported base address and the register image does not respond to PCI transactions as a target device when 0x00000 is written to this field — the image is disabled. PowerSpan II supports a Base Address of 0x00000 if the BAR\_EQ\_0 bit is set in the MISC\_CSR register (see page 378).

The BS field in the PCI\_TI2O\_CTL register determines the size of the image requested in PCI Memory space for the PCI I<sub>2</sub>O Target Image.

Writes are enabled to this register only if the BAR\_EN bit in the PCI\_TI2O\_CTL register is set.

This register is not implemented in the Secondary PCI Interface

# 13.5.6 PCI-1 Register Image Base Address Register

This register specifies the 4-KByte aligned base address of the device's register space in PCI Memory Space. The Register space is only 4 KByte, therefore the PCI address lines [11:0] are used to select the register.

## Table 82: PCI 1 Register Image Base Address Register

| Register Name: P1_BSREG |    |          |  |  |            |    | Regi | ster Offset | : 0x014 |  |
|-------------------------|----|----------|--|--|------------|----|------|-------------|---------|--|
| PCI<br>Bits             |    | Function |  |  |            |    |      |             |         |  |
| 31-24                   | BA |          |  |  |            |    |      |             | 0-7     |  |
| 23-16                   | ВА |          |  |  |            |    |      |             | 8-15    |  |
| 15-08                   | ВА |          |  |  | 0          | 0  | 0    | 0           | 16-23   |  |
| 07-00                   | 0  | 0 0 0 0  |  |  | PRFTC<br>H | ΤY | PE   | SPACE       | 24-31   |  |

#### P1\_BSREG Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                                             |
|------------|------|-------------|----------------|------------------------------------------------------|
| BA[19:0]   | R/W  | P1_RST      | 0              | Base Address                                         |
| PRFTCH     | R    | P1_RST      | 0              | Prefetchable<br>memory is not prefetchable           |
| TYPE [1:0] | R    | P1_RST      | 0              | Type<br>00 = locate anywhere in 32-bit address space |
| SPACE      | R    | P1_RST      | 0              | PCI Bus Address Space<br>0 = Memory                  |

A write must occur to this register before the device's registers can be accessed through PCI memory transactions. This write can be performed with a PCI Configuration transaction or a register access by the local processor.

A Base Address of 0x00000 is not a supported base address and the register image does not respond to PCI transactions as a target device when 0x00000 is written to this field — the image is disabled. PowerSpan II supports a Base Address of 0x00000 if the BAR\_EQ\_0 bit is set in the MISC\_CSR register (see page 378).

Writes are enabled to this register only when the BSREG\_BAR\_EN bit in the P1\_MISC\_CSR register is set.

#### Table 83: PCI 1 Target Image X Base Address Register

Register Name:P1\_BSTxRegister Offset:0x018, 0x01C, 0x020, 0x024

| PCI<br>Bits | Function |    |   |   |            |    |    |       | PB<br>Bits |
|-------------|----------|----|---|---|------------|----|----|-------|------------|
| 31-24       |          | ВА |   |   |            |    |    |       | 0-7        |
| 23-16       | BA       |    |   |   |            |    |    | 8-15  |            |
| 15-08       | 0        | 0  | 0 | 0 | 0          | 0  | 0  | 0     | 16-23      |
| 07-00       | 0        | 0  | 0 | 0 | PRFTC<br>H | ΤY | PE | SPACE | 24-31      |

#### P1\_BSTx Description

| Name       | Туре  | Reset<br>By | Reset<br>State | Function                                             |
|------------|-------|-------------|----------------|------------------------------------------------------|
| BA[15:0]   | R/W   | P1_RST      | 0              | Base Address                                         |
| PRFTCH     | R/WPB | P1_RST      | 1<br>EEPROM    | Prefetchable<br>memory is prefetchable               |
| TYPE [1:0] | R     | P1_RST      | 0              | Type<br>00 = locate anywhere in 32-bit address space |
| SPACE      | R     | P1_RST      | 0              | PCI Bus Address Space<br>0 = Memory Space            |

This register specifies the 64-KByte aligned base address of the device's PCI Target Image *x* in PCI Memory space.

A write must occur to this register before the device's PCI Target Image X is accessed through PCI Memory transactions. This write is performed with a PCI Configuration transaction or a register access by the local processor.

A Base Address of 0x00000 is not a supported base address and the register image does not respond to PCI transactions as a target device when 0x00000 is written to this field — the image is disabled. PowerSpan II supports a Base Address of 0x00000 if the BAR\_EQ\_0 bit is set in the MISC\_CSR register (see page 378).

The BS field of the P1\_TIx\_CTL register will determine the size of the image requested in PCI memory space for PCI Target Image X.

Writes are enabled to this register only when the BAR\_EN bit in the P1\_TIx\_CTL register is set.

Reads from this image are treated as prefetchable. The PRFTCH field is programmable to provide flexibility for the BIOS.

## Table 84: PCI 1 Subsystem ID Register

| Registe     | r Name: P1_SID | Register Offset | 0x02C      |
|-------------|----------------|-----------------|------------|
| PCI<br>Bits | Fund           | ction           | PB<br>Bits |
| 31-24       | S              | ID              | 0-7        |
| 23-16       | S              | ID              | 8-15       |
| 15-08       | S\             | /ID             | 16-23      |
| 07-00       | S\             | /ID             | 24-31      |

#### **P1\_SID Description**

| Name       | Туре  | Reset<br>By | Reset<br>State | Function                                                                                                                                          |
|------------|-------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| SID[15:0]  | R/WPB | P1_RST      | 0<br>EEPROM    | Subsystem ID<br>Values for subsystem ID are vendor specific                                                                                       |
| SVID[15:0] | R/WPB | P1_RST      | 0<br>EEPROM    | Subsystem Vendor ID<br>Subsystem Vendor IDs are obtained from the PCI<br>SIG and used to identify the vendor of the add-in<br>board or subsystem. |

Writes to the PCI\_SID register from the processor propagates to its contents. Writes to the P1\_SID register from the PCI bus have no effect on its contents.

# 13.5.7 PCI-1 Capability Pointer Register

Table 85: PCI 1 Capability Pointer Register

| Registe     | r Name: P1_CAP |       | Regi | ster Offset | : 0x034    |  |
|-------------|----------------|-------|------|-------------|------------|--|
| PCI<br>Bits | Fun            | ction |      |             | PB<br>Bits |  |
| 31-24       | PCI Reserved   |       |      |             |            |  |
| 23-16       | PCI Reserved   |       |      |             |            |  |
| 15-08       | PCI Reserved   |       |      |             |            |  |
| 07-00       | CAP_PTR        |       | 0    | 0           | 24-31      |  |

## P1\_CAP Description

| Name             | Туре | Reset<br>By | Reset<br>State | Function             |
|------------------|------|-------------|----------------|----------------------|
| CAP_PTR<br>[7:0] | R    | P1_RST      | 0xE4           | Capabilities Pointer |

The CAP\_PTR indicates the register offset in PCI configuration space of the first capabilities pointer in the capabilities linked-list.

This register is not implemented in the Secondary PCI Interface

# 13.5.8 PCI-1 Miscellaneous 1 Register

## Table 86: PCI 1 Miscellaneous 1 Register

| Registe     | r Name: P1_MISC1 | Register Offset: | 0x03C      |
|-------------|------------------|------------------|------------|
| PCI<br>Bits | Fun              | ction            | PB<br>Bits |
| 31-24       | МАХ              | LAT              | 0-7        |
| 23-16       | MIN              | GNT              | 8-15       |
| 15-08       | INT              | PIN              | 16-23      |
| 07-00       | INT_             | LINE             | 24-31      |

#### P1\_MISC1 Description

| Name              | Туре  | Reset<br>By | Reset<br>State | Function                                                                                    |
|-------------------|-------|-------------|----------------|---------------------------------------------------------------------------------------------|
| MAX_LAT<br>[7:0]  | R/W   | P1_RST      | 0              | Maximum Latency<br>No special latency requirements                                          |
| MIN_GNT<br>[7:0]  | R/W   | P1_RST      | 0              | Minimum Grant<br>No special requirements                                                    |
| INT_PIN [7:1]     | R     | P1_RST      | 0              | Interrupt Pin (7 to 1)                                                                      |
| INT_PIN [0]       | R/WPB | P1_RST      | 1<br>EEPROM    | Interrupt Pin<br>0 = The device does not use any PCI interrupts<br>1 = The device uses INTA |
| INT_LINE<br>[7:0] | R/W   | P1_RST      | 0              | Interrupt Line                                                                              |

**MAX\_LAT[7:0]**: This field specifies how often the device needs access to the PCI bus.

**MIN\_GNT[7:0]:** This field indicates how long a master wants to retain bus ownership whenever it initiates a transaction.

**INT\_PIN** [7:1]: This field represents general purpose interrupt pins. Interrupt pins are active low and, when configured as input, are sampled on three successive processor bus clock edges to ensure appropriate setting of a status bit.

Each pin is bidirectional, open drain, active low and level sensitive. The input/ output character of each interrupt pin is controlled through a corresponding bit in the "Interrupt Direction Register" on page 410. Each pin can be configured as either an input or output. All pins are configured as inputs by default.

**INT\_PIN[0]:** This interrupt pin is used to enable PCI interrupts. If this bit is not set, PowerSpan II does not use PCI interrupts. Setting this bit enables a single function PCI device to use INTA#.

**INT\_LINE**[7:0]: This read/write interrupt line field is used to identify which of the system interrupt request lines on the interrupt controller the device's interrupt request pin is routed to.

# 13.5.9 PCI-1 Compact PCI Hot Swap Control and Status Register

PowerSpan II supports *CompactPCI Hot Swap Specification Revision 2.0* and is a Hot Swap Silicon Device.

This register controls CompactPCI Hot Swap support in PowerSpan II. The Hot Swap functionality is enabled in the Primary PCI Interface of PowerSpan II. In the Single PCI PowerSpan II the lone PCI Interface is enabled as Primary, but in the Dual PCI PowerSpan II only one of the two ports can be enabled as Primary.

## Table 87: PCI 1 Compact PCI Hot Swap Control and Status Register

| Registe     | r Name: P    | 1_HS_CSR               |  |  |  | Regi | ster Offset | : 0x0E4 |  |
|-------------|--------------|------------------------|--|--|--|------|-------------|---------|--|
| PCI<br>Bits |              | Function               |  |  |  |      |             |         |  |
| 31-24       | PCI Reserved |                        |  |  |  |      |             | 0-7     |  |
| 23-16       | INS          | INS EXT PI LOO 0 EIM 0 |  |  |  |      | 0           | 8-15    |  |
| 15-08       | NXT_PTR      |                        |  |  |  |      |             | 16-23   |  |
| 07-00       |              | CAP_ID                 |  |  |  |      |             |         |  |

#### P1\_HS\_CSR Description

| Name | Туре                  | Reset<br>By | Reset<br>State | Function                                                                          |
|------|-----------------------|-------------|----------------|-----------------------------------------------------------------------------------|
| INS  | R/Write 1 to<br>clear | P1_RST      | 0              | ENUM# Status - Insertion<br>1 = ENUM# Asserted<br>0 = ENUM# Negated               |
| EXT  | R/Write 1 to<br>clear | P1_RST      | 0              | ENUM_ Status - Extraction<br>1 = ENUM# Asserted<br>0 = ENUM# Negated              |
| PI   | R                     | P1_RST      | 0              | Programming Interface<br>00 = INS, EXT, LOO, EIM supported<br>01,10,11 = Reserved |
| LOO  | R/W                   | P1_RST      | 0              | LED ON/OFF<br>1 = LED On<br>0 = LED Off                                           |

| Name             | Туре | Reset<br>By | Reset<br>State              | Function                                                  |
|------------------|------|-------------|-----------------------------|-----------------------------------------------------------|
| EIM              | R/W  | P1_RST      | 0                           | ENUM# Signal Mask<br>1 = Mask Signal<br>0 = Enable Signal |
| NXT_PTR<br>[7:0] | R    | P1_RST      | 0xE8 or 0<br>(See<br>Below) | Next Pointer                                              |
| CAP_ID [7:0]     | R    | P1_RST      | 0x06                        | Capability ID                                             |

## P1\_HS\_CSR Description

**PI:** Programming interface bit indicates the programming interface supported by the board. PowerSpan II implements a bit value of 0, which means INS, EXT, LOO, EIM are supported. Refer to the *CompactPCI Hot Swap Specification Revision 2.0* for more information

**NEXT\_PTR**: If MISC\_CSR[VPD\_EN] is set and an external EEPROM is detected, then this field reads back 0xE8. When the VPD\_EN bit in the MISC\_CSR register is cleared or an external EEPROM is not detected, this field reads back 0.

This register is not implemented in the Secondary PCI Interface.

# 13.5.10 PCI-1 Vital Product Data Capability Register

PowerSpan II only supports VPD access from the Primary PCI Interface. The Secondary PCI Interface reads zero for VPD accesses. VPD writes have no effect.

| Registe     | r Name: F     | P1_VPDC      | Register Offs | et: 0E8    |  |  |
|-------------|---------------|--------------|---------------|------------|--|--|
| PCI<br>Bits |               | Fund         | ction         | PB<br>Bits |  |  |
| 31-24       | F             | F Reserved   |               |            |  |  |
| 23-16       | VPDA          |              |               |            |  |  |
| 15-08       | NXT_PTR 16-23 |              |               |            |  |  |
| 07-00       |               | CAP_ID 24-31 |               |            |  |  |

## Table 88: PCI 1 Vital Product Data Capability Register

#### P1\_VPDC Description

| Name             | Туре | Reset<br>By | Reset<br>State | Function                                                      |
|------------------|------|-------------|----------------|---------------------------------------------------------------|
| F                | R/W  | P1_RST      | 0              | Data Transfer Complete Flag                                   |
| VPDA [7:0]       | R/W  | P1_RST      | 0x00           | Vital Product Data Address                                    |
| NXT_PTR<br>[7:0] | R    | P1_RST      | 0x00           | Next Pointer<br>VPD is the last Extended Capabilities Pointer |
| CAP_ID [7:0]     | R    | P1_RST      | 0x03           | Capability ID                                                 |

**F:** Indicates when the transfer between the VPD Data register and the EEPROM is complete. Software clears the bit to initiate a read and PowerSpan II sets the bit when the read data is available in the VPD Data register. Software sets the bit to initiate a write and PowerSpan II clears the bit to indicate when the data has been transferred.

**VPDA**: The 8-bit address specifies the VPD address offset for the VPD-Read or VPD-Write to the serial EEPROM. When  $I^2C$  chip select 0 is used for the VPD EEPROM the VPD address translates a maximum of 64 bytes and 192 bytes are available for VPD. The first 64 bytes of VPD is VPD-Read Only, and the remaining 128 bytes — 192 bytes if separate 256 byte EEPROM used for VPD — is VPD-Read/Write.

This register is not implemented in the Secondary PCI Interface. It is also disabled when the NXT\_PTR bit in the P1\_HS\_CSR register is 0.

# 13.5.11 PCI-1 Vital Product Data Register

This register is enabled when the VPD\_EN bit in the MISC\_CSR is set to 1. If it is disabled the register always reads zero.

PowerSpan II only supports VPD access from the Primary PCI Interface. The Secondary PCI Interface always reads zero for VPD accesses. VPD writes will have no effect.

This register is not implemented in the Secondary PCI Interface. It is also disabled when the NXT\_PTR bit in the P1\_HS\_CSR register is 0

Table 89: PCI 1 Vital Product Data Register

| Registe     | r Name: P1_VPDD | Register Offset: | 0x0EC      |
|-------------|-----------------|------------------|------------|
| PCI<br>Bits | Fund            | ction            | PB<br>Bits |
| 31-24       | VPD_DATA        |                  |            |
| 23-16       | VPD_            | DATA             | 8-15       |
| 15-08       | VPD_            | DATA             | 16-23      |
| 07-00       | VPD_            | DATA             | 24-31      |

## P1\_VPDD Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function |
|--------------------|------|-------------|----------------|----------|
| VPD_DATA<br>[31:0] | R/W  | P1_RST      | 0              | VPD Data |

# 13.5.12 PCI-1 Target Image x Control Register

This register contains the control information for the PowerSpan II PCI 1 Target Image x. The Image is enabled for decode when both IMG\_EN and BAR\_EN are set.



The bits in this register are not dynamic. Do not alter these settings while transactions are being processed through PowerSpan II. Refer to "Translation Address Mapping" on page 349 for more information on dynamic address translation.

## Table 90: PCI 1 Target Image x Control Register

| Register Name: P1_TIx_CTL |            |       |            |          | Regi | ister Offset: 0x100, 0x110, 0x120 | 0, 0x130 |
|---------------------------|------------|-------|------------|----------|------|-----------------------------------|----------|
| PCI<br>Bits               | Function   |       |            |          |      |                                   |          |
| 31-24                     | IMG_EN     | TA_EN | BAR_<br>EN | MD_EN BS |      |                                   | 0-7      |
| 23-16                     | MODE       | DEST  | MEM_IO     |          | RTT  |                                   |          |
| 15-08                     | GBL        | CI    | 0          | WTT      |      |                                   | 16-23    |
| 07-00                     | PR<br>KEEP | 13    | ND         | MRA      | 0    | RD_AMT                            | 24-31    |

## P1\_TIx\_CTL Description

| Name   | Туре | Reset<br>By | Reset<br>State | Function                                                      |
|--------|------|-------------|----------------|---------------------------------------------------------------|
| IMG_EN | R/W  | P1_RST      | 0              | Image Enable<br>0 = Disable<br>1 = Enable                     |
| TA_EN  | R/W  | P1_RST      | 0              | Translation Address Enable<br>0 = Disable<br>1 = Enable       |
| BAR_EN | R/W  | P1_RST      | 1<br>EEPROM    | PCI Base Address Register Enable<br>0 = Disable<br>1 = Enable |

## P1\_TIx\_CTL Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                              |
|----------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MD_EN    | R/W  | P1_RST      | 0              | Master Decode Enable<br>0=Disable<br>1=Enable                                                                                                                                                                         |
| BS[3:0]  | R/W  | P1_RST      | 0<br>EEPROM    | Block Size<br>(64 Kbyte * 2 <sup>BS</sup> )                                                                                                                                                                           |
| MODE     | R/W  | P1_RST      | 0              | Image Mode<br>0 = Memory command generation<br>1 = I/O command generation or 4 byte memory<br>read (see Table 92 on page 326)                                                                                         |
| DEST     | R/W  | P1_RST      | 0              | Destination Bus<br>0 = Processor Bus<br>1 = PCI-2 Bus                                                                                                                                                                 |
|          |      |             |                | Single PCI PowerSpan II: Reserved<br>Processor Bus is the only destination.                                                                                                                                           |
| MEM_IO   | R/W  | P1_RST      | 0              | MEM_IO mode<br>0 = Regular IO mode<br>1 = Enables 4 byte reads on the processor (60x)<br>bus or 1,2,3 or 4 byte memory reads on the PCI<br>bus(es). The bus that the read occurs on is<br>controlled by the DEST bit. |
| RTT[4:0] | R/W  | P1_RST      | 0b01010        | Processor Bus Read Transfer Type (PB_TT[0:4])<br>01010 = Read                                                                                                                                                         |
| GBL      | R/W  | P1_RST      | 0              | Global<br>0 = Assert PB_GBL_<br>1 = Negate PB_GBL_                                                                                                                                                                    |
| CI       | R/W  | P1_RST      | 0              | Cache Inhibit<br>0 = Assert PB_CI_<br>1 = Negate PB_CI_                                                                                                                                                               |
| WTT[4:0] | R/W  | P1_RST      | 0b00010        | Processor Bus Write Transfer Type (PB_TT[0:4])<br>00010 = Write with flush                                                                                                                                            |

| P1_TIx_CTL | Description |
|------------|-------------|
|------------|-------------|

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                         |
|-------------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| PRKEEP      | R/W  | P1_RST      | 0              | Prefetch Read Keep Data<br>0 = Disable<br>1 = Enable                                                                                             |
| END[1:0]    | R/W  | P1_RST      | 0b10           | Endian Conversion Mode<br>00 = Little-endian<br>01 = PowerPC little-endian<br>10 = Big-endian<br>11 = True little-endian                         |
| MRA         | R/W  | P1_RST      | 0              | PCI Memory Read Alias to Memory Read Multiple<br>0 = Disabled<br>1 = Enabled                                                                     |
| RD_AMT[2:0] | R/W  | P1_RST      | 0              | Prefetch Size<br>Specifies the number of bytes the device<br>prefetches for PCI Memory Read Multiple<br>transactions claimed by the target image |

**IMG\_EN:** The image enable bit is set by the following:

- Non-Zero write to the P1\_BSTx register
- Register write to IMG\_EN

The Image Enable is cleared by writing 0 to the IMG\_EN bit or writing a 0 the P1\_BSTx register (see page 312). IMG\_EN will always read zero if P1\_BSTx is zero.

**TA\_EN:** When set, the Translation Address (P1\_TIx\_TADDR) replaces the upper bits of the PCI x bus address. The new address is used on the destination bus. Clearing the enable bit results in no address translation.

**BAR\_EN**: When this bit is set, the P1\_BSTx register is Read/Write and visible to PCI BIOS Configuration cycles. When this bit is disabled, the P1\_BSTx register is not visible in PCI-1 Configuration space and is read zero only.

Writes to P1\_BSTx have no effect when this bit is cleared. This effectively disables the PowerSpan II P1\_BSTx Image and PowerSpan II does not request PCI Memory space for the image. If the user is clearing this bit, they must also clear P1\_BSTx.

**MD\_EN**: Enables master decode when the internal PCI arbiter is in use —when the P1\_ARB\_EN bit in the RST\_CSR register is set. If MD\_EN is cleared, only the PCI Address and Command are used for transaction decode. If MD\_EN is set, the originating master is included in the transaction decode. A transaction is claimed only if it originates from the master(s) specified in P1\_TIx\_TADDR.

**MRA:** When set, the PCI x Target Image X alias a PCI Memory Read cycle to a PCI Memory Read Multiple cycle and prefetches the number of bytes specified in the RD\_AMT[2:0] field. When MRA is cleared the Target Image prefetches 8 bytes when a PCI Memory Read command is decoded.

**BS:** The block size specifies the size of the image, address lines compared and address lines translated.

| BS[3:0] | Block Size | Address Lines Compared/Translated |
|---------|------------|-----------------------------------|
| 0000    | 64k        | AD31-AD16                         |
| 0001    | 128K       | AD31-AD17                         |
| 0010    | 256K       | AD31-AD18                         |
| 0011    | 512K       | AD31-AD19                         |
| 0100    | 1M         | AD31-AD20                         |
| 0101    | 2M         | AD31-AD21                         |
| 0110    | 4M         | AD31-AD22                         |
| 0111    | 8M         | AD31-AD23                         |
| 1000    | 16M        | AD31-AD24                         |
| 1001    | 32M        | AD31-AD25                         |
| 1010    | 64M        | AD31-AD26                         |
| 1011    | 128M       | AD31-AD27                         |
| 1100    | 256M       | AD31-AD28                         |
| 1101    | 512M       | AD31-AD29                         |
| 1110    | 1G         | AD31-AD30                         |
| 1111    | 2G         | AD31                              |



**MODE:** Determines if the image is used to generate Memory or IO commands on PCI. The MODE is only applicable if the destination is the alternate PCI bus.

• Memory Command Mode:

PCI Memory commands generated on PCI-2.

Bursting is supported.

PRKEEP and RD\_AMT[2:0] are only applicable in Memory Command Mode.

• IO Command Mode

Causes PCI IO commands to be generated on PCI-2. When the image is selected to perform IO commands, transactions are limited to 4 bytes or less. A PCI Master initiated cycle attempting to burst to the image in this mode will be terminated with a Target Disconnect (Retry) after every data beat.

The MODE bit and the MEM\_IO bit work together to control the size of the transaction (see Table 92)..

| MODE Setting | MEM_IO setting | Transaction size                                 |
|--------------|----------------|--------------------------------------------------|
| 0            | 0              | Memory cycle<br>(minimum 8 byte<br>rmemory read) |
| 0            | 1              | Memory cycle<br>(minimum 8 byte<br>memory read)  |
| 1            | 0              | I/O Cycle                                        |
| 1            | 1              | Memory cycle<br>(minimum 4 byte<br>memory read)  |

Table 92: Setting for MODE and MEM\_IO Bits

**END:** This bit sets the endian conversion mode. This field is only applicable if the destination is the Processor Bus.

**DEST:** Selects the destination bus for the transaction.

**MEM\_IO:** PowerSpan II supports 4-byte reads. When this bit is set, I/O commands to the corresponding image generates Memory Read commands on the destination PCI bus (Py) with the same byte enables latched from the source bus transaction. If the destination of the transaction is the PB Interface, a minimum 32-bit aligned, 4-byte read is generated on the processor bus.

The MODE bit and the MEM\_IO bit work together to control the size of the transaction (see Table 92).

**RTT/WTT:** Selects the Transfer Type on the Processor Bus. The register bits RTT[4:0]/WTT[4:0] are mapped to pins PB\_TT[0:4]

**PRKEEP:** Used to hold read data fetched beyond the initial PCI read cycle. When set, subsequent read requests to the same image at the next address retrieves the read data directly from the Switching Fabric instead of causing the destination bus to fetch more data. The read data is invalidated when a read with a non-matching address occurs.

**RD\_AMT[2:0]:** The read amount setting determines different values to prefetch from the destination bus.

| RD_AMT[2:0] | Data Fetched |
|-------------|--------------|
| 000         | 8 bytes      |
| 001         | 16 bytes     |
| 010         | 32 bytes     |
| 011         | 64 bytes     |
| 100         | 128 bytes    |
| 101-111     | Reserved     |

**Table 93: Read Amount** 

# 13.5.13 PCI-1 Target Image x Translation Address Register

### Table 94: PCI 1 Target Image x Translation Address Register

| Register Name: P1_TIx_TADDR |                       |    |    |    | Regi | ster Offset | : 0x104, 0 | x114, 0x12 | 4, 0x134 |
|-----------------------------|-----------------------|----|----|----|------|-------------|------------|------------|----------|
| PCI<br>Bits                 | Function              |    |    |    |      |             |            | PB<br>Bits |          |
| 31-24                       | TADDR                 |    |    |    |      |             | 0-7        |            |          |
| 23-16                       | TADDR                 |    |    |    |      |             | 8-15       |            |          |
| 15-08                       | PowerSpan II Reserved |    |    |    |      |             | 16-23      |            |          |
| 07-00                       | M7                    | M6 | M5 | M4 | М3   | M2          | M1         | 0          | 24-31    |

### P1\_TIx\_TADDR Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                  |
|-------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------|
| TADDR[15:0] | R/W  | P1_RST      | 0              | Translation Address (through substitution)                                                                                |
| M7-M1       | R/W  | P1_RST      | 0              | Master Select<br>0=Do not claim transactions generated by this<br>master<br>1=Claim transactions generated by this master |

**TADDR[15:0]:** When the TA\_EN bit in the P1\_TIx\_CTL register is set, TADDR[15:0] replaces the PCI-1 bus upper address bits. It replaces the upper address bits up to the size of the image.

The TADDR[15:0] field can be changed while transactions are being processed by PowerSpan II. This is the only parameter that can be changed during a transaction. All other programmable parameters must stay constant during a transaction

**M7-M1:** These bits indicate which external master(s) are qualified to access the image. The image supports master decode if the PCI Arbiter is enabled (the P1\_ARB\_EN bit in the RST\_CSR register is set) and when the MD\_EN bit in the P1\_TIx\_CTL register is set.

Table 95 details external arbitration pins associated with bits M7-M1. The shaded combinations in the table identify external arbitration pins which can be used for PCI-1, depending on the programming of the PCI\_M7, PCI\_M6,PCI\_M5 bits in the MISC\_CSR register.

| Register Bit | External Arbitration Pins |
|--------------|---------------------------|
| M1           | P1_REQ#[1]/P1_GNT#[1]     |
| M2           | P1_REQ#[2]/P1_GNT#[2]     |
| М3           | P1_REQ#[3]/P1_GNT#[3]     |
| M4           | P1_REQ#[4]/P1_GNT#[4]     |
| M5           | PCI_REQ#[5]/PCI_GNT#[5]   |
| M6           | PCI_REQ#[6]/PCI_GNT#[6]   |
| M7           | PCI_REQ#[7]/PCI_GNT#[7]   |

Table 95: Arbitration Pin Mapping

# 13.5.14 PCI-1 to PCI-2 Configuration Cycle Information Register

This register is used to set up the address phase of a PCI configuration cycle on PCI-2.

### Table 96: PCI 1 to PCI-2 Configuration Cycle Information Register

| Registe     | r Name: P1_CONF_INFO  |       |   | Regi    | ster Offset | :: 0x144   |
|-------------|-----------------------|-------|---|---------|-------------|------------|
| PCI<br>Bits | Fund                  | ction |   |         |             | PB<br>Bits |
| 31-24       | PowerSpan II Reserved |       |   |         | 0-7         |            |
| 23-16       | BUS_NUM               |       |   |         | 8-15        |            |
| 15-08       | DEV_NUM               |       | F | UNC_NUN | Л           | 16-23      |
| 07-00       | REG_NUM               |       |   | 0       | TYPE        | 24-31      |

#### P1\_CONF\_INFO Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function                                             |
|--------------------|------|-------------|----------------|------------------------------------------------------|
| BUS_NUM<br>[7:0]   | R/W  | P1_RST      | 0              | Bus Number                                           |
| DEV_NUM<br>[4:0]   | R/W  | P1_RST      | 0              | Device Number                                        |
| FUNC_<br>NUM [2:0] | R/W  | P1_RST      | 0              | Function Number                                      |
| REG_NUM<br>[5:0]   | R/W  | P1_RST      | 0              | Register Offset                                      |
| TYPE               | R/W  | P1_RST      | 0              | Configuration Cycle Type<br>0 = Type 0<br>1 = Type 1 |

For a Configuration Type 1 cycle — with the TYPE bit set to 1— an access of the PCI-1 Configuration Data register performs a corresponding Configuration Type 1 cycle on the PCI-2 Interface. During the address phase of the Configuration Type 1 cycle, the PCI-2 address lines carry the values encoded in the P1\_CONF\_INFO register (P2\_AD[31:0] = P1\_CONF\_INFO[31:0]).

For a Configuration Type 0 cycle — with the TYPE bit set to 0 — an access of the PCI Configuration Data register performs a corresponding Configuration Type 0 cycle on the PCI-2 Interface. Programming the Device Number causes one of the upper address lines, P2\_AD[31:11], to be asserted during the address phase of the Configuration

Type 0 cycle as defined in Table 97.

| DEV_NUM[4:0] | P2_AD[31:11]               |
|--------------|----------------------------|
| 00000        | 0000 0000 0000 0001 0000 0 |
| 00001        | 0000 0000 0000 0010 0000 0 |
| 00010        | 0000 0000 0000 0100 0000 0 |
| 00011        | 0000 0000 0000 1000 0000 0 |
| 00100        | 0000 0000 0001 0000 0000 0 |
| 00101        | 0000 0000 0010 0000 0000 0 |
| 00110        | 0000 0000 0100 0000 0000 0 |
| 00111        | 0000 0000 1000 0000 0000 0 |
| 01000        | 0000 0001 0000 0000 0000 0 |
| 01001        | 0000 0010 0000 0000 0000 0 |
| 01010        | 0000 0100 0000 0000 0000 0 |
| 01011        | 0000 1000 0000 0000 0000 0 |
| 01100        | 0001 0000 0000 0000 0000 0 |
| 01101        | 0010 0000 0000 0000 0000 0 |
| 01110        | 0100 0000 0000 0000 0000 0 |
| 01111        | 1000 0000 0000 0000 0000 0 |
| 10000        | 0000 0000 0000 0000 0000 1 |
| 10001        | 0000 0000 0000 0000 0001 0 |
| 10010        | 0000 0000 0000 0000 0010 0 |
| 10011        | 0000 0000 0000 0000 0100 0 |
| 10100        | 0000 0000 0000 0000 1000 0 |
| 10101-11111  | 0000 0000 0000 0000 0000 0 |

| Table 97: PCI-2 AD[31:11] lines asserted during Configuration Type 0 |  |
|----------------------------------------------------------------------|--|
| cycles                                                               |  |

The remaining address lines are:

- P2\_AD[10:8] = FUNC\_NUM[2:0]
- P2\_AD[7:2] = REG\_NUM[5:0]
- P2\_AD[1:0] = 00

## 13.5.15 PCI-1 to PCI-2 Configuration Cycle Data Register

A write to the Configuration Data register from the PCI-1 bus causes a Configuration Write Cycle to be generated on the PCI-2 Interface. This is defined by the Configuration Address register (P1\_CONF\_ADDR). A read of this register from the PCI-1 bus causes a Configuration Read Cycle to be generated on the PCI-2 Interface. The PCI Bus Configuration Cycles generated by accessing the Configuration Data register are handled as a posted write or delayed read.

A write to the PCI Configuration Data register from the PCI-2 Interface or the Processor Bus has no effect. A read from PCI-2 Interface or the Processor Bus returns undefined data.

### Table 98: PCI 1 to PCI-2 Configuration Cycle Data Register

| Registe     | r Name: P1_CONF_DATA | Register Offset: | 0x148      |
|-------------|----------------------|------------------|------------|
| PCI<br>Bits | Fund                 | ction            | PB<br>Bits |
| 31-24       | CD                   | ATA              | 0-7        |
| 23-16       | CD                   | ATA              | 8-15       |
| 15-08       | CD                   | ATA              | 16-23      |
| 07-00       | CD                   | АТА              | 24-31      |

### P1\_CON\_DAT Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function           |
|--------------|------|-------------|----------------|--------------------|
| CDATA [31:0] | R/W  | P1_RST      | 0              | Configuration data |

# 13.5.16 PCI-1 to PCI-2 Interrupt Acknowledge Cycle Generation Register

This register generates an Interrupt Acknowledge cycle on PCI-2.

#### Table 99: PCI 1 to PCI-2 Interrupt Acknowledge Cycle Generation Register

| Registe     | r Name: P1_IACK | Register Offset | 0x14C      |
|-------------|-----------------|-----------------|------------|
| PCI<br>Bits | Fund            | ction           | PB<br>Bits |
| 31-24       | IACK            | _VEC            | 0-7        |
| 23-16       | IACK            | _VEC            | 8-15       |
| 15-08       | IACK            | _VEC            | 16-23      |
| 07-00       | IACK            | _VEC            | 24-31      |

#### **P1\_ACK Description**

| Name               | Туре | Reset<br>By | Reset<br>State | Function              |
|--------------------|------|-------------|----------------|-----------------------|
| IACK_VEC<br>[31:0] | R    | P1_RST      | 0              | PCI IACK Cycle Vector |

Reading this register from the PCI-1 bus causes an IACK cycle to be generated on the PCI-2 Interface. The byte lanes enabled on the PCI-2 bus are determined by P1\_CBE#[3:0] of the PCI-1 Memory Read cycle. The address on the PCI-1 bus used to access the P1\_IACK register is passed directly over to the PCI-2 bus during the PCI IACK cycle. However, address information is ignored during PCI IACK cycles and has no effect.

Reads from this register behave as delayed transfers. This means that the PCI-1 bus master is retried until the read data is latched from the PCI-2 target. When the IACK cycle completes on the PCI-2 bus, the IACK\_VEC[31:0] field is returned as read data when the PCI-1 bus master returns after the retry.

Writing to this register from the Processor Bus or either PCI bus has no effect. Reads from the PCI-2 Interface and Processor Bus return all zeros.

## 13.5.17 PCI-1 Bus Error Control and Status Register

The PCI-1 bus interface logs errors when it detects a Parity Error, Master-Abort, Target-Abort or Maximum Retry conditions

### Table 100: PCI 1 Bus Error Control and Status Register

| Registe              | r Name: P1_ERRCS             |           | Re         | egister Offe | set: 150 |  |
|----------------------|------------------------------|-----------|------------|--------------|----------|--|
| PCI<br>Bits Function |                              |           |            |              |          |  |
| 31-24                | PowerSpan II Reserved MES ES |           |            |              |          |  |
| 23-16                | PowerSpan II Reserved        |           |            |              |          |  |
| 15-08                | 08 PowerSpan II Reserved     |           |            |              |          |  |
| 07-00                | CMDERR                       | PowerSpan | II Reserve | d            | 24-31    |  |

#### **P1\_ERRCS** Description

| Name            | Туре                  | Reset<br>By | Reset<br>State | Function                                                                                         |
|-----------------|-----------------------|-------------|----------------|--------------------------------------------------------------------------------------------------|
| MES             | R                     | P1_RST      | 0              | Multiple Error Status<br>1 = a second error occurred before the first error<br>could be cleared. |
| ES              | R/Write 1 to<br>clear | P1_RST      | 0              | Error Status<br>0 = no error currently logged<br>1 = error currently logged                      |
| CMDERR<br>[3:0] | R                     | P1_RST      | 0              | PCI Command Error Log                                                                            |

When the ES bit is set, it means an error has been logged and the contents of the CMDERR[3:0] and PAERR[31:0] of the P1\_AERR register are valid. Information in the log cannot be changed while ES is set. Clearing the ES by writing 1 to the bit allows the error log registers to capture future errors.

MES is useful in determining if multiple errors occur. The original error logging is not overwritten when MES is set. Clearing ES also clears the MES bit.

## 13.5.18 PCI-1 Address Error Log Register

The PCI-1 Interface logs errors when it detects a Parity Error, Master-Abort, Target-Abort or Maximum Retry conditions.

### Table 101: PCI 1 Address Error Log Register

| Registe     | r Name: P1_AERR | Register Offset | : 0x154    |
|-------------|-----------------|-----------------|------------|
| PCI<br>Bits | Fun             | ction           | PB<br>Bits |
| 31-24       | PA              | ERR             | 0-7        |
| 23-16       | PAI             | ERR             | 8-15       |
| 15-08       | PAI             | ERR             | 16-23      |
| 07-00       | PAI             | ERR             | 24-31      |

#### **P1\_AERR Description**

| Name         | Туре | Reset<br>By | Reset<br>State | Function              |
|--------------|------|-------------|----------------|-----------------------|
| PAERR [31:0] | R    | P1_RST      | 0              | PCI Address Error Log |

The address of a PCI-1 bus transaction that generates an error condition is logged in this register. When the error occurs, the ES bit in the P1\_ERRCS register is set, qualifying and freezing the contents of this register. This register logs additional errors only after the ES bit in the P1\_ERRCS register is cleared.

# 13.5.19 PCI-1 Miscellaneous Control and Status Register

### Table 102: PCI 1 Miscellaneous Control and Status Register

| Registe     | er Name: P            | 1_MISC_CSR            | Register Offset  | :: 0x160 |  |  |  |  |
|-------------|-----------------------|-----------------------|------------------|----------|--|--|--|--|
| PCI<br>Bits |                       | Function              |                  |          |  |  |  |  |
| 31-24       | PowerSpan II Reserved |                       |                  |          |  |  |  |  |
| 23-16       |                       | PowerSpan             | II Reserved      | 8-15     |  |  |  |  |
| 15-08       | BSREG<br>_BAR_<br>EN  | PowerSpan II Reserved | MAX_RETRY        | 16-23    |  |  |  |  |
| 07-00       | MAC_<br>ERR           | Power                 | Span II Reserved | 24-31    |  |  |  |  |

#### **P1\_MISC** Description

| Name           | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                         |
|----------------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BSREG_BAR_EN   | R/W  | P1_RST      | 1<br>EEPROM    | PCI-1 Registers Image Base Address Register<br>enable.<br>0=disable<br>1=enable                                                                                                                                  |
| MAX_RETRY[3:0] | R/W  | P1_RST      | 0              | Maximum number of PCI Retry Terminations<br>0000 = retry forever<br>0001 = 64 retries<br>other - 2 <sup>24</sup> retries                                                                                         |
| MAC_ERR        | R/W  | P1_RST      | 1              | Master Abort Configuration Error Mapping<br>0 = generate target abort when master abort<br>occurs on PCI-2 configuration cycles<br>1 = return all ones when Master-Abort occurs on<br>PCI-2 configuration cycles |
|                |      |             |                | Single PCI PowerSpan II: Reserved                                                                                                                                                                                |

**BSREG\_BAR\_EN**: When this bit is cleared, the P1\_BSREG register is not visible in PCI-1 Configuration space and reads zero. Also, when this bit is cleared writes have no effect when this bit is cleared.

When the P1\_BSREG register is not visible in PCI-1 Configuration space, the PowerSpan II PCI-1 register image is disabled and PowerSpan II does not request PCI Memory space for the image.

# 13.5.20 PCI-1 Bus Arbiter Control Register

PowerSpan II's PCI-1 interface has dedicated support for four external PCI masters. The user can assign up to three additional PCI masters to the PCI-1 arbiter by configuring the PCI\_M7 bit, the PCI\_M6 bit, and the PCI\_M5 in the MISC\_CSR register (see page 378).



Depending on the number of external masters supported, some of bits M4-M7 and combinations of BM\_PARK are not applicable. Programming these combinations result in unpredictable PowerSpan II behavior.

The PowerSpan II PCI-1 internal arbiter is enabled by a power-up option. When disabled, an external arbiter is used. The signals P1\_REQ[1]\_/P1\_GNT[1]\_ are used by the PowerSpan II PCI-1 Master to arbitrate for access to the bus.

The P1\_ARB\_EN bit in the RST\_CSR register (see page 385) specifies if the PCI-1 arbiter is enabled or disabled.

### Table 103: PCI 1 Bus Arbiter Control Register

| PCI<br>Bits | Function    |                                                         |        |               |      |  |         | PB<br>Bits |       |
|-------------|-------------|---------------------------------------------------------|--------|---------------|------|--|---------|------------|-------|
| 31-24       |             | PowerSpan II Reserved                                   |        |               |      |  |         |            | 0-7   |
| 23-16       | STATUS_BITS |                                                         |        |               |      |  |         | 8-15       |       |
| 15-08       | M7_PRI      | M7_PRI M6_PRI M5_PRI M4_PRI M3_PRI M2_PRI M1_PRI PS_PRI |        |               |      |  |         | 16-23      |       |
| 07-00       | Power       | Span II Re                                              | served | STATUS<br>_EN | PARK |  | BM_PARK |            | 24-31 |

### P1\_ARB\_CTRL Description

| Name            | Туре | Reset<br>By | Reset<br>State | Function                                                                                   |
|-----------------|------|-------------|----------------|--------------------------------------------------------------------------------------------|
| STATUS_<br>BITS | R/W  | P1_RST      | 0              | Operational status of PCI Master Device <i>x</i><br>0 = functioning<br>1 = non-functioning |
| Mx_PRI          | R/W  | P1_RST      | 0              | Arbitration Level for PCI Master Device <i>x</i><br>0 = low priority<br>1 = high priority  |

| Name             | Туре | Reset<br>By | Reset<br>State | Function                                                                    |
|------------------|------|-------------|----------------|-----------------------------------------------------------------------------|
| PS_PRI           | R/W  | P1_RST      | 0              | Arbitration Level for PowerSpan II<br>0 = low priority<br>1 = high priority |
| STATUS_EN        | R/W  | P1_RST      | 0              | Enable monitoring of master by arbiter<br>0 = disabled<br>1 = enabled       |
| PARK             | R/W  | P1_RST      | 0              | PCI-1 Bus Parking Algorithm<br>0 = last master<br>1 = select master         |
| BM_PARK<br>[2:0] | R/W  | P1_RST      | 0              | Parked Master                                                               |

P1\_ARB\_CTRL Description

**STATUS\_BITS:** These series of bits are separated per master. There is one bit designated for each master and is separate from the others, but all eight are called STATUS\_BITS[7:0]. The individual bits are set when a PCI Master does not respond to a grant given by the PowerSpan II arbiter for 16 clock cycles. Once this bit is set to 1 by the PowerSpan II arbiter, the PowerSpan II arbiter does not include the non-functioning PCI Master in the arbitration algorithm used by PowerSpan II. When the bit is set to 0, the operating status of the PCI Master is functioning and it is included in the arbitration algorithm used by PowerSpan II.

**Mx\_PRI:** Determines the arbitration priority level for PCI Master agents assigned to the PCI-1 arbiter.

**STATUS\_EN:** Enables internal monitor of the PowerSpan II PCI arbiter. The monitor checks that no PCI Master waits longer than 16 PCI clock cycles before starting a transaction. The default setting is 0.

**PARK:** When this bit is set the arbiter parks the PCI-1 bus on the PCI master programmed in the BM\_PARK[2:0] field. When cleared the arbiter parks the PCI-1 bus on the last PCI master to be granted the bus.

**BM\_PARK[2:0]:** This field instructs the arbiter where to park the bus. The shaded combinations in Table 104 identifies potential PCI-1 external masters. Their presence depends on the programming of the PCI\_M7,PCI\_M6,PCI\_M5 bits in the MISC\_CSR register.

| BM_PARK [2:0] | Parked PCI Master | External Pins           |
|---------------|-------------------|-------------------------|
| 000           | PowerSpan II      | None                    |
| 001           | M1                | P1_REQ#[1]/P1_GNT#[1]   |
| 010           | M2                | P1_REQ#[2]/P1_GNT#[2]   |
| 011           | M3                | P1_REQ#[3]/P1_GNT#[3]   |
| 100           | M4                | P1_REQ#[4]/P1_GNT#[4]   |
| 101           | M5                | PCI_REQ#[5]/PCI_GNT#[5] |
| 110           | M6                | PCI_REQ#[6]/PCI_GNT#[6] |
| 111           | M7                | PCI_REQ#[7]/PCI_GNT#[7] |

Table 104: Parked PCI Master

## 13.5.21 Processor Bus Slave Image x Control Register

This register contains the control information for the "Processor Bus Slave Image x Base Address Register" on page 350.



The bits in this register are not dynamic. Do not alter these settings while transactions are being processed through PowerSpan II. Refer to "Processor Bus Slave Image x Translation Address Register" on page 348 for more information on dynamic address translation.

### Table 105: Processor Bus Slave Image x Control Register

| Registe | er Name: PB_SIx_CTL | Register Offset: 0x200, 0x210, 0x220, 0x230,<br>0x240, 0x250, 0x260, 0x270 |  |  |  |  |
|---------|---------------------|----------------------------------------------------------------------------|--|--|--|--|
| PCI     |                     | PB                                                                         |  |  |  |  |

| 1.01  |                       |       |        |                       |   |        |       |  |
|-------|-----------------------|-------|--------|-----------------------|---|--------|-------|--|
| Bits  | Function              |       |        |                       |   |        |       |  |
| 31-24 | IMG_EN                | TA_EN | MD_EN  | MD_EN BS              |   |        |       |  |
| 23-16 | MODE                  | DEST  | MEM_IO | PowerSpan II Reserved |   |        |       |  |
| 15-08 | PowerSpan II Reserved |       |        |                       |   |        |       |  |
| 07-00 | PRKEE<br>P            | END   |        | 0                     | 0 | RD_AMT | 24-31 |  |

#### **PB\_SIx\_CTL** Description

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                            |
|---------|------|-------------|----------------|-----------------------------------------------------|
| IMG_EN  | R/W  | PB_RST      | 0<br>EEPROM    | Image Enable<br>0=Disable<br>1=Enable               |
| TA_EN   | R/W  | PB_RST      | 0<br>EEPROM    | Translation Address Enable<br>0=Disable<br>1=Enable |
| MD_EN   | R/W  | PB_RST      | 0<br>EEPROM    | Master Decode Enable<br>0=Disable<br>1=Enable       |
| BS[4:0] | R/W  | PB_RST      | 0<br>EEPROM    | Block Size<br>(4 Kbyte*2 <sup>BS</sup> )            |

### **PB\_SIx\_CTL** Description

| Name            | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                        |
|-----------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------|
| MODE            | R/W  | PB_RST      | 0<br>EEPROM    | Image Mode<br>0 = Memory command generation<br>1 = I/O command generation or 4 byte memeory<br>read (see Table 107 on page 346) |
| DEST            | R/W  | PB_RST      | 0<br>EEPROM    | Destination Bus<br>0 = PCI 1 bus<br>1 = PCI-2 bus                                                                               |
|                 |      | -           |                | Single PCI PowerSpan II: Reserved<br>PCI-1 Bus is the only destination.                                                         |
| MEM_IO          | R/W  | PB_RST      | 0              | MEM_IO mode<br>0 = Regular I/O mode<br>1 = Enables 1,2,3, or 4 byte memory reads on the<br>PCI bus(es)                          |
| PRKEEP          | R/W  | PB_RST      | 0<br>EEPROM    | Prefetch Read Keep<br>0 = purge read data at end of transfer<br>1 = keep read data                                              |
| END[1:0]        | R/W  | P1_RST      | 10b<br>EEPROM  | Endian Conversion Mode<br>00 = Little-endian<br>01 = PowerPC little-endian<br>10 = Big-endian<br>11 = True little-endian        |
| RD_AMT<br>[2:0] | R/W  | PB_RST      | 0<br>EEPROM    | Read Prefetch Amount<br>Amount of read data fetched from PCI                                                                    |

**IMG\_EN:** The Image Enable bit is changed in the following ways:

- EEPROM initialization
- register write to IMG\_EN

The IMG\_EN is cleared by writing a zero to the bit.

**TA\_EN:** When set, the Translation Address (PB\_SIx\_TADDR) replaces the upper bits of the Processor Bus address. Clearing the enable results in no address translation.

**MD\_EN**: Enables Master Decode when the Processor Bus arbiter is in use — the Processor Bus Arbiter Enable bit, in the "Reset Control and Status Register" on page 385, is set. If MD\_EN is cleared, only the Processor Bus Address and Transaction Type are used for transaction decode. If MD\_EN is set, the originating master is included in the transaction decode. A transaction is claimed only if it originates from the master(s) specified in PB\_SIx\_TADDR.

**BS:** The Block Size specifies the size of the image, address lines compared and address lines translated.

| BS[4:0] | Block Size | Address Lines Compared/<br>Translated |
|---------|------------|---------------------------------------|
| 00000   | 4k         | A0-A19                                |
| 00001   | 8k         | A0-A18                                |
| 00010   | 16k        | A0-A17                                |
| 00011   | 32k        | A0-A16                                |
| 00100   | 64k        | A0-A15                                |
| 00101   | 128k       | A0-A14                                |
| 00110   | 256k       | A0-A13                                |
| 00111   | 512k       | A0-A12                                |
| 01000   | 1M         | A0-A11                                |
| 01001   | 2M A0-A10  |                                       |
| 01010   | 4M         | A0-A9                                 |
| 01011   | 8M         | A0-A8                                 |
| 01100   | 16M        | A0-A7                                 |
| 01101   | 32M        | A0-A6                                 |
| 01110   | 64M        | A0-A5                                 |
| 01111   | 128M       | A0-A4                                 |
| 10000   | 256M       | A0-A3                                 |
| 10001   | 512M       | A0-A2                                 |

### Table 106: Block Size

Table 106: Block Size

| BS[4:0]     | Block Size | Address Lines Compared/<br>Translated |
|-------------|------------|---------------------------------------|
| 10010       | 1G         | A0-A1                                 |
| 10011       | 2G         | A0                                    |
| 10100-11111 | Reserved   | Reserved                              |

**MODE:** Determines if the image is used to generate Memory or IO commands on PCI.

• Memory Command Mode

Causes PCI Memory commands to be generated on PCI. Bursting is supported.

PRKEEP and RD\_AMT[2:0] are only applicable in Memory Command Mode.

• IO Command Mode

Causes PCI IO commands to be generated on PCI. When the image is selected to perform IO commands, transactions are limited to 4 bytes or less. A transaction attempting to move more than 4 bytes will cause a TEA\_ response. The TEA\_ can be suppressed by setting the PB\_MISC\_CSR[TEA\_EN] bit.

The MODE bit and the MEM\_IO bit work together to control the size of the transaction (see Table 107)..

| MODE Setting | MEM_IO setting | Transaction size                                 |
|--------------|----------------|--------------------------------------------------|
| 0            | 0              | Memory cycle<br>(minimum 8 byte<br>memory read)  |
| 0            | 1              | Memory cycle<br>(minimum 8 byte<br>memeory read) |
| 1            | 0              | I/O Cycle                                        |
| 1            | 1              | Memory cycle<br>(minimum 4 byte<br>memeory read) |

Table 107: Setting for MODE and MEM\_IO Bits

**DEST:** Selects the destination bus for the transaction.

**MEM\_IO:** PowerSpan II supports 4-byte reads. When this bit is set, the Memory Read command to the corresponding image generates the Memory Read command on the destination PCI bus with a minimum 32 bit aligned 4-byte read.

The MODE bit and the MEM\_IO bit work together to control the size of the transaction (see Table 107).

**PRKEEP:** Prefetch Read Keep stores prefetch data beyond an initial read. When set, subsequent read requests to the same image at the next address retrieves the read data directly from the switching fabric instead of causing either PCI bus to fetch more data. The read data is invalidated when a read with a non-matching address occurs.



The ARTRY\_EN bit must be set to 1 in order for the PowerSpan II Prefetch Keep feature to keep prefetched data. The ARTRY\_EN bit is in the Processor Bus Miscellaneous Control and Status register (see page 361).

**END:** Selects the endian mapping.

**RD\_AMT[2:0]:** The Read Amount setting determines different values to prefetch from PCI. If PRKEEP is not set, it is recommended limiting the RD\_AMT to 32-bytes.

| RD_AMT[2:0] | Data Fetched |  |  |
|-------------|--------------|--|--|
| 000         | 8 bytes      |  |  |
| 001         | 16 bytes     |  |  |
| 010         | 32 bytes     |  |  |
| 011         | 64 bytes     |  |  |
| 100         | 128 bytes    |  |  |
| 101-111     | Reserved     |  |  |

Table 108: Read Amount

If the slave image is programmed to be in IO mode (the MODE bit in the PB\_SIx\_CTL register set to 1) then the RD\_AMT is not used and a maximum of 4 bytes will be read from the PCI bus.



The EEPROM load capability allows a processor on the Processor Bus to boot directly from a device on PCI. Only the control registers for Processor Bus Slave Image 0 are loaded from EEPROM.

## 13.5.22 Processor Bus Slave Image x Translation Address Register

### Table 109: Processor Bus Slave Image x Translation Address Register

| Registe              | r Name: PB_SIx_TADDR        | Register Offset: 0x204, 0x214, 0x224, 0x234,<br>0x244, 0x254, 0x264, 0x274 |    |    |   |       |  |  |
|----------------------|-----------------------------|----------------------------------------------------------------------------|----|----|---|-------|--|--|
| PCI<br>Bits Function |                             |                                                                            |    |    |   |       |  |  |
| 31-24                | 31-24 TADDR                 |                                                                            |    |    |   |       |  |  |
| 23-16                | 23-16 TADDR                 |                                                                            |    |    |   |       |  |  |
| 15-08                | TADDR PowerSpan II Reserved |                                                                            |    |    |   |       |  |  |
| 07-00                | PowerSpan II Reserved       | M3                                                                         | M2 | M1 | 0 | 24-31 |  |  |

#### **PB\_SIx\_TADDR** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                  |
|-------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------|
| TADDR[19:0] | R/W  | PB_RST      | 0<br>EEPROM    | Translation Address                                                                                                       |
| M3-M1       | R/W  | PB_RST      | 0<br>EEPROM    | Master Select<br>0=Do not claim transactions generated by this<br>master<br>1=Claim transactions generated by this master |

**TADDR**: The Translation Address register replaces the Processor Bus address, up to the size of the image. TADDR[31:12] replace the Processor Bus PB\_A[0:19].

For example, if TADDR[31:12] = 0x12345 and PB\_SIx\_CTL[BS]=0 (4 K image) and the address on the Processor Bus is PB\_A[0:31] = 0x78563412, then the PCI address becomes 0x12345412

The TADDR[19:0] field can be changed while transactions are being processed by PowerSpan II. This is the only parameter that can be changed during a transaction. All other programmable parameters must stay constant during a transaction

| PB_SIx_<br>TADDR[] | Processor Bus Address PB_A | PB_SIx_CTL[BS] | Block Size |
|--------------------|----------------------------|----------------|------------|
| 31                 | 0                          | 10011          | 2G         |
| 31:30              | 0:1                        | 10010          | 1G         |
| 31:29              | 0:2                        | 10001          | 512M       |
| 31:28              | 0:3                        | 10000          | 256M       |
| 31:27              | 0:4                        | 01111          | 128M       |
| 31:26              | 0:5                        | 01110          | 64M        |
| 31:25              | 0:6                        | 01101          | 32M        |
| 31:24              | 0:7                        | 01100          | 16M        |
| 31:23              | 0:8                        | 01011          | 8M         |
| 31:22              | 0:9                        | 01010          | 4M         |
| 31:21              | 0:10                       | 01001          | 2M         |
| 31:20              | 0:11                       | 01000          | 1M         |
| 31:19              | 0:12                       | 00111          | 512k       |
| 31:18              | 0:13                       | 00110          | 256k       |
| 31:17              | 0:14                       | 00101          | 128k       |
| 31:16              | 0:15                       | 00100          | 64k        |
| 31:15              | 0:16                       | 00011          | 32k        |
| 31:14              | 0:17                       | 00010          | 16k        |
| 31:13              | 0:18                       | 00001          | 8k         |
| 31:12              | 0:19                       | 00000          | 4k         |

 Table 110: Translation Address Mapping

M3-M1: These bits indicate which external master(s) are qualified to access the image. The image supports master decode if the Processor Bus arbiter is enabled — the Processor Bus Arbiter Enable bit, in the "Reset Control and Status Register" on page 385, is set and when MD\_EN bit in the PB\_SIx\_CTL is set. Bit M3 represents the external master connected to PB\_BG[3]\_ and M1 represents the external master connected to PB\_BG[1]\_.

## 13.5.23 Processor Bus Slave Image x Base Address Register

This register defines the lowest address of the slave image. The minimum image size is 4 Kbyte as defined in BS field in the PB\_SIx\_CTL.

The initial write to this register sets the IMG\_EN bit in the PB\_SIx\_CTL register. Subsequent writes to this register will have no effect on the IMG\_EN bit.



A base address of 0 is valid.

### Table 111: Processor Bus Slave Image x Base Address Register

| Registe                     | r Name: PB_SIx_BADDR | Regis | ster Offset |  | 218, 0x228<br>258, 0x26 |            |
|-----------------------------|----------------------|-------|-------------|--|-------------------------|------------|
| PCI<br>Bits Function        |                      |       |             |  |                         | PB<br>Bits |
| 31-24                       | BA                   |       |             |  |                         | 0-7        |
| 23-16                       | 23-16 BA             |       |             |  |                         | 8-15       |
| 15-08                       | BA 0 0 0 0           |       |             |  |                         | 16-23      |
| 07-00 PowerSpan II Reserved |                      |       |             |  | 24-31                   |            |

#### **PB\_SIx\_BADDR** Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function                   |
|----------|------|-------------|----------------|----------------------------|
| BA[19:0] | R/W  | PB_RST      | 0<br>EEPROM    | Processor Bus Base Address |

## 13.5.24 Processor Bus Register Image Base Address Register

This register defines the Processor Bus address offset for PowerSpan II internal registers. The register can be loaded by an external EEPROM.



Г

A base address of 0 is valid.

### Table 112: Processor Bus Register Image Base Address Register

| Registe     | r Name: PB_REG_BADDR      | Reg   | ister Offse | t: 0x280   |
|-------------|---------------------------|-------|-------------|------------|
| PCI<br>Bits | Fun                       | ction |             | PB<br>Bits |
| 31-24       | ВА                        |       |             |            |
| 23-16       | ВА                        |       |             |            |
| 15-08       | BA PowerSpan II Reserved  |       |             |            |
| 07-00       | PowerSpan II Reserved END |       |             |            |

#### PB\_REG\_BADDR Description

| Name     | Туре | Reset<br>By | Reset<br>State    | Function                                                              |
|----------|------|-------------|-------------------|-----------------------------------------------------------------------|
| BA[19:0] | R/W  | PB_RST      | 0x30000<br>EEPROM | Processor Bus Register Base Address                                   |
| END      | R/W  | PB_RST      | 0<br>EEPROM       | Endian Conversion Mode<br>0 = Big-endian<br>1 = PowerPC little-endian |

**BA:** The base address for the Processor Bus Base Address image represent the upper address bits (A[31:12]). The base address for the processor address bus at reset is 0x3000\_0000.

**END[1:0]:** The endian conversion mode for processor access to PowerSpan II registers.

# 13.5.25 Processor Bus PCI Configuration Cycle Information Register

This register is used to set up the address phase of a PCI Configuration cycle.

### Table 113: Processor Bus PCI Configuration Cycle Information Register

| Register Name: PB_CONF_INFO |                  |                    |      |      |  |  | Reg   | ister Offse | t: 0x290 |
|-----------------------------|------------------|--------------------|------|------|--|--|-------|-------------|----------|
| PCI<br>Bits                 | Function         |                    |      |      |  |  |       | PB<br>Bits  |          |
| 31-24                       | 0                | 0 0 0 0 0 0 0 DEST |      |      |  |  |       |             | 0-7      |
| 23-16                       | BUS_NUM          |                    |      |      |  |  |       | 8-15        |          |
| 15-08                       | DEV_NUM FUNC_NUM |                    |      |      |  |  | 16-23 |             |          |
| 07-00                       |                  |                    | REG_ | _NUM |  |  | 0     | TYPE        | 24-31    |

### **PB\_CONF\_INFO** Description

| Name          | Туре | Reset<br>By | Reset<br>State | Function                                                                |
|---------------|------|-------------|----------------|-------------------------------------------------------------------------|
| DEST          | R/W  | PB_RST      | 0              | Destination Bus<br>0 = PCI 1<br>1 = PCI-2                               |
| DEST          | R/W  | PB_RST      | 0              | Single PCI PowerSpan II: Reserved<br>PCI-1 Bus is the only destination. |
| BUS_NUM[7:0]  | R/W  | PB_RST      | 0              | Bus Number                                                              |
| DEV_NUM[4:0]  | R/W  | PB_RST      | 0              | Device Number                                                           |
| FUNC_NUM[2:0] | R/W  | PB_RST      | 0              | Function Number                                                         |
| REG_NUM[5:0]  | R/W  | PB_RST      | 0              | Register Number                                                         |
| TYPE          | R/W  | PB_RST      | 0              | Configuration Cycle Type<br>0 = Type 0<br>1 = Type 1                    |

For a Configuration Type 1 cycle — with the TYPE bit set to 1— an access of the PCI Configuration Data register performs a corresponding Configuration Type 1 cycle on either PCI bus. During the address phase of the Configuration Type 1 cycle, the PCI address lines carry the values encoded in the PB\_CONF\_INFO register (AD[31:0] = PB\_CONF\_INFO[31:0]). The Destination (DEST) field, in the PB\_CONF\_INFO register, is an exception to this because it is zero on AD[24].

For a Configuration Type 0 cycle — with the TYPE bit set to 0 — an access of the PCI Configuration Data register performs a corresponding Configuration Type 0 cycle on either PCI bus. Programming the Device Number causes the assertion of one of the upper address lines, AD[31:11], during the address phase of the Configuration Type 0 cycle. This is shown in Table 114.

| DEV_NUM[4:0] | AD[31:11]                  |
|--------------|----------------------------|
| 00000        | 0000 0000 0000 0001 0000 0 |
| 00001        | 0000 0000 0000 0010 0000 0 |
| 00010        | 0000 0000 0000 0100 0000 0 |
| 00011        | 0000 0000 0000 1000 0000 0 |
| 00100        | 0000 0000 0001 0000 0000 0 |
| 00101        | 0000 0000 0010 0000 0000 0 |
| 00110        | 0000 0000 0100 0000 0000 0 |
| 00111        | 0000 0000 1000 0000 0000 0 |
| 01000        | 0000 0001 0000 0000 0000 0 |
| 01001        | 0000 0010 0000 0000 0000 0 |
| 01010        | 0000 0100 0000 0000 0000 0 |
| 01011        | 0000 1000 0000 0000 0000 0 |
| 01100        | 0001 0000 0000 0000 0000 0 |
| 01101        | 0010 0000 0000 0000 0000 0 |
| 01110        | 0100 0000 0000 0000 0000 0 |
| 01111        | 1000 0000 0000 0000 0000 0 |
| 10000        | 0000 0000 0000 0000 0000 1 |
| 10001        | 0000 0000 0000 0000 0001 0 |

Table 114: PCI AD[31:11] lines asserted during Configuration Type 0 cycles

| Table 114: PCI AD[31:11] lines asserted during Configuration Ty | pe 0 |
|-----------------------------------------------------------------|------|
| cycles                                                          |      |

| DEV_NUM[4:0] | AD[31:11]                  |
|--------------|----------------------------|
| 10010        | 0000 0000 0000 0000 0010 0 |
| 10011        | 0000 0000 0000 0000 0100 0 |
| 10100        | 0000 0000 0000 0000 1000 0 |
| 10101-11111  | 0000 0000 0000 0000 0000 0 |

The remaining address lines are:

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



PowerSpan II does not generate configuration cycles to devices connected to AD[15:11].

# 13.5.26 Processor Bus Configuration Cycle Data Register

| Register Name: PB_CONF_DATA |          | Register Offset: 0x29 |            |  |
|-----------------------------|----------|-----------------------|------------|--|
| PCI<br>Bits                 | Function |                       | PB<br>Bits |  |
| 31-24                       | CDATA    |                       | 0-7        |  |
| 23-16                       | CDATA    |                       | 8-15       |  |
| 15-08                       | CDATA    |                       | 16-23      |  |
| 07-00                       | CDATA    |                       | 24-31      |  |

#### **PB\_CONF\_DATA** Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function           |
|-------------|------|-------------|----------------|--------------------|
| CDATA[31:0] | R/W  | PB_RST      | 0              | Configuration Data |

A write to the Configuration Data register from the Processor Bus causes a Configuration Write Cycle to be generated on either PCI bus as defined by the Configuration Info register (PB\_CONF\_INFO). A read of this register from the Processor Bus causes a Configuration Read Cycle to be generated on either PCI bus. The PCI Bus Configuration Cycles generated by accessing the Configuration Data register is handled as a posted write or delayed read.

The byte lanes enabled on the PCI bus are determined by PB\_SIZ[0:3] and PB\_A[30:31] of the Processor Bus read or write cycle.

A write to the PCI Configuration Data register from the either PCI bus has no effect. A read from either PCI bus is undefined.

The END bit in the PB\_REG\_BADDR selects the endian conversion scheme used for accesses to PCI through this register. The definition of endian conversion scheme is for PCI accesses, not register accesses.

## 13.5.27 Processor Bus to PCI-1 Interrupt Acknowledge Cycle Generation Register

This register is used to generate an Interrupt Acknowledge cycle originating on the Processor Bus and destined for the PCI-1 bus. Reading this register from the Processor Bus causes an IACK cycle to be generated on the PCI bus. The byte lanes enabled on the PCI bus are determined by PB\_SIZ[0:3] and PB\_A[30:31] of the Processor Bus read cycle. The address on the Processor Bus used to access the PB\_P1\_IACK 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.

#### Table 116: Processor Bus to PCI-1 Interrupt Acknowledge Cycle Generation Register

| Register Name: PB_P1_IACK |          | Register Offset: 0x2A0 |            |  |
|---------------------------|----------|------------------------|------------|--|
| PCI<br>Bits               | Fund     | ction                  | PB<br>Bits |  |
| 31-24                     | IACK_VEC |                        | 0-7        |  |
| 23-16                     | IACK_VEC |                        | 8-15       |  |
| 15-08                     | IACK_VEC |                        | 16-23      |  |
| 07-00                     | IACK_VEC |                        | 24-31      |  |

#### **PB\_P1\_IACK** Description

| Name           | ResetResetNameTypeByState |        | Function |                       |
|----------------|---------------------------|--------|----------|-----------------------|
| IACK_VEC[31:0] | R                         | PB_RST | 0        | PCI IACK Cycle Vector |

If the Address Retry Enable (ARTRY\_EN) bit is set, in the "PCI 1 Miscellaneous 1 Register" on page 315, the Processor Bus Master is retried until the read data is latched from the PCI target. When the IACK cycle completes on the PCI-1 bus, the IACK\_VEC[31:0] field is returned as read data when the Processor Bus Master returns after the retry.

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

The END bit in the PB\_REG\_BADDR selects the endian conversion scheme used for accesses to PCI through this register. The definition of endian conversion scheme is for PCI accesses, not register accesses.

## 13.5.28 Processor Bus to PCI-2 Interrupt Acknowledge Cycle Generation Register

This register is used to generate an Interrupt Acknowledge cycle originating on the Processor Bus and destined for the PCI-2 bus. Reading this register from the Processor Bus causes an IACK cycle to be generated on the PCI bus. The byte lanes enabled on the PCI bus are determined by PB\_SIZ[0:3] and PB\_A[30:31] of the Processor Bus read cycle. The address on the Processor Bus used to access the PB\_P1\_IACK register is passed directly over to the PCI bus during the PCI IACK cycle. However this has no effect because address information is ignored during PCI IACK cycles.

### Table 117: Processor Bus to PCI-2 Interrupt Acknowledge Cycle Generation Register

| Register Name: PB_P2_IACK |          | Register Offset: 0x2A |            |  |
|---------------------------|----------|-----------------------|------------|--|
| PCI<br>Bits               | Fund     | ction                 | PB<br>Bits |  |
| 31-24                     | IACK_VEC |                       | 0-7        |  |
| 23-16                     | IACK_VEC |                       | 8-15       |  |
| 15-08                     | IACK_VEC |                       | 16-23      |  |
| 07-00                     | IACK_VEC |                       | 24-31      |  |

#### PB\_P2\_IACK Description

| Name           | Туре | Reset<br>By | Reset<br>State | Function              |
|----------------|------|-------------|----------------|-----------------------|
| IACK_VEC[31:0] | R    | PB_RST      | 0              | PCI IACK Cycle Vector |

If the Address Retry Enable (ARTRY\_EN)) bit is set, in the "PCI 1 Miscellaneous 1 Register" on page 315, the Processor Bus Master is retried until the read data is latched from the PCI target. When the IACK cycle completes on the PCI-2 bus, the IACK\_VEC[31:0] field is returned as read data when the Processor Bus Master returns after the retry.

Writing to this register from the Processor Bus, or either PCI bus, has no effect. Reads from the PCI bus return all zeros.

The END bit in the PB\_REG\_BADDR selects the endian conversion scheme used for accesses to PCI through this register. The definition of endian conversion scheme is for PCI accesses, not register accesses.

## 13.5.29 Processor Bus Error Control and Status Register

The Processor Bus Interface logs errors when it detects a maximum retry error, parity error or assertion of PB\_TEA\_ conditions.

### Table 118: Processor Bus Error Control and Status Register

| Registe     | r Name: PB_ERRCS             |   |           | Regi       | ister Offsei | t: 0x2B0 |
|-------------|------------------------------|---|-----------|------------|--------------|----------|
| PCI<br>Bits |                              |   |           |            |              |          |
| 31-24       | PowerSpan II Reserved MES ES |   |           |            | 0-7          |          |
| 23-16       | PowerSpan II Reserved        |   |           |            |              | 8-15     |
| 15-08       | TT_ERR PowerSpan II Reserved |   |           |            | 16-23        |          |
| 07-00       | SIZ_ERR                      | F | PowerSpan | II Reserve | d            | 24-31    |

#### **PB\_ERRCS** Description

| Name         | Туре                  | Reset<br>By | Reset<br>State | Function                                                                                         |
|--------------|-----------------------|-------------|----------------|--------------------------------------------------------------------------------------------------|
| MES          | R                     | PB_RST      | 0              | Multiple Error Status<br>1 = a second error occurred before the first error<br>could be cleared. |
| ES           | R/Write 1 to<br>Clear | PB_RST      | 0              | Error Status<br>0 = no error currently logged<br>1 = error currently logged                      |
| TT_ERR[4:0]  | R                     | PB_RST      | 0              | Processor Bus Transaction Type Error Log                                                         |
| SIZ_ERR[3:0] | R                     | PB_RST      | 0              | Processor Bus SIZ field Error Log                                                                |

When the ES bit is set, it means an error has been logged and the contents of the TT\_ERR, SIZ\_ERR and AERR are valid. Information in the log cannot be changed while ES is set. Clearing the ES by writing a one to the bit allows the error log registers to capture future errors.

MES is useful for determining if multiple errors occur. The Processor Bus error logs are not overwritten when MES is set. Clearing ES also clears MES.

## 13.5.30 Processor Bus Address Error Log

The Processor Bus Interface logs errors when it detects a maximum retry error, parity error or assertion of PB\_TEA\_ conditions.

#### Table 119: Processor Bus Address Error Log

| Registe     | r Name: PB_AERR | Register Offset | :: 0x2B4   |
|-------------|-----------------|-----------------|------------|
| PCI<br>Bits | Fund            | ction           | PB<br>Bits |
| 31-24       | AE              | RR              | 0-7        |
| 23-16       | AE              | RR              | 8-15       |
| 15-08       | AE              | RR              | 16-23      |
| 07-00       | AE              | RR              | 24-31      |

#### **PB\_AERR Description**

| Name       | Туре | Reset<br>By | Reset<br>State | Function                |
|------------|------|-------------|----------------|-------------------------|
| AERR[31:0] | R    | PB_RST      | 0              | Processor Bus Error Log |

The address of a processor bus transaction that generates an error condition is logged in this register. When the error occurs, the ES bit in the PB\_ERRCS is set, qualifying and freezing the contents of this register. This register logs additional errors only after the ES bit (see Table 135 on page 388) is cleared.

# 13.5.31 Processor Bus Miscellaneous Control and Status Register

### Table 120: Processor Bus Miscellaneous Control and Status Register

| Registe     | r Name: P                       | PB_MISC_C   | SR            |        |              |       | Regi  | ster Offset | :: 0x2C0   |
|-------------|---------------------------------|-------------|---------------|--------|--------------|-------|-------|-------------|------------|
| PCI<br>Bits | Function                        |             |               |        |              |       |       |             | PB<br>Bits |
| 31-24       | PowerSpan II Reserved           |             |               |        |              |       |       | 0-7         |            |
| 23-16       | PowerSpan II Reserved           |             |               |        |              |       |       | 8-15        |            |
| 15-08       | PowerSpan II Reserved MAX_RETRY |             |               |        |              | 16-23 |       |             |            |
| 07-00       | EXT<br>CYC                      | MAC_<br>TEA | MODE_<br>7400 | TEA_EN | ARTRY_<br>EN | DP_EN | AP_EN | PARITY      | 24-31      |

#### **PB\_MISC\_CSR** Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                                                       |
|--------------------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAX_RETRY<br>[3:0] | R/W  | PB_RST      | 0              | Maximum number of retries. Except for 0000, all<br>entries are multiples of 64 retries<br>0000 = retry forever<br>0001 = 64 retries<br>0010 = 128 retries<br>0011 = 192 retries, etc.                          |
| EXTCYC             | R/W  | PB_RST      | 0              | Determines if the PowerSpan II PB master is<br>enabled to generate extended cycles (16 byte or<br>24 byte)<br>0 = Cannot generate extended cycle<br>1= Can generate extended cycle                             |
| MAC_TEA            | R/W  | PB_RST      | 1              | Master-Abort Configuration Error Mapping<br>0 = Assert PB_TEA_ when Master-Abort occurs on<br>PCI configuration cycles<br>1 = Return all "1s" when Master-Abort occurs on<br>PCI configuration cycles          |
| MODE_7400          | R/W  | PB_RST      | 1              | Determines if PowerSpan II Processor Bus Slave<br>can accept misaligned data transfers defined for<br>MPC7400<br>0 = cannot accept MPC7400 misaligned transfers<br>1 = can accept MPC7400 misaligned transfers |

**PB\_MISC\_CSR** Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                             |
|----------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TEA_EN   | R/W  | PB_RST      | 1              | Suppress PB_TEA_ generation<br>0 = PowerSpan II does not assert PB_TEA_                                                                                                              |
| ARTRY_EN | R/W  | PB_RST      | 0              | <ul> <li>1 = PowerSpan II asserts PB_TEA_</li> <li>Address Retry Enable</li> <li>0 = PB Slave never asserts PB_ARTRY_</li> <li>1 = PB Slave asserts PB_ARTRY_ as required</li> </ul> |
| DP_EN    | R/W  | PB_RST      | 0              | Data Parity Enable<br>0 = Data parity checking disabled<br>1 = Data parity checking enabled                                                                                          |
| AP_EN    | R/W  | PB_RST      | 0              | Address Parity Enable<br>0 = Address parity checking disabled<br>1 = Address parity checking enabled                                                                                 |
| PARITY   | R/W  | PB_RST      | 0              | Parity<br>0 = Odd Parity<br>1 = Even Parity                                                                                                                                          |

**EXTCYC:** PowerSpan II generates 16 byte and 24 byte extended cycles when EXTCYC is set. This ability improves performance of PowerQUICC II systems. To maintain compatibility with other PowerPC devices, clearing EXTCYC ensures PowerSpan II never generates extended cycles.

**MAC\_TEA:** This bit controls the handling of a Master-Abort while a PowerSpan II PCI Master is generating a configuration transaction initiated by a processor bus master. If MAC\_TEA is cleared, the processor bus slave returns all ones to the initiating processor bus master. If MAC\_TEA is cleared, the processor bus slave returns all ones to the processor bus slave asserts PB\_TEA\_ to terminate the transaction initiated by the processor.

**MODE\_7400:** PowerSpan II supports a specific set of PowerPC 7400 misaligned transactions when this bit is set to 1. Refer to Table 29 on page 131 for a complete list of data transfers supported by PowerSpan II.

**TEA\_EN:** When this bit is cleared, PowerSpan II never asserts TEA\_. Error conditions are signalled exclusively with interrupts.

**ARTRY\_EN:** Controls PowerSpan II's use of PB\_ARTRY\_during the servicing of transactions. When ARTRY\_EN is set, the Processor Bus Slave retries a processor (60x) bus master under the following conditions:

- Register write while an external master connected to another PowerSpan II interface is doing a register write
- Register read during I<sup>2</sup>C load
- Posted write when no buffers are available
- Read from PCI-1 or PCI-2

ARTRY\_EN is cleared by default. The user will see improved Processor Bus Interface utilization by setting ARTRY\_EN.



The ARTRY\_EN bit must be set to 1 in order for the PowerSpan II Prefetch Keep feature to keep prefetched data. Prefetch Keep is enabled by setting the PRKEEP bit in the Processor Bus Slave Image xBase Address Control register (see page 350).

**DP\_EN, AP\_EN:** When cleared, the PowerSpan II does not check the parity pins for the proper parity value. PowerSpan II still drives out parity on master writes and slave read cycles. Parity checking is disabled by default.

# 13.5.32 Processor Bus Arbiter Control Register

The arbitration control register is used to control the parameters of the on-chip Processor Bus arbiter.

### Table 121: Processor Bus Arbiter Control Register

| Registe              | r Name: PB_ARB_CTRL                               |  |  | Regi | ster Offset | : 0x2D0 |  |
|----------------------|---------------------------------------------------|--|--|------|-------------|---------|--|
| PCI<br>Bits Function |                                                   |  |  |      |             |         |  |
| 31-24                | PowerSpan II Reserved                             |  |  |      |             |         |  |
| 23-16                | PowerSpan II Reserved M3_EN M2_EN M1_EN 0         |  |  |      |             | 8-15    |  |
| 15-08                | PowerSpan II Reserved M3_PRI M2_PRI M1_PRI PS_PRI |  |  |      |             | 16-23   |  |
| 07-00                | PowerSpan II Reserved TS_DLY PARK BM_PARK         |  |  |      |             | 24-31   |  |

### PB\_ARB\_CTRL Description

| Name   | Туре | Reset<br>By | Reset<br>State | Function                                                                                              |
|--------|------|-------------|----------------|-------------------------------------------------------------------------------------------------------|
| Mx_EN  | R/W  | PB_RST      | PWRUP          | External Master x Enable<br>0=External requests ignored<br>1=External requests recognized             |
| Mx_PRI | R/W  | PB_RST      | 0              | External Master x Priority Level<br>0 = Low Priority<br>1 = High Priority                             |
| PS_PRI | R/W  | PB_RST      | 0              | PowerSpan II Priority Level<br>0 = Low Priority<br>1 = High Priority                                  |
| TS_DLY | R/W  | PB_RST      | 0              | Controls when arbiter samples requests<br>0 = sample clock after TS_<br>1 = sample 2 clocks after TS_ |

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                   |
|---------|------|-------------|----------------|----------------------------------------------------------------------------------------------------------------------------|
| PARK    | R/W  | PB_RST      | 0              | Bus Park Mode<br>0 = Park on last bus master<br>1 = Park on specific master                                                |
| BM_PARK | R/W  | PB_RST      | 0              | Bus Master to be Parked<br>00 = PowerSpan II<br>01 = External Master 1<br>10 = External Master 2<br>11 = External Master 3 |

PB\_ARB\_CTRL Description

**Mx\_EN**: When set, the arbiter recognizes address bus requests for this master. When cleared, the arbiter ignores address bus requests from this master. The default state for these bits is determined by the PWRUP\_BOOT option as defined by the following table:

#### Table 122: Mx\_EN Default State

| PWRUP_BOOT<br>Selection | RST_CSR Register | M1_EN | M2_EN | M3_EN |
|-------------------------|------------------|-------|-------|-------|
| Boot PCI                | PCI_BOOT=1       | 0     | 0     | 0     |
| Boot Processor Bus      | PCI_BOOT=0       | 1     | 0     | 0     |

Mx\_PRI: Determines the arbitration priority for external masters.

**TS\_DLY**: When set, the PB arbiter samples incoming requests two clocks after a TS\_ signal is received. When cleared, the arbiter samples requests one clock after a TS\_ signal is received. The default state is 0.

An example application for this feature is some L2 caches hold the BR\_ signal after the TS\_ signal starts. The PowerSpan II arbiter could see this as a valid request and give the bus to the L2 cache when the bus was not requested. This bit delays when the PB arbiter samples the signal so a false bus request is not granted.

**PARK**: When set, the arbiter parks the address bus on the Processor Bus master programmed in the BM\_PARK field. When cleared, the arbiter parks the address bus on the last Processor Bus master to be granted the bus.

**BM\_PARK**: Identifies the master to be parked (see Table 123).

| BM_PARK [1:0] | Parked Processor Bus<br>Master | External Pins       |
|---------------|--------------------------------|---------------------|
| 00            | PowerSpan II                   | None                |
| 01            | M1                             | PB_BR[1]_/PB_BG[1]_ |
| 10            | M2                             | PB_BR[2]_/PB_BG[2]_ |
| 11            | М3                             | PB_BR[3]_/PB_BG[3]_ |

## 13.5.33 DMA x Source Address Register

This register specifies the starting byte address on the source port for channel DMAx. The register is programmed for Direct mode DMA or updated by the Linked-list when loading the command packet.

| Table 124 | : DMA x | Source | Address | Register |
|-----------|---------|--------|---------|----------|
|-----------|---------|--------|---------|----------|

| Registe     | r Name: DMAx_SRC_ADDR | Register Offset: | 0x304, 0x334, 0x 364 | 4, 0x394   |
|-------------|-----------------------|------------------|----------------------|------------|
| PCI<br>Bits | Fund                  | ction            |                      | PB<br>Bits |
| 31-24       | SAI                   | DDR              |                      | 0-7        |
| 23-16       | SAI                   | DDR              |                      | 8-15       |
| 15-08       | SAI                   | DDR              |                      | 16-23      |
| 07-00       | SAI                   | DDR              |                      | 24-31      |

#### DMAx\_SRC\_ADDR Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                           |
|-------------|------|-------------|----------------|------------------------------------------------------------------------------------|
| SADDR[31:0] | R/W  | G_RST       | 0              | Starting byte address on the source bus for the port defined by DMAx_TCR[SRC_PORT] |

The DMAx\_SRC\_ADDR register is updated during the DMA transaction. Writing to this register while the DMA is active has no effect. While the DMA is active, this register provide status information on the progress of the transfer

## 13.5.34 DMA x Destination Address Register

This register specifies the starting byte address on the destination port for channel DMAx. This register is programmed for a Direct mode DMA or programmed by the Linked-list when loading the command packet.

| Table 125: | DMA x | Destination | Address | Register |
|------------|-------|-------------|---------|----------|
|------------|-------|-------------|---------|----------|

| Registe     | r Name: DMAx_DST_ADDR | Regist | ter Offset: | 0x30C, 0x3 | 33C, 0x36C | C, 0x39C   |
|-------------|-----------------------|--------|-------------|------------|------------|------------|
| PCI<br>Bits | Fund                  | ction  |             |            |            | PB<br>Bits |
| 31-24       | DADDR                 |        |             |            |            |            |
| 23-16       | DADDR                 |        |             |            |            |            |
| 15-08       | DADDR                 |        |             |            |            | 16-23      |
| 07-00       | DADDR                 |        | 0           | 0          | 0          | 24-31      |

#### DMAx\_DST\_ADDR Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                |
|-------------|------|-------------|----------------|-----------------------------------------------------------------------------------------|
| DADDR[31:3] | R/W  | G_RST       | 0              | Starting byte address on the destination bus for the port defined by DMAx_TCR[DST_PORT] |

The DMAx\_DST\_ADDR register is updated during the DMA transaction. Writing to this register while the DMA is active has no effect. While the DMA is active, this register provides status information on the progress of the transfer.

**DADDR:** The lower three bits of the destination address is identical to the lower three bits of the source address (DMAx\_SRC\_ADDR).

## 13.5.35 DMA x Transfer Control Register

This register is used to specify parameters for channel DMAx. It is programmed directly for direct mode DMA or programmed by the Linked-list when loading the command packet.

Writing to this register while the DMA is active has no effect. While the DMA is active, this register provides status information on the progress of the transfer.

| Table 1 | 126: | DMA | Х | Transfer | Control | Register |
|---------|------|-----|---|----------|---------|----------|
|---------|------|-----|---|----------|---------|----------|

| Registe     | r Name: DMAx_TCR |          | Register Offset | : 0x314, 0x344, 0x374 | 4, 0x3A4 |  |  |
|-------------|------------------|----------|-----------------|-----------------------|----------|--|--|
| PCI<br>Bits | Function         |          |                 |                       |          |  |  |
| 31-24       | SRC_PORT         | DST_PORT | END             | 0                     | 0-7      |  |  |
| 23-16       | BC               |          |                 |                       |          |  |  |
| 15-08       | BC 16            |          |                 |                       |          |  |  |
| 07-00       |                  | В        | С               |                       | 24-31    |  |  |

#### DMAx\_TCR Description

| Name              | Туре | Reset<br>By | Reset<br>State | Function                                                                                  |
|-------------------|------|-------------|----------------|-------------------------------------------------------------------------------------------|
| SRC_PORT<br>[1:0] | R/W  | G_RST       | 0              | Source Port for DMA transfer<br>00 = PCI-1<br>01 = PCI-2<br>10 = PB<br>11 = reserved      |
|                   |      |             |                | Single PCI PowerSpan II:<br>00 = PCI-1<br>10 = PB<br>01, 11 = reserved                    |
| DST_PORT<br>[1:0] | R/W  | G_RST       | 0              | Destination Port for DMA transfer<br>00 = PCI-1<br>01 = PCI-2<br>10 = PB<br>11 = reserved |

| DMAx_ | TCR | Description |
|-------|-----|-------------|
|       |     |             |

| Name     | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                 |
|----------|------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------|
|          |      |             |                | Single PCI PowerSpan II:<br>00 = PCI-1<br>10 = PB<br>01, 11 = reserved                                                   |
| END[1:0] | R/W  | P1_RST      | 10             | Endian Conversion Mode<br>00 = Little-endian<br>01 = PowerPC little-endian<br>10 = Big-endian<br>11 = True little-endian |
| BC[23:0] | R/W  | G_RST       | 0              | Byte Count                                                                                                               |

**END[1:0]**: Selects the endian conversion mode for DMA activity involving the Processor Bus and a PCI Interface. When the source and destination ports are the same, then the conversion mode is little-endian, regardless of the value of this bit.

**BC**: When the initial value of the byte count is non-zero in Linked-List mode, the DMA starts with a Direct mode transfer. After the direct mode transfer has completed, the DMA channel begins processing the linked-list.

The field is updated during the DMA transaction.

## 13.5.36 DMA x Command Packet Pointer Register

This register specifies the 32-byte aligned address of the next command packet in the Linked-List for channel DMAx. It is programmed by PowerSpan II from the Linked-list when loading the command packet.

The DMAx\_CPP register is updated at the start of a Linked-list transfer and remains constant throughout the transfer. Writing to this register while the DMA is active has no effect.

For a Direct mode DMA transfer, this register does not need to be programmed.

Table 127: DMA x Command Packet Pointer Register

| Register Name: DMAx_CPP |     |                                | Register Offset: 0x31C, 0x | 34C, 0x37C | , 0x3AC |
|-------------------------|-----|--------------------------------|----------------------------|------------|---------|
| PCI<br>Bits Function    |     |                                |                            |            |         |
| 31-24                   | NCP |                                |                            |            |         |
| 23-16                   | NCP |                                |                            |            |         |
| 15-08                   | NCP |                                |                            |            | 16-23   |
| 07-00                   | NCP | NCP PowerSpan II Reserved LAST |                            |            |         |

DMAx\_CPP Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                               |
|-----------|------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NCP[31:5] | R/W  | G_RST       | 0              | Next Command Packet Address.<br>Points to a 32-byte aligned memory location of a<br>linked-list on the port specified by the CP_PORT<br>bit in the DMAx_ATTR register. |
| LAST      | R/W  | G_RST       | 0              | Last Item<br>0 = more items in linked list<br>1 = last item in linked list                                                                                             |

## 13.5.37 DMA x General Control and Status Register

This register contains general control and status information for channel DMA*x*. This register is not part of a linked-list Command Packet.



Writing to the CHAIN and OFF bits while the DMA is active has no effect.

### Table 128: DMA x General Control and Status Register

| Registe     | er Name: D | MAx_GCS | R             |               | Regi          | ster Offset  | : 0x320, 0x  | 350, 0x380  | ), 0x3B0 |
|-------------|------------|---------|---------------|---------------|---------------|--------------|--------------|-------------|----------|
| PCI<br>Bits | Function   |         |               |               |               |              |              | PB<br>Bits  |          |
| 31-24       | GO         | CHAIN   | 0             | 0             | 0             | STOP_<br>REQ | HALT_<br>REQ | 0           | 0-7      |
| 23-16       | DACT       | DI      | 38            | DBS_<br>EN    |               |              | OFF          |             | 8-15     |
| 15-08       | 0          | 0       | P1_ERR        | P2_ERR        | PB_ER<br>R    | STOP         | HALT         | DONE        | 16-23    |
| 07-00       | 0          | 0       | P1_ERR<br>_EN | P2_ERR<br>_EN | PB_ER<br>R_EN | STOP_<br>EN  | HALT_<br>EN  | DONE_<br>EN | 24-31    |

#### DMAx\_GCSR Description

| Name     | Туре              | Reset<br>By | Reset<br>State | Function                                                                                     |
|----------|-------------------|-------------|----------------|----------------------------------------------------------------------------------------------|
| GO       | Write 1 to<br>Set | G_RST       | 0              | DMA Go bit<br>0 = no effect, 1 = Begin DMA transfer                                          |
| CHAIN    | R/W               | G_RST       | 0              | DMA Chaining<br>0 = DMA Direct mode<br>1 = DMA Linked-List mode                              |
| STOP_REQ | Write 1 to<br>Set | G_RST       | 0              | DMA Stop Request<br>0 = no effect<br>1 = Stop DMA when all buffered data has been<br>written |

#### DMAx\_GCSR Description

| Name     | Туре                  | Reset<br>By | Reset<br>State | Function                                                                                                                                                |
|----------|-----------------------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| HALT_REQ | Write 1 to<br>Set     | G_RST       | 0              | DMA Halt Request<br>0 = no effect<br>1 = Halt DMA at completion of current command<br>packet                                                            |
| DACT     | R                     | G_RST       | 0              | DMA Active<br>0 = not active<br>1 = active                                                                                                              |
| DBS[1:0] | R/W                   | G_RST       | 0              | DMA Block Size (when DBS_EN is set to 1)<br>00=32 bytes<br>01=16 bytes<br>10=8 bytes<br>11=4 bytes                                                      |
| DBS_EN   | R/W                   | G_RST       | 0              | DMA Block Size Enable<br>0 = not active<br>1 = active                                                                                                   |
| OFF      | R/W                   | G_RST       | 0              | DMA Channel Off Counter (number of PB clocks)<br>000 = 0<br>001 = 128<br>010 = 256<br>011 = 512<br>100 = 1024<br>101 = 2048<br>110 = 4096<br>111 = 8192 |
| P1_ERR   | R/Write 1 to<br>Clear | G_RST       | 0              | PCI-1 Bus Error<br>0 = no error<br>1 = error                                                                                                            |
| P2_ERR   | R/Write 1 to<br>Clear | G_RST       | 0              | PCI-2 Bus Error<br>0 = no error<br>1 = error                                                                                                            |
|          |                       |             |                | Single PCI PowerSpan II: Reserved                                                                                                                       |

#### DMAx\_GCSR Description

| Name      | Туре                  | Reset<br>By | Reset<br>State | Function                                                                         |
|-----------|-----------------------|-------------|----------------|----------------------------------------------------------------------------------|
| PB_ERR    | R/Write 1 to<br>Clear | G_RST       | 0              | Processor Bus Error<br>0 = no error<br>1 = error                                 |
| STOP      | R/Write 1 to<br>Clear | G_RST       | 0              | DMA Stopped Flag<br>0 = not stopped<br>1 = stopped                               |
| HALT      | R/Write 1 to<br>Clear | G_RST       | 0              | DMA Halted Flag<br>0 = not halted<br>1 = halted                                  |
| DONE      | R/Write 1 to<br>Clear | G_RST       | 0              | DMA Done Flag<br>0 = transfer not done<br>1 = transfer done                      |
| P1_ERR_EN | R/W                   | G_RST       | 0              | Primary PCI Error Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt   |
| P2_ERR_EN | R/W                   | G_RST       | 0              | Normal PCI Error Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt    |
|           |                       |             |                | Single PCI PowerSpan II: Reserved                                                |
| PB_ERR_EN | R/W                   | G_RST       | 0              | Processor Bus Error Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt |
| STOP_EN   | R/W                   | G_RST       | 0              | DMA Stop Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt            |
| HALT_EN   | R/W                   | G_RST       | 0              | DMA Halt Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt            |
| DONE_EN   | R/W                   | G_RST       | 0              | DMA Done Interrupt Enable<br>0 = no interrupt<br>1 = enable interrupt            |

**DBS**[1:0]: Controls the byte size of transactions generated by the DMA channel. The DBS\_EN bit must be set to 1 in order for the DBS functionality to be enabled.

**DBS\_EN**: Provides programmable control over the byte size of transactions generated by the DMA channel. The byte size is based on values programmed into DBS[1:0].

**OFF**: Provides programmable control over the amount of source bus traffic generated by the DMA channel. The channel will interleave source bus transfers with a period of idle Processor Bus clocks where no source bus requests are generated. When source and destination ports are different, 256 bytes of source bus traffic occur before the idle period. If source and destination ports are the same, 64 bytes of source bus traffic occur before the idle period. This helps prevent PowerSpan II from interfering with Processor Bus instruction fetches.

**DONE**: The DONE bit is set in the following cases:

- completion of Direct Mode DMA
- completion of Linked-List DMA

The DMA will not proceed until the DONE, and all other status bits, are cleared.

# 13.5.38 DMA x Attributes Register

This register contains additional parameters for DMA channel x. It is not part of a Linked-List Command Packet.

Table 129: DMA x Attributes Register

| Registe     | r Name: DMAx_ATTR     | 2                     |      | Register Offset: 0x324, 0x354, 0x384, 0x3B4 |       |       |  |
|-------------|-----------------------|-----------------------|------|---------------------------------------------|-------|-------|--|
| PCI<br>Bits |                       | Function              |      |                                             |       |       |  |
| 31-24       | CP_PORT               | 0                     | GBL_ | GBL_ CI_ PowerSpan II Reserved              |       | 0-7   |  |
| 23-16       | PowerSpan II Re       | PowerSpan II Reserved |      |                                             | RTT   |       |  |
| 15-08       | PowerSpan II Reserved |                       |      |                                             | 16-23 |       |  |
| 07-00       | PowerSpan II Reserved |                       |      |                                             |       | 24-31 |  |

#### DMAx\_ATTR Description

| Name             | Туре | Reset<br>By | Reset<br>State | Function                                                                     |
|------------------|------|-------------|----------------|------------------------------------------------------------------------------|
| CP_PORT<br>[1:0] | R/W  | G_RST       | 0              | Command Packet Port<br>00 = PCI-1<br>01 = PCI-2,<br>10 = PB<br>11 = reserved |
|                  |      |             |                | Single PCI PowerSpan II:<br>00 = PCI-1<br>10 = PB<br>01, 11 = reserved       |
| PB_GBL_          | R/W  | G_RST       | 0              | Processor Bus Global<br>0 = Assert PB_GBL_<br>1 = Negate PB_GBL_             |
| PB_CI_           | R/W  | G_RST       | 0              | Processor Bus Cache Inhibit<br>0 = Assert PB_CI_<br>1 = Negate PB_CI_        |

DMAx\_ATTR Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function                                                                 |
|----------|------|-------------|----------------|--------------------------------------------------------------------------|
| RTT[4:0] | R/W  | G_RST       | 01010          | Processor Bus Read Transfer Type PB_TT[0:4]<br>01010 = Read              |
| WTT[4:0] | R/W  | G_RST       | 00010          | Processor Bus Write Transfer Type PB_TT[0:4]<br>00010 = Write with flush |

**RTT/WTT:** Selects the Transfer Type on the Processor Bus. The register bits RTT[4:0]/WTT[4:0] are mapped to pins PB\_TT[0:4].

# 13.5.39 Miscellaneous Control and Status Register

### Table 130: Miscellaneous Control and Status Register

| Registe     | er Name: M     | ISC_CSR        |        |              |               | Registe | er Offset: | 0x400 |  |
|-------------|----------------|----------------|--------|--------------|---------------|---------|------------|-------|--|
| PCI<br>Bits |                | Function       |        |              |               |         |            |       |  |
| 31-24       | TUNDRA_DEV_ID  |                |        |              |               |         |            | 0-7   |  |
| 23-16       | TUNDRA_VER_ID  |                |        |              |               |         |            | 8-15  |  |
| 15-08       | VPD_E<br>N     |                | VPD_CS | BAR_<br>EQ_0 | Re-<br>served | ELOAI   | D_OPT      | 16-23 |  |
| 07-00       | P1_LOC<br>KOUT | P2_LOC<br>KOUT | -      |              | PCI_M7        | PCI_M6  | PCI_M5     | 24-31 |  |

#### MISC\_CSR Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function                                                                             |
|--------------------|------|-------------|----------------|--------------------------------------------------------------------------------------|
| TUNDRA_DEV_ID[7:0] | R    | G_RST       | 0x00           | Tundra Internal Device ID                                                            |
|                    |      |             | 0x01           | Single PCI PowerSpan II                                                              |
| TUNDRA_VER_ID[7:0] | R    | G_RST       | 0x02           | Tundra Internal Version ID<br>PowerSpan II = 02<br>(Original PowerSpan = 01)         |
| VPD_EN             | R/W  | G_RST       | 0<br>EEPROM    | PCI Vital Product Data.<br>0=disabled<br>1=enabled                                   |
| VPD_CS[2:0]        | R/W  | G_RST       | 0<br>EEPROM    | PCI Vital Product Data EEPROM Chip Select.                                           |
| BAR_EQ_0           | R/W  | G_RST       | 0<br>EEPROM    | Base Address Equivalent to 0x00000                                                   |
| ELOAD_OPT[1:0]     | R    | G_RST       | 0<br>EEPROM    | EEPROM load option<br>00=do not load<br>01=short load<br>10=long load<br>11=reserved |

#### MISC\_CSR Description

| Name        | Туре         | Reset<br>By | Reset<br>State | Function                               |
|-------------|--------------|-------------|----------------|----------------------------------------|
| Indiffe     | Type         | Бу          | State          | Function                               |
| P1_LOCKOUT  | R/Write 1 to | G_RST       | 1              | PCI-1 lockout                          |
|             | Clear        |             | EEPROM         | 0=not set                              |
|             |              |             |                | 1=set                                  |
| P2_LOCKOUT  | R/Write 1 to | G_RST       | 1              | PCI-2 lockout                          |
|             | Clear        |             | EEPROM         | 0=not set                              |
|             |              |             |                | 1=set                                  |
|             |              |             |                | Single PCI PowerSpan II: Reserved      |
| PCI_ARB_CFG | Write 1 to   | G_RST       | 0              | PCI Arbiter Pins Configured            |
|             | set          |             | EEPROM         | 0=Floating PCI Arbiter pins not yet    |
|             |              |             |                | configured                             |
|             |              |             |                | 1=Floating PCI Arbiter pins configured |
|             |              |             |                | Single PCI PowerSpan II: Reserved      |
| PCI_M7      | R/W          | G_RST       | 0              | PCI Arbiter Master 7                   |
|             |              |             | EEPROM         | 0=PowerSpan II PCI-1 arbiter           |
|             |              |             |                | 1=PowerSpan II PCI-2 arbiter           |
|             |              |             |                | Single PCI PowerSpan II: Reserved      |
| PCI_M6      | R/W          | G_RST       | 0              | PCI Arbiter Master 6                   |
|             |              |             | EEPROM         | 0=PowerSpan II PCI-1 arbiter           |
|             |              |             |                | 1=PowerSpan II PCI-2 arbiter           |
|             |              |             |                | Single PCI PowerSpan II: Reserved      |
| PCI_M5      | R/W          | G_RST       | 0              | PCI Arbiter Master 5                   |
|             |              |             | EEPROM         | 0=PowerSpan II PCI-1 arbiter           |
|             |              |             |                | 1=PowerSpan II PCI-2 arbiter           |
|             |              |             |                | Single PCI PowerSpan II: Reserved      |

**VPD\_EN:** Enables PCI Vital Product Data (VPD) as described in the "I2C/ EEPROM" on page 153. When enabled, the VPD registers in the PCI Interface that has been designated as primary are used to access PCI Vital Product Data.

**BAR\_EQ\_0:** This bit enables a value of 0x00000 for Px Base Address registers.

**ELOAD\_OPT:** Identifies the load option selected in the first byte of the power-up EEPROM.

**Px\_LOCKOUT:** When set, all configuration and memory register space accesses from PCI are retried. The Px\_LOCKOUT bit must be cleared for all memory space accesses to the PowerSpan II's PCI target images.



PowerSpan II does not terminate the cycle when the Px\_LOCKOUT bit is not cleared during a memory space access to the PCI target images. If PowerSpan II does not terminate the cycle, the PCI bus experiences a deadlock condition.

The Px\_LOCKOUT bit must be cleared before the corresponding PCI Target Image claims a transaction. The bit is cleared by an agent on the Processor Bus or by EEPROM load. The bit is cleared automatically by PowerSpan II when the PWRUP\_BOOT option is set to PCI.

**PCI\_ARB\_CFG**: When set, this bit enables recognition of external master requests on PCI\_REQ#[7:5]. The user must set this bit after completing configuration all of the PowerSpan II floating PCI arbitration pins with bits PCI\_M7, PCI\_M6 and PCI\_M5. When PCI\_ARB\_CFG is not set, requests from external masters connected to PCI\_REQ#[7:5] are ignored.

Initialization of PCI\_ARB\_CFG is not required for the Single PCI PowerSpan II because PCI\_REQ#[7:5]/PCI\_GNT#[7:5] are dedicated to the PCI-1 Interface.

PCI\_Mx: Each of these PCI Master bits must be explicitly initialized by the user to indicate which PowerSpan II PCI arbiter should service the pair of PCI\_REQ#/ PCI\_GNT# pins. Initialization occurs through EEPROM load or a register write.

Table 131 indicates register bit to arbitration pin mappings:

| Table | 131: | Arbitration | Pin | Mappings |
|-------|------|-------------|-----|----------|
|       |      |             |     |          |

| Bit Arbitration Pins |                         |  |  |
|----------------------|-------------------------|--|--|
| PCI_M5               | PCI_REQ#[5]/PCI_GNT#[5] |  |  |
| PCI_M6               | PCI_REQ#[6]/PCI_GNT#[6] |  |  |
| PCI_M7               | PCI_REQ#[7]/PCI_GNT#[7] |  |  |

The PCI\_Mx bits do not affect the behavior of the Single PCI PowerSpan II because PCI\_REQ#[7:5]#/PCI\_GNT#[7:5] are dedicated to the PCI-1 Interface.

## 13.5.40 Clock Control Register

PowerSpan II does not use the TUNE bits for adjusting the PLL parameters. This register does not effect PLL performance.



This register does not effect the functionality or performance of PowerSpan II. This register makes the device backwards compatible with the PowerSpan II device.

### Table 132: Clock Control Register

| Registe     | r Name: CLOCK_CTL | Register Offset: 0x404 |  |  |
|-------------|-------------------|------------------------|--|--|
| PCI<br>Bits | Fund              | ction PB Bits          |  |  |
| 31-24       | PB_TUNE           |                        |  |  |
| 23-16       | P1_TUNE           |                        |  |  |
| 15-08       | P2_1              | UNE 16-23              |  |  |
| 07-00       | PowerSpan         | II Reserved 24-31      |  |  |

#### **CLOCK\_CTL** Description

| Name         | Туре | Reset<br>By | Reset<br>State           | Function            |
|--------------|------|-------------|--------------------------|---------------------|
| PB_TUNE[7:0] | R    | G_RST       | (See<br>Below)<br>EEPROM | PB PLL Tune Bits    |
| P1_TUNE[7:0] | R    | G_RST       | (See<br>Below)<br>EEPROM | PCI-1 PLL Tune Bits |
| P2_TUNE[7:0] | R    | G_RST       | (See<br>Below)<br>EEPROM | PCI-2 PLL Tune Bits |

**PB\_TUNE:** Tune bits for the Processor Bus PLL. The reset value is a function of the system level applied to the PB\_FAST external pin. The reset values are:

- PB\_TUNE[7:2] = 000100
- $PB_TUNE[1] = \sim PB_FAST$
- PB\_TUNE[0] = 1

**P1\_TUNE**: Tune bits for the PCI-1 PLL. The reset value is a function of the system level applied to the P1\_M66EN external pin. The reset values are:

- P1\_TUNE[7:1] = 0001001
- P1\_TUNE[0] = ~P1\_M66EN

**P2\_TUNE**: Tune bits for the PCI-2 PLL. The reset value is a function of the system level applied to the P2\_M66EN external pin. The reset values are:

- P2\_TUNE[7:1] = 0001001
- P2\_TUNE[0] = ~P2\_M66EN

# 13.5.41 I<sup>2</sup>C/EEPROM Interface Control and Status Register

This register supports the PowerSpan II I<sup>2</sup>C/EEPROM interface.

### Table 133: I<sup>2</sup>C/EEPROM Interface Control and Status Register

| Registe     | r Name: 12 | 2C_CSR   |                       | Register | Offset: | 0x408 |  |  |
|-------------|------------|----------|-----------------------|----------|---------|-------|--|--|
| PCI<br>Bits |            | Function |                       |          |         |       |  |  |
| 31-24       | ADDR       |          |                       |          |         |       |  |  |
| 23-16       | DATA       |          |                       |          |         |       |  |  |
| 15-08       | DEV_CODE   |          |                       | CS       | RW      | 16-23 |  |  |
| 07-00       | ACT        | ERR      | PowerSpan II Reserved |          |         |       |  |  |

#### I2C\_CSR Description

| Name          | Туре                  | Reset<br>By | Reset<br>State | Function                                                                      |
|---------------|-----------------------|-------------|----------------|-------------------------------------------------------------------------------|
| ADDR[7:0]     | R/W                   | G_RST       | 0              | Specifies I <sup>2</sup> C device address to be accessed.                     |
| DATA[7:0]     | R/W                   | G_RST       | 0              | Specifies the required data for a write. Holds the data at the end of a read. |
| DEV_CODE[3:0] | R/W                   | G_RST       | 1010           | Device select. I <sup>2</sup> C 4-bit device code.                            |
| CS[2:0]       | R/W                   | G_RST       | 0              | Chip Select                                                                   |
| RW            | R/W                   | G_RST       | 0              | 0=read<br>1=write                                                             |
| ACT           | R                     | G_RST       | 0              | I <sup>2</sup> C interface active<br>0=not active<br>1=active                 |
| ERR           | R/Write 1 to<br>Clear | G_RST       | 0              | Error<br>0=no error<br>1=error condition                                      |

The user initiates a  $I^2C$  bus cycle by writing to this register. Software must wait for the ACT bit to be zero before starting a new  $I^2C$  cycle. When the ACT bit is 1, writes to this register have no effect and the DATA field is undefined.

The ACT bit is set under of the following conditions:

- I<sup>2</sup>C interface is busy servicing a read or write as a result of a write to this register
- I<sup>2</sup>C interface is busy loading registers at the end of reset
- I<sup>2</sup>C interface is busy accessing PCI Vital Product Data

The PCI VPD EEPROM Chip Select (VPD\_CS) bit, in the MISC\_CSR, selects the EEPROM where VPD resides. If VPD\_CS is 000b, then VPD starts at address offset 0x40 of the first EEPROM. For all other values of VPD\_CS, VPD starts at address offset 0x00 of the specified EEPROM.

**ERR:** The register updates the ERR bit five clock cycles after a clean transaction has completed.

# 13.5.42 Reset Control and Status Register

This register contains the read-only bits that specify all PowerSpan II power-up options and status of a number of pins that are normally fixed for each application.

| Table 134: | <b>Reset Control and Sta</b> | atus Register |
|------------|------------------------------|---------------|
|------------|------------------------------|---------------|

| Registe     | er Name: R                | ST_CSR        |               |                                    |           | Regis         | ster Offset: | 0x40C |
|-------------|---------------------------|---------------|---------------|------------------------------------|-----------|---------------|--------------|-------|
| PCI<br>Bits |                           | Function      |               |                                    |           |               |              |       |
| 31-24       | PB_RST<br>_DIR            | PB_ARB<br>_EN | PB_FAS<br>T   | PCI_ PowerSpan II Reserved<br>BOOT |           | d             | 0-7          |       |
| 23-16       | P1_RST<br>_DIR            | P1_ARB<br>_EN | P1_M66<br>EN  | PowerSpan II Reserved              |           | P1_R64<br>_EN | P1_D64       | 8-15  |
| 15-08       | P2_RST<br>_DIR            | P2_ARB<br>_EN | P2_M66<br>EN  | PowerSpan II Reserved PRI_PCI      |           | PRI_PCI       | 16-23        |       |
| 07-00       | Power-<br>Span II<br>Rsvd | 7400_<br>MODE | BYPASS<br>_EN | ELOAD                              | PowerSpan | II Reserve    | d            | 24-31 |

### **RST\_CSR** Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                                                                                 |
|------------|------|-------------|----------------|------------------------------------------------------------------------------------------|
| PB_RST_DIR | R    | G_RST       | PWRUP          | Status of PB_RST_DIR pin.                                                                |
| PB_ARB_EN  | R    | G_RST       | PWRUP          | Processor bus arbiter enable.<br>0=Disabled power-up option<br>1=Enabled power-up option |
| PB_FAST    | R    | G_RST       | PWRUP          | Processor Bus Clock Frequency Selection<br>0=25 MHz to 50 MHz<br>1=50 MHz to 100 MHz     |
| PCI_BOOT   | R    | G_RST       | PWRUP          | PCI Boot<br>0=Boot from Processor Bus<br>1=Boot from PCI                                 |
| P1_RST_DIR | R    | G_RST       | PWRUP          | Status of P1_RST_DIR pin.                                                                |

#### **RST\_CSR** Description

| Name       | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                                                              |
|------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1_ARB_EN  | R    | G_RST       | PWRUP          | PCI-1 arbiter enable<br>0=Disabled power-up option<br>1=Enabled power-up option                                                                                                       |
| P1_M66EN   | R    | G_RST       | PWRUP          | PCI-1 Clock Frequency Selection<br>0=25 MHz to 33 MHz<br>1=33 MHz to 66 MHz                                                                                                           |
| P1_R64_EN  | R    | G_RST       | PWRUP          | P1_REQ64# output enable.<br>0=PowerSpan II does not assert P1_REQ64# at<br>reset<br>1=PowerSpan II does assert P1_REQ64# at reset<br>to indicate the presence of a 64-bit P1_AD[] bus |
| P1_D64     | R    | G_RST       | PWRUP          | PCI-1 Databus Width<br>0=connected to 32-bit AD bus<br>1=connected to 64-bit AD bus<br>See Table 3 on page 46                                                                         |
| P2_RST_DIR | R    | G_RST       | PWRUP          | Status of P2_RST_DIR pin.                                                                                                                                                             |
|            |      |             |                | Single PCI PowerSpan II: Reserved                                                                                                                                                     |
| P2_ARB_EN  | R    | G_RST       | PWRUP          | PCI-2 arbiter enable.<br>0=Disabled power-up option<br>1=Enabled power-up option                                                                                                      |
|            |      |             |                | Single PCI PowerSpan II: Reserved                                                                                                                                                     |
| P2_M66EN   | R    | G_RST       | PWRUP          | PCI-2 Clock Frequency Selection<br>0=25 MHz to 50 MHz<br>1=33 MHz to 66 MHz                                                                                                           |
|            |      |             |                | Single PCI PowerSpan II: Reserved                                                                                                                                                     |
| PRI_PCI    | R    | G_RST       | PWRUP          | Designated Primary PCI Bus.<br>0=PCI-1 is Primary<br>1=PCI-2 is Primary                                                                                                               |
|            |      |             |                | Single PCI PowerSpan II: Reserved                                                                                                                                                     |

| Name      | Туре | Reset<br>By | Reset<br>State | Function                                                                                   |
|-----------|------|-------------|----------------|--------------------------------------------------------------------------------------------|
| 7400_MODE | R    | G_RST       | PWRUP          | 7400 Mode Enable<br>0=Disabled power-up option<br>1=Enabled power-up option                |
| BYPASS_EN | R    | G_RST       | PWRUP          | Phase Locked Loop Bypass Enable<br>0=Disabled power-up option<br>1=Enabled power-up option |
| ELOAD     | R    | G_RST       | PWRUP          | EEPROM load after reset.<br>0=EEPROM load not enabled<br>1=EEPROM load enabled             |

#### RST\_CSR Description

**P1\_D64**: Indicates the width of the databus to which the PCI-1 Interface is connected. This is determined by the level on P1\_REQ64# at the negation of P1\_RST#, or by the level on P1\_64EN#.

**PB\_FAST:** Indicates the latched value of the PB\_FAST pin. This bit is used to optimally configure the Processor Bus Interface PLL for the desired operating frequency.

**P1\_M66EN:** Indicates the latched value of the P1\_M66EN pin. This bit is used to optimally configure the PCI-1 interface PLL for the desired operating frequency.

**P2\_M66EN:** Indicates the latched value of the P2\_M66EN pin. This bit is used to optimally configure the PCI-2 interface PLL for the desired operating frequency.

**7400\_MODE:** When enabled, the PB arbiter qualifies bus grants before issuing a grant to a PB Master. When disabled, the PB arbiter issues a grant to a PB Master and it is expected that the PB Master receiving the grant qualifies the grant.

**BYPASS\_EN:** Indicates the setting of this power-up option. If this bit is set, the user has elected to bypass all PowerSpan II PLL's. This bit supports slow speed emulation of a PowerSpan II based system.

## 13.5.43 Interrupt Status Register 0

This register is one of two interrupt status registers. ISR0 is used primarily for normal operating status.

When set, each bit of this register indicates the corresponding interrupt source is active.

Table 135: Interrupt Status Register 0

| Register Name: ISR0 |               |       |              |             |             |             | Reg         | ister Offse | t: 0x410 |
|---------------------|---------------|-------|--------------|-------------|-------------|-------------|-------------|-------------|----------|
| PCI<br>Bits         | Function      |       |              |             |             |             |             | PB<br>Bits  |          |
| 31-24               | ISR1_A<br>CTV | 0     | I2O_HO<br>ST | I2O_IOP     | DMA3        | DMA2        | DMA1        | DMA0        | 0-7      |
| 23-16               | P2_HW         | P1_HW | INT5_<br>HW  | INT4_<br>HW | INT3_<br>HW | INT2_<br>HW | INT1_<br>HW | INT0_<br>HW | 8-15     |
| 15-08               | DB7           | DB6   | DB5          | DB4         | DB3         | DB2         | DB1         | DB0         | 16-23    |

MBOX3

MBOX2

MBOX1

MBOX0

24-31

MBOX4

MBOX5

#### **ISR0** Description

MBOX7

MBOX6

07-00

| Name      | Туре                  | Reset<br>By | Reset<br>State | Function                                                                                                                                       |
|-----------|-----------------------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| ISR1_ACTV | R                     | G_RST       | 0              | Indicates an interrupt status bit is set in ISR1 register.                                                                                     |
| I2O_HOST  | R                     | G_RST       | 0              | Interrupt asserted to the I2O Host to indicate<br>that the Outbound Post List FIFO contains MFAs of<br>messages for the Host to process.       |
| 120_10P   | R/Write 1 to<br>Clear | G_RST       | 0              | Interrupt to embedded PowerPC to indicate that<br>the Inbound Post List FIFO contains MFAs of<br>messages for the embedded PowerPC to process. |
| DMAx      | R/Write 1 to<br>Clear | G_RST       | 0              | Set when DMAx generates an interrupt. See DMAx_GCSR register for details.                                                                      |
| P1_HW     | R/Write 1 to<br>Clear | G_RST       | 0              | PCI-1 hardware interrupt. Set when a level interrupt is detected on the PCI-1 INTA# pin.                                                       |
| P2_HW     | R/Write 1 to<br>Clear | G_RST       | 0              | PCI-2 hardware interrupt. Set when a level interrupt is detected on the PCI-2 INTA# pin.                                                       |

#### **ISR0** Description

| Name      | Туре                  | Reset<br>By | Reset<br>State | Function                                                                       |
|-----------|-----------------------|-------------|----------------|--------------------------------------------------------------------------------|
|           |                       |             |                | Single PCI PowerSpan II: Reserved                                              |
| INT0_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[0]_ pin. |
| INT1_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[1]_ pin. |
| INT2_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[2]_ pin. |
| INT3_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[3]_ pin. |
| INT4_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[4]_ pin. |
| INT5_HW   | R/Write 1<br>to Clear | G_RST       | 0              | Hardware interrupt. Set when a level interrupt is detected on the INT[5]_ pin. |
| DB7-DB0   | R/Write 1 to<br>Clear | G_RST       | 0              | Set when a doorbell register is written to in the IER register.                |
| MBOX[7:0] | R/Write 1 to<br>Clear | G_RST       | 0              | Set when a mailbox is written to.                                              |

**ISR1\_ACTV**: This bit is a logical OR of all the status bits in the ISR1 register. When any status bit in ISR1 is set, ISR1\_ACTV is set. When all bits of the ISR1 register are cleared, ISR1\_ACTV is cleared. This bit is useful in determining whether or not to read the ISR1 register to determine the source of the interrupt.

**I2O\_HOST:** This bit is an alias for the I2O Outbound Post List Status Register located at offset 0x030 of the I2O Target Image.

# 13.5.44 Interrupt Status Register 1

This register is one of two interrupt status registers. ISR1 is organized with error conditions in PowerSpan II.

Table 136: Interrupt Status Register 1

| Registe     | er Name: IS   | SR1           |                       |              |                 |                 | Regi            | ister Offse | t: 0x414   |
|-------------|---------------|---------------|-----------------------|--------------|-----------------|-----------------|-----------------|-------------|------------|
| PCI<br>Bits | Function      |               |                       |              |                 |                 |                 |             | PB<br>Bits |
| 31-24       | ISR0_A<br>CTV | Power         | PowerSpan II Reserved |              |                 | PB_P2_<br>RETRY | PB_PB_<br>RETRY | 0           | 0-7        |
| 23-16       | PB_P1_<br>ERR | PB_P2_<br>ERR | PB_PB_<br>ERR         | PB_A_P<br>AR | PB_P1_<br>D_PAR | PB_P2_<br>D_PAR | PB_PB_<br>D_PAR | 0           | 8-15       |
| 15-08       | P2_P1_<br>ERR | P2_PB_<br>ERR | P2_P2_<br>ERR         | P2_A_<br>PAR | P2_P1_<br>RETRY | P2_PB_<br>RETRY | P2_P2_<br>RETRY | 0           | 16-23      |
| 07-00       | P1_P2_<br>ERR | P1_PB_<br>ERR | P1_P1_<br>ERR         | P1_A_P<br>AR | P1_P2_<br>RETRY | P1_PB_<br>RETRY | P1_P1_<br>RETRY | 0           | 24-31      |

#### **ISR1** Description

| Name            | Туре                  | Reset<br>By | Reset<br>State | Function                                                                                                                     |
|-----------------|-----------------------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------|
| ISR0_ACTV       | R                     | G_RST       | 0              | Indicates an interrupt status bit is set in ISR0 register.                                                                   |
| PB_P1_<br>RETRY | R/Write 1 to<br>Clear | G_RST       | 0              | Processor Bus Max Retry Error. Maximum number<br>of retries detected. The cycle was initiated/<br>destined to the PCI 1 bus. |
| PB_P2_<br>RETRY | R/Write 1 to<br>Clear | G_RST       | 0              | Processor Bus Max Retry Error. Maximum number<br>of retries detected. The cycle was initiated/<br>destined to the PCI-2 bus. |
|                 |                       |             |                | Single PCI PowerSpan II: Reserved                                                                                            |
| PB_PB_RET<br>RY | R/Write 1 to<br>Clear | G_RST       | 0              | Processor Bus Max Retry Error. Maximum number<br>of retries detected during Processor Bus to<br>Processor Bus DMA.           |
| PB_P1_ERR       | R/Write 1 to<br>Clear | G_RST       | 0              | Processor Bus interface asserted/received<br>PB_TEA The cycle was initiated/destined to the<br>PCI-1 bus.                    |

#### **ISR1** Description

|                 |                       | Reset | Reset |                                                                                                                                                                       |
|-----------------|-----------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name            | Туре                  | Ву    | State | Function                                                                                                                                                              |
| PB_P2_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus interface asserted/received<br>PB_TEA The cycle was initiated/destined to the<br>PCI-2 bus.                                                             |
|                 |                       |       |       | Single PCI PowerSpan II: Reserved                                                                                                                                     |
| PB_PB_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus interface asserted/received<br>PB_TEA_ during Processor Bus to Processor Bus<br>DMA.                                                                    |
| PB_A_PAR        | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus Address Parity Error detected.                                                                                                                          |
| PB_P1_D_PA<br>R | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus Data Parity Error detected. The cycle was initiated/destined to the PCI 1 bus.                                                                          |
| PB_P2_D_PA<br>R | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus Data Parity Error detected. The cycle was initiated/destined to the PCI-2 bus.                                                                          |
|                 |                       |       |       | Single PCI PowerSpan II: Reserved                                                                                                                                     |
| PB_PB_D_PA<br>R | R/Write 1 to<br>Clear | G_RST | 0     | Processor Bus Data Parity Error detected during<br>Processor Bus to Processor Bus DMA.                                                                                |
| P2_P1_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 interface detected an error. The P2_CSR error bits must be checked for the source of the error. The cycle was initiated/destined to the PCI 1 bus.              |
|                 |                       |       |       | Single PCI PowerSpan II: Reserved                                                                                                                                     |
| P2_PB_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 interface detected an error. The P2_CSR<br>error bits must be checked for the source of the<br>error. The cycle was initiated/destined to the<br>Processor Bus. |
|                 |                       |       |       | Single PCI PowerSpan II: Reserved                                                                                                                                     |
| P2_P2_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 interface detected an error during P2 to P2 DMA.                                                                                                                |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P2_A_PAR        | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 interface detected an address parity error.                                                                                                                     |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |

#### **ISR1** Description

|                 |                       | Reset | Reset |                                                                                                                                                                       |
|-----------------|-----------------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name            | Туре                  | Ву    | State | Function                                                                                                                                                              |
| P2_P1_<br>RETRY | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 Master received too many retries. The cycle was initiated from the PCI 1 bus.                                                                                   |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P2_PB_<br>RETRY | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 Master received too many retries. The cycle was initiated from the Processor Bus.                                                                               |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P2_P2_<br>RETRY | R/Write 1 to<br>Clear | G_RST | 0     | PCI-2 Master received too many retries during P2 to P2 DMA.                                                                                                           |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P1_P2_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 interface detected an error. The P1_CSR<br>error bits must be checked for the source of the<br>error. The cycle was initiated/destined to the PCI-2<br>bus.     |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P1_PB_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 interface detected an error. The P1_CSR<br>error bits must be checked for the source of the<br>error. The cycle was initiated/destined to the<br>Processor Bus. |
| P1_P1_ERR       | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 interface detected an error during P1 to P1 DMA.                                                                                                                |
| P1_A_PAR        | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 interface detected an address parity error.                                                                                                                     |
| P1_P2_<br>RETRY | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 Master received too many retries. The cycle was initiated from the PCI-2 bus.                                                                                   |
|                 |                       |       |       | 2P: Reserved                                                                                                                                                          |
| P1_PB_RET<br>RY | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 Master received too many retries. The cycle was initiated from the Processor Bus.                                                                               |
| P1_P1_RETR<br>Y | R/Write 1 to<br>Clear | G_RST | 0     | PCI-1 Master received too many retries during<br>PCI-1 to PCI-1 DMA.                                                                                                  |

**ISR0\_ACTV:** This bit is a logical OR of all the status bits in the ISR0 register. If any register is set, ISR0\_ACTV is set. When all bits of the ISR0 register are cleared, ISR0\_ACTV is cleared.

# 13.5.45 Interrupt Enable Register 0

Each bit, when set, allows the corresponding active status bit in ISR0 to generate an interrupt on an external pin. The external pin is determined by the Interrupt Mapping Registers and the Interrupt Direction Register.

| Table 137: | Interrupt | Enable | Register 0 |
|------------|-----------|--------|------------|
|------------|-----------|--------|------------|

| Registe     | er Name: II  | ER0              |                       |                |                |                | Regist         | er Offset:     | 0x418 |
|-------------|--------------|------------------|-----------------------|----------------|----------------|----------------|----------------|----------------|-------|
| PCI<br>Bits |              | Function         |                       |                |                |                |                |                |       |
| 31-24       |              | Span II<br>erved | I2O_HO<br>ST_MA<br>SK | I2O_IOP<br>_EN | DMA3_<br>EN    | DMA2_<br>EN    | DMA1_<br>EN    | DMA0_<br>EN    | 0-7   |
| 23-16       | P2_HW<br>_EN | P1_HW<br>_EN     | INT5_H<br>W_EN        | INT4_H<br>W_EN | INT3_H<br>W_EN | INT2_H<br>W_EN | INT1_H<br>W_EN | INT0_H<br>W_EN | 8-15  |
| 15-08       | DB7_EN       | DB6_EN           | DB5_EN                | DB4_EN         | DB3_EN         | DB2_EN         | DB1_EN         | DB0_EN         | 16-23 |
| 07-00       | MBOX7<br>_EN | MBOX6<br>_EN     | MBOX5<br>_EN          | MBOX4<br>_EN   | MBOX3<br>_EN   | MBOX2<br>_EN   | MBOX1<br>_EN   | MBOX0<br>_EN   | 24-31 |

**IER0** Description

| Name              | Туре | Reset<br>By | Reset<br>State | Function                                                           |
|-------------------|------|-------------|----------------|--------------------------------------------------------------------|
| I2O_HOST_M<br>ASK | R/W  | G_RST       | 0              | I2O_HOST interrupt mask<br>0=interrupt enabled, 1=interrupt masked |
| I2O_IOP_EN        | R/W  | G_RST       | 0              | I2O_IOP interrupt enable                                           |
| DMAx_EN           | R/W  | G_RST       | 0              | DMAx interrupt enable                                              |
| P1_HW_EN          | R/W  | G_RST       | 0              | PCI 1 hardware interrupt enable                                    |
| P2_HW_EN          | R/W  | G_RST       | 0              | PCI-2 hardware interrupt enable                                    |
|                   |      |             |                | 2P: Reserved                                                       |
| INT0_HW_EN        | R/W  | G_RST       | 0              | INT[0]_ hardware interrupt enable                                  |
| INT1_HW_EN        | R/W  | G_RST       | 0              | INT[1]_ hardware interrupt enable                                  |
| INT2_HW_EN        | R/W  | G_RST       | 0              | INT[2]_ hardware interrupt enable                                  |
| INT3_HW_EN        | R/W  | G_RST       | 0              | INT[3]_ hardware interrupt enable                                  |

| Name       | Туре              | Reset<br>By | Reset<br>State | Function                                                                        |
|------------|-------------------|-------------|----------------|---------------------------------------------------------------------------------|
| INT4_HW_EN | R/W               | G_RST       | 0              | INT[4]_ hardware interrupt enable                                               |
| INT5_HW_EN | R/W               | G_RST       | 0              | INT[5]_ hardware interrupt enable                                               |
| DBx_EN     | Write 1 to<br>set | G_RST       | 0              | Writing a one to this register sets the doorbell register in the ISR0 register. |
| MBOXx_EN   | R/W               | G_RST       | 0              | Mailbox interrupt enable                                                        |

**IER0** Description

**I2O\_HOST\_MASK:** This bit is an alias for the I2O register OPL\_IM[OP\_ISM] used to mask interrupts associated with the I2O Outbound Queue.

The Doorbell registers generate an interrupt when writing 1 to the register. This causes the corresponding doorbell bit in the ISR0 register to be set. In order to clear the doorbell interrupt, the ISR0 status bit must be cleared.

# 13.5.46 Interrupt Enable Register 1

Each bit, when set, allows the corresponding active status bit in ISR1 to generate an interrupt on an external pin. The external pin is determined by the Interrupt Mapping Registers and the Interrupt Direction Register.

| Table 138 | : Interrupt | Enable | Register 1 |
|-----------|-------------|--------|------------|
|-----------|-------------|--------|------------|

| Register Name: IER1 | Register Offset: 0x41C |
|---------------------|------------------------|
|                     |                        |

| PCI<br>Bits | Function              |                      |                      |                        |                        |                        |                        |     | PB<br>Bits |
|-------------|-----------------------|----------------------|----------------------|------------------------|------------------------|------------------------|------------------------|-----|------------|
| 31-24       | PowerSpan II Reserved |                      |                      | PB_P1_<br>RETRY_<br>EN | PB_P2_<br>RETRY_<br>EN | PB_PB_<br>RETRY_<br>EN | 0                      | 0-7 |            |
| 23-16       | PB_P1_<br>ERR_E<br>N  | PB_P2_<br>ERR_<br>EN | PB_PB_<br>ERR_E<br>N | PB_A_P<br>AR_EN        | PB_P1_<br>D_PAR_<br>EN | PB_P2_<br>D_PAR_<br>EN | PB_PB_<br>D_PAR_<br>EN | 0   | 8-15       |
| 15-08       | P2_P1_<br>ERR_<br>EN  | P2_PB_<br>ERR_<br>EN | P2_P2_<br>ERR_<br>EN | P2_A_P<br>AR_EN        | P2_P1_<br>RETRY_<br>EN | P2_PB_<br>RETRY_<br>EN | P2_P2_<br>RETRY_<br>EN | 0   | 16-23      |
| 07-00       | P1_P2_<br>ERR_<br>N   | P1_PB_<br>ERR_E<br>N | P1_P1_<br>ERR_E<br>N | P1_A_P<br>AR_EN        | P1_P2_<br>RETRY_<br>EN | P1_PB_<br>RETRY_<br>EN | P1_P1_<br>RETRY_<br>EN | 0   | 24-31      |

#### **IER1** Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function                                                                                   |
|--------------------|------|-------------|----------------|--------------------------------------------------------------------------------------------|
| PB_P1_RET<br>RY_EN | R/W  | G_RST       | 0              | Processor Bus Max Retry Counter enable. The cycle was initiated/destined to the PCI-1 bus. |
| PB_P2_<br>RETRY_EN | R/W  | G_RST       | 0              | Processor Bus Max Retry Error enable. The cycle was initiated/destined to the PCI-2 bus.   |
|                    |      |             |                | 2P: Reserved                                                                               |
| PB_PB_RET<br>RY    | R/W  | G_RST       | 0              | Processor Bus Max Retry Counter enable.<br>Processor Bus to Processor Bus DMA.             |
| PB_P1_ERR_<br>EN   | R/W  | G_RST       | 0              | Processor Bus Error Enable. The cycle was initiated/destined to the PCI-1 bus.             |
| PB_P2_ERR_<br>EN   | R/W  | G_RST       | 0              | Processor Bus Error enable. The cycle was initiated/destined to the PCI-2 bus.             |

### **IER1** Description

| Name               | Turpo | Reset | Reset<br>State | Function                                                                                   |
|--------------------|-------|-------|----------------|--------------------------------------------------------------------------------------------|
| Name               | Туре  | Ву    | State          |                                                                                            |
|                    |       | 1     |                | 2P: Reserved                                                                               |
| PB_PB_ERR<br>_EN   | R/W   | G_RST | 0              | Processor Bus Error enable. Processor Bus to<br>Processor Bus DMA.                         |
| PB_A_PAR_E<br>N    | R/W   | G_RST | 0              | Processor Bus Address Parity Error enable                                                  |
| PB_P1_D_PA<br>R_EN | R/W   | G_RST | 0              | Processor Bus Data Parity Error enable. The cycle was initiated/destined to the PCI-1 bus. |
| PB_P2_D_<br>PAR_EN | R/W   | G_RST | 0              | Processor Bus Data Parity Error enable. The cycle was initiated/destined to the PCI-2 bus. |
|                    |       |       |                | 2P: Reserved                                                                               |
| PB_PB_D_<br>PAR_EN | R/W   | G_RST | 0              | Processor Bus Data Parity Error enable. Processor<br>Bus to Processor Bus DMA.             |
| P2_P1_ERR_<br>EN   | R/W   | G_RST | 0              | PCI-2 error enable. The cycle was initiated/<br>destined to the PCI 1 bus.                 |
|                    |       |       |                | 2P: Reserved                                                                               |
| P2_PB_ERR_<br>EN   | R/W   | G_RST | 0              | PCI-2 error enable. The cycle was initiated/<br>destined to the Processor Bus.             |
|                    |       |       |                | 2P: Reserved                                                                               |
| P2_P2_ERR_<br>EN   | R/W   | G_RST | 0              | PCI-2 error enable.PCI-2 to PCI-2 DMA.                                                     |
|                    |       |       |                | 2P: Reserved                                                                               |
| P2_A_PAR_<br>EN    | R/W   | G_RST | 0              | PCI-2 address parity error enable.                                                         |
|                    |       |       |                | 2P: Reserved                                                                               |
| P2_P1_<br>RETRY_EN | R/W   | G_RST | 0              | PCI-2 max retry enable. The cycle was initiated/<br>destined to the PCI-1 bus.             |
|                    |       |       |                | 2P: Reserved                                                                               |
| P2_PB_<br>RETRY_EN | R/W   | G_RST | 0              | PCI-2 max retry enable. The cycle was initiated/<br>destined to the Processor Bus.         |
|                    |       | •<br> |                | 2P: Reserved                                                                               |

#### **IER1 Description**

| Name               | Туре | Reset<br>By | Reset<br>State | Function                                                                        |
|--------------------|------|-------------|----------------|---------------------------------------------------------------------------------|
| P2_P2_<br>RETRY_EN | R/W  | G_RST       | 0              | PCI-2 max retry enable. PCI-2 to PCI-2 DMA.                                     |
|                    |      |             |                | 2P: Reserved                                                                    |
| P1_P2_ERR_<br>EN   | R/W  | G_RST       | 0              | PCI-1 error enable. The cycle was initiated/<br>destined to the PCI-2 bus.      |
|                    |      |             |                | 2P: Reserved                                                                    |
| P1_PB_ERR_<br>EN   | R/W  | G_RST       | 0              | PCI-1 error enable. The cycle was initiated/<br>destined to the Processor Bus.  |
| P1_P1_ERR_<br>EN   | R/W  | G_RST       | 0              | PCI-1 error enable. PCI-1 to PCI-1 DMA.                                         |
| P1_A_PAR_E<br>N    | R/W  | G_RST       | 0              | PCI-1 address parity error enable.                                              |
| P1_P2_<br>RETRY_EN | R/W  | G_RST       | 0              | PCI-1 max retry enable. The cycle was initiated/<br>destined to the PCI-2 bus.  |
|                    |      |             |                | 2P: Reserved                                                                    |
| P1_PB_RET<br>RY_EN | R/W  | G_RST       | 0              | PCI-1 max retry enable. The cycle was initiated/ destined to the Processor Bus. |
| P1_P1_RETR<br>Y_EN | R/W  | G_RST       | 0              | PCI-1 max retry enable. PCI-1 to PCI-1 DMA.                                     |

# 13.5.47 Interrupt Map Register Mail Box

Each map field assigns an interrupt output pin to the corresponding interrupt source.

### Table 139: Interrupt Map Register Mail Box

| Register Name: IMR_MBOX | Register Offset: 0x420 |
|-------------------------|------------------------|
|                         | -<br>-                 |

| PCI<br>Bits | Function  |   |           |   |       |
|-------------|-----------|---|-----------|---|-------|
| 31-24       | MBOX7_MAP | 0 | MBOX6_MAP | 0 | 0-7   |
| 23-16       | MBOX5_MAP | 0 | MBOX4_MAP | 0 | 8-15  |
| 15-08       | MBOX3_MAP | 0 | MBOX2_MAP | 0 | 16-23 |
| 07-00       | MBOX1_MAP | 0 | MBOX0_MAP | 0 | 24-31 |

#### **IMR\_MBOX** Description

| Name               | Туре | Reset<br>By | Reset<br>State | Function                            |
|--------------------|------|-------------|----------------|-------------------------------------|
| MBOX7_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #7 to an interrupt pin. |
| MBOX6_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #6 to an interrupt pin. |
| MBOX5_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #5 to an interrupt pin. |
| MBOX4_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #4 to an interrupt pin. |
| MBOX3_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #3 to an interrupt pin. |
| MBOX2_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #2 to an interrupt pin. |
| MBOX1_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #1 to an interrupt pin. |
| MBOX0_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map Mailbox #0 to an interrupt pin. |

Table 140 describes the mapping of interrupt sources to the external interrupt pins. The shaded entries indicate unsupported combinations for the Single PCI PowerSpan II.

| Map Field | Interrupt Pin |
|-----------|---------------|
| 000       | P1_INTA#      |
| 001       | P2_INTA#      |
| 010       | INT[0]_       |
| 011       | INT[1]_       |
| 100       | INT[2]_       |
| 101       | INT[3]_       |
| 110       | INT[4]_       |
| 111       | INT[5_        |

### Table 140: Mapping Definition

## 13.5.48 Interrupt Map Register Doorbell

Each map field assigns an interrupt output pin to the corresponding interrupt source. Table 140 on page 399 defines the mapping definitions.

Table 141: Interrupt Map Register Doorbell

| Register Name: IMR_DB |         |      | Reg     | ister Offse | t: 0x424   |
|-----------------------|---------|------|---------|-------------|------------|
| PCI<br>Bits           |         | Fund | ction   |             | PB<br>Bits |
| 31-24                 | DB7_MAP | 0    | DB6_MAP | 0           | 0-7        |
| 23-16                 | DB5_MAP | 0    | DB4_MAP | 0           | 8-15       |
| 15-08                 | DB3_MAP | 0    | DB2_MAP | 0           | 16-23      |
| 07-00                 | DB1_MAP | 0    | DB0_MAP | 0           | 24-31      |

### IMR\_DB Description

| Name         | Туре | Reset<br>By | Reset<br>State | Function                            |
|--------------|------|-------------|----------------|-------------------------------------|
| DB7_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #7 to an interrupt pin |
| DB6_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #6 to an interrupt pin |
| DB5_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #5 to an interrupt pin |
| DB4_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #4 to an interrupt pin |
| DB3_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #3 to an interrupt pin |
| DB2_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #2 to an interrupt pin |
| DB1_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #1 to an interrupt pin |
| DB0_MAP[2:0] | R/W  | G_RST       | 0              | Map doorbell #0 to an interrupt pin |

# 13.5.49 Interrupt Map Register DMA

Each map field assigns an interrupt output pin to the corresponding interrupt source. Table 140 on page 399 defines the mapping definitions.

Table 142: Interrupt Map Register DMA

| Register Name: IMR_DMA |                         |   | Reg      | ister Offse | t: 0x428   |
|------------------------|-------------------------|---|----------|-------------|------------|
| PCI<br>Bits Function   |                         |   |          |             | PB<br>Bits |
| 31-24                  | PowerSpan II Reserved   |   |          |             | 0-7        |
| 23-16                  | B PowerSpan II Reserved |   |          |             | 8-15       |
| 15-08                  | DMA3_MAP                | 0 | DMA2_MAP | 0           | 16-23      |
| 07-00                  | DMA1_MAP                | 0 | DMA0_MAP | 0           | 24-31      |

#### IMR\_DMA\_TIMER Description

| Name          | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------|------|-------------|----------------|--------------------------------|
| DMA3_MAP[2:0] | R/W  | G_RST       | 0              | Map DMA #3 to an interrupt pin |
| DMA2_MAP[2:0] | R/W  | G_RST       | 0              | Map DMA #2 to an interrupt pin |
| DMA1_MAP[2:0] | R/W  | G_RST       | 0              | Map DMA #1 to an interrupt pin |
| DMA0_MAP[2:0] | R/W  | G_RST       | 0              | Map DMA #0 to an interrupt pin |

### 13.5.50 Interrupt Map Register Hardware

This register assigns an interrupt output pin to the corresponding interrupt source. All sources are associated with errors detected by the PCI-1 Interface.

Each map field assigns an interrupt output pin to the corresponding interrupt source. Table 140 on page 399 defines the mapping definitions

Table 143: Interrupt Map Register Hardware

| Register Name: IMR_HW |             |   | Regi        | ister Offsei | :: 0x42C   |
|-----------------------|-------------|---|-------------|--------------|------------|
| PCI<br>Bits           | Function    |   |             |              | PB<br>Bits |
| 31-24                 | P2_HW_MAP   | 0 | P1_HW_MAP   | 0            | 0-7        |
| 23-16                 | INT5_HW_MAP | 0 | INT4_HW_MAP | 0            | 8-15       |
| 15-08                 | INT3_HW_MAP | 0 | INT2_HW_MAP | 0            | 16-23      |
| 07-00                 | INT1_HW_MAP | 0 | INT0_HW_MAP | 0            | 24-31      |

#### **IMR\_MISC** Description

| Name             | Туре | Reset<br>By  | Reset<br>State | Function                                              |
|------------------|------|--------------|----------------|-------------------------------------------------------|
| P1_HW_MAP[2:0]   | R/W  | G_RST        | 0              | Map PCI-1 hardware interrupt to an interrupt pin      |
| P2_HW_MAP[2:0]   | R/W  | G_RST        | 0              | Map PCI-2 hardware interrupt to an interrupt pin      |
|                  |      | 2P: Reserved |                |                                                       |
| INT5_HW_MAP[2:0] | R/W  | G_RST        | 0              | Map INT[5]_ hardware interrupt to an<br>interrupt pin |
| INT4_HW_MAP[2:0] | R/W  | G_RST        | 0              | Map INT[4]_ hardware interrupt to an<br>interrupt pin |
| INT3_HW_MAP[2:0] | R/W  | G_RST        | 0              | Map INT[3]_ hardware interrupt to an<br>interrupt pin |
| INT2_HW_MAP[2:0] | R/W  | G_RST        | 0              | Map INT[2]_ hardware interrupt to an<br>interrupt pin |

### IMR\_MISC Description

| Name             | Туре | Reset<br>By | Reset<br>State | Function                                              |
|------------------|------|-------------|----------------|-------------------------------------------------------|
| INT1_HW_MAP[2:0] | R/W  | G_RST       | 0              | Map INT[1]_ hardware interrupt to an<br>interrupt pin |
| INT0_HW_MAP[2:0] | R/W  | G_RST       | 0              | Map INT[0]_ hardware interrupt to an<br>interrupt pin |

## 13.5.51 Interrupt Map Register PCI-1

Each map field assigns an interrupt output pin to the corresponding interrupt source. Table 140 on page 399 defines the mapping definitions.

Table 144: Interrupt Map Register PCI 1

| Registe     | r Name: IMR_P1  |   | Reg                   | ister Offse | t: 0x430 |
|-------------|-----------------|---|-----------------------|-------------|----------|
| PCI<br>Bits | Function        |   |                       |             |          |
| 31-24       | P1_P2_ERR_MAP   | 0 | P1_PB_ERR_MAP         | 0           | 0-7      |
| 23-16       | P1_P1_ERR_MAP   | 0 | P1_A_PAR_MAP          | 0           | 8-15     |
| 15-08       | P1_P2_RETRY_MAP | 0 | P1_PB_RETRY_MAP       | 0           | 16-23    |
| 07-00       | P1_P1_RETRY_MAP |   | PowerSpan II Reserved |             |          |

### IMR\_P1 Description

| Name                     | Туре | Reset<br>By | Reset<br>State | Function                                                              |
|--------------------------|------|-------------|----------------|-----------------------------------------------------------------------|
| P1_P2_ERR_MAP<br>[2:0]   | R/W  | G_RST       | 0              | Map PCI-1 errors to an interrupt pin                                  |
|                          |      | _           | _              | 2P: Reserved                                                          |
| P1_PB_ERR_MAP<br>[2:0]   | R/W  | G_RST       | 0              | Map PCI-1 errors to an interrupt pin                                  |
| P1_P1_ERR_MAP<br>[2:0]   | R/W  | G_RST       | 0              | Map PCI-1 errors to an interrupt pin. PCI-1 to PCI-1 DMA.             |
| P1_A_PAR_MAP<br>[2:0]    | R/W  | G_RST       | 0              | Map PCI-11 address parity errors to an interrupt pin                  |
| P1_P2_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-1 max retry error to an interrupt pin                         |
|                          |      |             |                | 2P: Reserved                                                          |
| P1_PB_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-1 max retry error to an interrupt pin                         |
| P1_P1_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-1 max retry error to an interrupt pin.<br>PCI-1 to PCI-1 DMA. |

# 13.5.52 Interrupt Map Register PCI-2

This register assigns an interrupt output pin to the corresponding interrupt source. All sources are associated with errors detected by the PCI-2 Interface. Table 140 on page 399 defines the mapping definitions.

This register is not implemented in the Single PCI PowerSpan II and must be treated as reserved.

| Register Name: IMR_P2 |                 |   | R                     | egister Off | set: 434 |  |
|-----------------------|-----------------|---|-----------------------|-------------|----------|--|
| PCI<br>Bits           |                 |   |                       |             |          |  |
| 31-24                 | P2_P1_ERR_MAP   | 0 | P2_PB_ERR_MAP         | 0           | 0-7      |  |
| 23-16                 | P2_P2_ERR_MAP   | 0 | P2_A_PAR_MAP          | 0           | 8-15     |  |
| 15-08                 | P2_P1_RETRY_MAP | 0 | P2_PB_RETRY_MAP       | 0           | 16-23    |  |
| 07-00                 | P2_P2_RETRY_MAP |   | PowerSpan II Reserved |             | 24-31    |  |

### Table 145: Interrupt Map Register PCI-2

#### **IMR\_P2** Description

| Name                 | Туре | Reset<br>By | Reset<br>State | Function                                                           |
|----------------------|------|-------------|----------------|--------------------------------------------------------------------|
| P2_P1_ERR[2:0]       | R/W  | G_RST       | 0              | Map PCI-2 errors to an interrupt pin                               |
| P2_PB_ERR[2:0]       | R/W  | G_RST       | 0              | Map PCI-2 errors to an interrupt pin                               |
| P2_P2_ERR_MAP[2:0]   | R/W  | G_RST       | 0              | Map PCI-2 errors to an interrupt pin.<br>PCI-2 to PCI-2 DMA.       |
| P2_A_PAR_MAP[2:0]    | R/W  | G_RST       | 0              | Map PCI-2 address parity errors to an<br>interrupt pin             |
| P2_P1_RETRY_MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-2 max retry error to an<br>interrupt pin                   |
| P2_PB_RETRY_MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-2 max retry error to an<br>interrupt pin                   |
| P2_P2_RETRY_MAP[2:0] | R/W  | G_RST       | 0              | Map PCI-2 max retry error to an interrupt pin. PCI-2 to PCI-2 DMA. |

### 13.5.53 Interrupt Map Register Processor Bus

This register assigns an interrupt output pin to the corresponding interrupt source. All sources are associated with errors detected by the Processor Bus Interface. Table 140 on page 399 defines the mapping definitions.

### Table 146: Interrupt Map Register Processor Bus

| Registe     | r Name: IMR_PB  |                       | Reg             | ister Offse | t: 0x438 |  |
|-------------|-----------------|-----------------------|-----------------|-------------|----------|--|
| PCI<br>Bits |                 |                       |                 |             |          |  |
| 31-24       | PB_P1_ERR_MAP   | 0                     | PB_P2_ERR_MAP   | 0           | 0-7      |  |
| 23-16       | PB_PB_ERR_MAP   | 0                     | PB_A_PAR_MAP    | 0           | 8-15     |  |
| 15-08       | PB_P1_D_PAR_MAP | 0                     | PB_P2_D_PAR_MAP | 0           | 16-23    |  |
| 07-00       | PB_PB_D_PAR_MAP | PowerSpan II Reserved |                 |             | 24-31    |  |

#### **IMR\_PB** Description

| Name                 | Туре | Reset<br>By  | Reset<br>State | Function                                                                               |
|----------------------|------|--------------|----------------|----------------------------------------------------------------------------------------|
| PB_P1_ERR_MAP[2:0]   | R/W  | G_RST        | 0              | Map Processor Bus error to an<br>interrupt pin                                         |
| PB_P2_ERR_MAP[2:0]   | R/W  | G_RST        | 0              | Map Processor Bus error to an<br>interrupt pin                                         |
|                      |      | 2P: Reserved |                |                                                                                        |
| PB_PB_ERR_MAP[2:0]   | R/W  | G_RST        | 0              | Map Processor Bus error to an<br>interrupt pin. Processor Bus to<br>Processor Bus DMA. |
| PB_A_PAR_MAP[2:0]    | R/W  | G_RST        | 0              | Map Processor Bus address parity error to an interrupt pin                             |
| PB_P1_D_PAR_MAP[2:0] | R/W  | G_RST        | 0              | Map Processor Bus data parity error to<br>an interrupt pin                             |
| PB_P2_D_PAR_MAP[2:0] | R/W  | G_RST        | 0              | Map Processor Bus data parity error to<br>an interrupt pin                             |

#### **IMR\_PB** Description

| Name                 | Туре | Reset<br>By | Reset<br>State | Function                                                                                           |
|----------------------|------|-------------|----------------|----------------------------------------------------------------------------------------------------|
|                      |      | -           |                | 2P: Reserved                                                                                       |
| PB_PB_D_PAR_MAP[2:0] | R/W  | G_RST       | 0              | Map Processor Bus data parity error to<br>an interrupt pin. Processor Bus to<br>Processor Bus DMA. |

### 13.5.54 Interrupt Map Register Two Processor Bus

This register maps Processor Bus maximum retry errors to interrupt pins. Max retry errors that are mapped include PCI-1, PCI-2 and Processor Bus.

| Register Name: IMR2_PB |                          |                       | Regi | ster Offset | :: 0x43C |  |
|------------------------|--------------------------|-----------------------|------|-------------|----------|--|
| PCI<br>Bits            | Function                 |                       |      |             |          |  |
| 31-24                  | PB_P1_RETRY_MAP          | 0 PB_P2_RETRY_MAP 0   |      |             |          |  |
| 23-16                  | PB_PB_RETRY_MAP          | PowerSpan II Reserved |      |             |          |  |
| 15-08                  | PowerSpan II Reserved    |                       |      |             |          |  |
| 07-00                  | 00 PowerSpan II Reserved |                       |      |             |          |  |

| Name                     | Туре | Reset<br>By | Reset<br>State | Function                                                                                          |
|--------------------------|------|-------------|----------------|---------------------------------------------------------------------------------------------------|
| PB_P1_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map Processor Bus max retry errors to an interrupt pin                                            |
| PB_P2_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map Processor Bus max retry errors to an<br>interrupt pin                                         |
|                          |      |             |                | Single PCI PowerSpan II Reserved                                                                  |
| PB_PB_RETRY_<br>MAP[2:0] | R/W  | G_RST       | 0              | Map Processor Bus max retry errors to an<br>interrupt pin. Processor Bus to Processor Bus<br>DMA. |

### 13.5.55 Interrupt Map Register Miscellaneous

Each map field assigns an interrupt output pin to the corresponding interrupt source. Table 140 on page 399 defines the mapping definitions.

| Register Name: IMR_MISC |                       |          | Reg          | ister Offse | et: 0x440 |
|-------------------------|-----------------------|----------|--------------|-------------|-----------|
| PCI<br>Bits             | Function              |          |              |             |           |
| 31-24                   | I2O_IOP_MAP           | 0        | I2O_HOST_MAP | 0           | 0-7       |
| 23-16                   | PowerSpan II Reserved |          |              |             |           |
| 15-08                   | PowerSpan II Reserved |          |              |             | 16-23     |
| 07-00                   | P                     | owerSpan | II Reserved  |             | 24-31     |

**IMR\_MISC** Description

| Name                  | Туре | Reset<br>By | Reset<br>State | Function                                   |
|-----------------------|------|-------------|----------------|--------------------------------------------|
| I2O_HOST_MAP<br>[2:0] | R/W  | G_RST       | 0              | Map I2O Host interrupt to an interrupt pin |
| I2O_IOP_MAP[2:0]      | R/W  | G_RST       | 0              | Map I2O IOP interrupt to an interrupt pin  |

**I2O\_HOST\_MAP:** This field must be configured to route the interrupt source to the interrupt pin on PowerSpan II's Primary PCI Interface

## 13.5.56 Interrupt Direction Register

This register controls the direction of the corresponding interrupt pin. The direction can be to be an input or output.

Table 149: Interrupt Direction Register

| Registe     | er Name: II           | DR            |                 |                 |                 |                 | Reg             | ister Offse     | t: 0x444 |
|-------------|-----------------------|---------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|
| PCI<br>Bits | Function              |               |                 |                 |                 |                 |                 | PB<br>Bits      |          |
| 31-24       | P2_HW<br>_DIR         | P1_HW<br>_DIR | INT5_H<br>W_DIR | INT4_H<br>W_DIR | INT3_H<br>W_DIR | INT2_H<br>W_DIR | INT1_H<br>W_DIR | INT0_H<br>W_DIR | 0-7      |
| 23-16       | PowerSpan II Reserved |               |                 |                 |                 |                 |                 | 8-15            |          |
| 15-08       | PowerSpan II Reserved |               |                 |                 |                 |                 | 16-23           |                 |          |
| 07-00       |                       |               | F               | PowerSpan       | II Reserve      | d               |                 |                 | 24-31    |

### **IDR Description**

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                               |
|-------------|------|-------------|----------------|--------------------------------------------------------|
| P2_HW_DIR   | R/W  | G_RST       | 0<br>EEPROM    | P2_INTA _ Direction<br>0 = Input<br>1 = Output         |
|             |      |             |                | 2P: Reserved                                           |
| P1_HW_DIR   | R/W  | G_RST       | 0<br>EEPROM    | P1_INTA_ Direction<br>0 = Input<br>1 = Output          |
| INT5_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[5]_ Interrupt Direction<br>0 = Input<br>1 = Output |
| INT4_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[4]_ Interrupt Direction<br>0 = Input<br>1 = Output |
| INT3_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[3]_ Interrupt Direction<br>0 = Input<br>1 = Output |

### **IDR Description**

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                               |
|-------------|------|-------------|----------------|--------------------------------------------------------|
| INT2_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[2]_ Interrupt Direction<br>0 = Input<br>1 = Output |
| INT1_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[1]_ Interrupt Direction<br>0 = Input<br>1 = Output |
| INT0_HW_DIR | R/W  | G_RST       | 0<br>EEPROM    | INT[0]_ Interrupt Direction<br>0 = Input<br>1 = Output |

### 13.5.57 Mailbox x Register

This register is the General Purpose Mailbox register. When interrupts are enabled in the IER0 register, writes to any byte of this register cause an interrupt. The interrupt can be mapped to any of PowerSpan II's interrupt pins. This mapping is set in the IMR\_MBOX register.

### Table 150: Mailbox x Register

| Register Name: MBOXx |       | Register Offset: 0x450, 0x454, 0x458<br>0x460, 0x464, 0x468 |            |  |
|----------------------|-------|-------------------------------------------------------------|------------|--|
| PCI<br>Bits          | Fund  | ction                                                       | PB<br>Bits |  |
| 31-24                | MB    | MBOXx                                                       |            |  |
| 23-16                | MBOXx |                                                             |            |  |
| 15-08                | MBOXx |                                                             |            |  |
| 07-00                | MBOXx |                                                             |            |  |

#### **MBOXx** Description

| Name            | Туре | Reset<br>By | Reset<br>State | Function  |
|-----------------|------|-------------|----------------|-----------|
| MBOXx<br>[31:0] | R/W  | G_RST       | 0              | Mailbox x |

## 13.5.58 Semaphore 0 Register

When a SEMx is 0, this semaphore can be obtained by writing a 1 to the SEMx bit with a unique tag TAGx. If on a subsequent read, the SEMx bit is set and the TAGx field contains the same unique tag, then the semaphore has been obtained successfully.

To release a semaphore, write a 0 to the SEMx bit and the same tag that was used to obtain the semaphore. If the tag is different from the tag that is in the register, then the write will have no effect.

Access to a single semaphore in this register requires a byte-wide transaction.

Table 151: Semaphore 0 Register

| Registe     | r Name: Sl | EMA0      |      | Register Offset | : 0x470    |
|-------------|------------|-----------|------|-----------------|------------|
| PCI<br>Bits | Function   |           |      |                 | PB<br>Bits |
| 31-24       | SEM3       |           | TAG3 |                 | 0-7        |
| 23-16       | SEM2       |           | TAG2 |                 | 8-15       |
| 15-08       | SEM1       |           | TAG1 |                 | 16-23      |
| 07-00       | SEM0       | SEM0 TAG0 |      |                 |            |

#### **SEMA0** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function    |
|-----------|------|-------------|----------------|-------------|
| SEM3      | R/W  | G_RST       | 0              | Semaphore 3 |
| TAG3[6:0] | R/W  | G_RST       | 0              | Tag 3       |
| SEM2      | R/W  | G_RST       | 0              | Semaphore 2 |
| TAG2[6:0] | R/W  | G_RST       | 0              | Tag 2       |
| SEM1      | R/W  | G_RST       | 0              | Semaphore 1 |
| TAG1[6:0] | R/W  | G_RST       | 0              | Tag 1       |
| SEM0      | R/W  | G_RST       | 0              | Semaphore 0 |
| TAG0[6:0] | R/W  | G_RST       | 0              | Tag 0       |

# 13.5.59 Semaphore 1 Register

If a SEMx is 0, this semaphore can be obtained by writing a 1 to the SEMx bit with a unique tag TAGx. If on a subsequent read, the SEMx bit is set and the TAGx field contains the same unique tag, then the semaphore has been obtained successfully.

To release a semaphore, write a 0 to the SEMx bit and the same tag that was used to obtain the semaphore. If the tag is different from the tag that is in the register, then the write will have no effect.

Access to a single semaphore in this register requires a byte-wide transaction.

Table 152: Semaphore 1 Register

| Registe     | r Name: SI | EMA1 |       | Register Offset | :: 0x474   |
|-------------|------------|------|-------|-----------------|------------|
| PCI<br>Bits |            | Fund | ction |                 | PB<br>Bits |
| 31-24       | SEM7       |      | TAG7  |                 | 0-7        |
| 23-16       | SEM6       |      | TAG6  |                 | 8-15       |
| 15-08       | SEM5       |      | TAG5  |                 | 16-23      |
| 07-00       | SEM4       |      | TAG4  |                 | 24-31      |

#### **SEMA1** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function    |
|-----------|------|-------------|----------------|-------------|
| SEM7      | R/W  | G_RST       | 0              | Semaphore 7 |
| TAG7[6:0] | R/W  | G_RST       | 0              | Tag 7       |
| SEM6      | R/W  | G_RST       | 0              | Semaphore 6 |
| TAG6[6:0] | R/W  | G_RST       | 0              | Tag 6       |
| SEM5      | R/W  | G_RST       | 0              | Semaphore 5 |
| TAG5[6:0] | R/W  | G_RST       | 0              | Tag 5       |
| SEM4      | R/W  | G_RST       | 0              | Semaphore 4 |
| TAG4[6:0] | R/W  | G_RST       | 0              | Tag 4       |

# 13.5.60 PCI I2O Target Image Control Register

This register contains the control information for the PowerSpan II PCI I<sup>2</sup>O Target Image. The lower 4 Kbytes of the image provide the I<sup>2</sup>O Shell Interface - Inbound and Outbound Queues and the Host Interrupt Status and Mask Registers. I<sup>2</sup>O Message Frames are accessible above the 4-KByte boundary. The Queues and the Message Frames reside in memory connected to the processor bus.

All PCI transactions claimed by the image are destined for the Processor Bus.

| Table 153: PCI I2O Table 153: PC | arget Image Control Register |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|

END

| Register Name: PCI_TI2O_CTL |                       |       |        |      |       |     | Register Offset | :: 0x500   |
|-----------------------------|-----------------------|-------|--------|------|-------|-----|-----------------|------------|
| PCI<br>Bits                 |                       |       |        | Fund | ction |     |                 | PB<br>Bits |
| 31-24                       | IMG_EN                | TA_EN | BAR_EN | 0    | 0 BS  |     |                 |            |
| 23-16                       | PowerSpan II Reserved |       |        |      |       | RTT |                 | 8-15       |
| 15-08                       | GBL                   | CI    | 0      | WTT  |       |     |                 | 16-23      |

0

MRA

### PCI\_TI2O\_CTL Description

PRKEE

Ρ

07-00

| Name    | Туре | Reset<br>By | Reset<br>State | Function                                                      |
|---------|------|-------------|----------------|---------------------------------------------------------------|
| IMG_EN  | R/W  | PRI_RST     | 0              | Image Enable<br>0 = Disable<br>1 = Enable                     |
| TA_EN   | R/W  | PRI_RST     | 0              | Translation Address Enable<br>0 = Disable<br>1 = Enable       |
| BAR_EN  | R/W  | PRI_RST     | 0<br>EEPROM    | PCI Base Address Register Enable<br>0 = Disable<br>1 = Enable |
| BS[3:0] | R/W  | PRI_RST     | 0<br>EEPROM    | Block Size<br>(64 Kbyte * 2 <sup>BS</sup> )                   |

24-31

RD\_AMT

PCI\_TI2O\_CTL Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                                            |
|-------------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| RTT[4:0]    | R/W  | PRI_RST     | 0b01010        | Processor Bus Read Transaction Type<br>(PB_TT[0:4])<br>01010 = Read                                                                                 |
| GBL         | R/W  | PRI_RST     | 0              | Global<br>0=Assert PB_GBL_<br>1=Negate PB_GBL_                                                                                                      |
| CI          | R/W  | PRI_RST     | 0              | Cache Inhibit<br>0=Assert PB_CI_<br>1=Negate PB_CI_                                                                                                 |
| WTT[4:0]    | R/W  | PRI_RST     | 0b00010        | Processor Bus Write Transaction Type<br>(PB_TT[0:4])<br>00010=Write with flush                                                                      |
| PRKEEP      | R/W  | PRI_RST     | 0              | Prefetch Read Keep Data<br>0 = Disable<br>1 = Enable                                                                                                |
| END[1:0]    | R/W  | PRI_RST     | 10b            | Endian Conversion Mode<br>00 = Little-endian<br>01 = PowerPC little-endian<br>10 = Big-endian<br>11 = True little-endian                            |
| MRA         | R/W  | PRI_RST     | 0              | PCI Memory Read Alias to MRM<br>0 = Disabled<br>1 = Enabled                                                                                         |
| RD_AMT[2:0] | R/W  | PRI_RST     | 0              | Prefetch Size<br>Specifies the number of bytes the device will<br>prefetch for PCI Memory Read Multiple<br>transactions claimed by the target image |

The following parameters do not affect Processor Bus transactions generated by  $I_2O$  Shell accesses:

• TA\_EN

no address translation for  $\mathrm{I}^{2}\mathrm{O}$  Shell accesses

PRKEEP

no read keep for I<sup>2</sup>O Shell accesses

- END
- RD\_AMT

prefetch amount fixed at 8 bytes for I<sup>2</sup>O Shell accesses

**IMG\_EN:** The Image Enable bit can be changed with the following actions:

- initial write to Px\_BSI2O[BA]
- register write to IMG\_EN

The image enable is cleared by writing a zero to IMG\_EN or writing zero to the Px\_BSI2O[BA] field. This effectively disables I2O functionality.

**TA\_EN:** When set, the Translation Address (TADDR[15:0]) field, in the PCI\_TI2O\_TADDR replaces the upper bits of the PCI bus address. The new address is used on the Processor Bus. Clearing the enable will result in no address translation.

**BAR\_EN:** When this bit is enabled the Px\_BSI2O register is Read/Write. When this bit is disabled the Px\_BSI2O register is not visible and read zero only. Writes to Px\_BSI2O have no effect when this bit is cleared. This bit must be enabled for PCI BIOS configuration in order to map PowerSpan II PCI I<sup>2</sup>O Target Image into memory space.

The Image is enabled for decode when IMG\_EN and BAR\_EN are set.

**MRA:** When set, the PCI I2O Target Image will alias a PCI Memory Read cycle to a PCI Memory Read Multiple cycle and prefetches the number of bytes specified in the RD\_AMT[2:0] field. When MRA is the Target Image prefetches 8 bytes when a PCI Memory Read cycle is decoded and claimed.

**BS:** The Block Size specifies the size of the image, address lines compared and address lines translated.

| BS[3:0] | Block Size | Address Lines Compared/Translated |
|---------|------------|-----------------------------------|
| 0000    | 64k        | AD31-AD16                         |
| 0001    | 128K       | AD31-AD17                         |
| 0010    | 256K       | AD31-AD18                         |

#### Table 154: Block Size

| BS[3:0]     | Block Size | Address Lines Compared/Translated |
|-------------|------------|-----------------------------------|
| 0011        | 512K       | AD31-AD19                         |
| 0100        | 1M         | AD31-AD20                         |
| 0101        | 2M         | AD31-AD21                         |
| 0110        | 4M         | AD31-AD22                         |
| 0111        | 8M         | AD31-AD23                         |
| 1000        | 16M        | AD31-AD24                         |
| 1001        | 32M        | AD31-AD25                         |
| 1010        | 64M        | AD31-AD26                         |
| 1011        | 128M       | AD31-AD27                         |
| 1100        | 256M       | AD31-AD28                         |
| 1101        | 512M       | AD31-AD29                         |
| 1110        | 1G         | AD31-AD30                         |
| 1111        | 2G         | AD31                              |
| 10100-11111 | Reserved   | Reserved                          |

Table 154: Block Size

**END:** This selects the endian conversion mode.

**PRKEEP:** This bit is used to hold read data is fetched beyond the initial PCI read cycle. When set, subsequent read requests to the same image at the next address retrieves the read data directly from the switching fabric instead of causing the destination bus to fetch more data. The read data is invalidated when a read with a non-matching address occurs.

**RD\_AMT[2:0]:** The read amount setting determines different values to prefetch from the destination bus.

| RD_AMT[2:0] | Data Fetched |
|-------------|--------------|
| 000         | 8bytes       |
| 001         | 16 bytes     |
| 010         | 32 bytes     |

Table 155: Read Amount

| RD_AMT[2:0] | Data Fetched |
|-------------|--------------|
| 011         | 64 bytes     |
| 100         | 128 bytes    |
| 101-111     | Reserved     |

# 13.5.61 PCI I2O Target Image Translation Address Register

Address translation does not occur for I<sup>2</sup>O Shell Interface accesses.

### Table 156: PCI I2O Target Image Translation Address Register

| Registe     | r Name: PCI_TI2O_TADDR | Register Offset: 0    | x504       |  |  |  |
|-------------|------------------------|-----------------------|------------|--|--|--|
| PCI<br>Bits | Fund                   |                       | PB<br>Bits |  |  |  |
| 31-24       | TAI                    | DDR                   | 0-7        |  |  |  |
| 23-16       | TADDR                  |                       |            |  |  |  |
| 15-08       | PowerSpan II Reserved  |                       |            |  |  |  |
| 07-00       | PowerSpan              | PowerSpan II Reserved |            |  |  |  |

#### PCI\_TI2O\_TADDR Description

| Name        | Туре | Reset<br>By | Reset<br>State | Function                                   |
|-------------|------|-------------|----------------|--------------------------------------------|
| TADDR[15:0] | R/W  | PRI_RST     | 0              | Translation Address (through substitution) |

TADDR[15:0]: When the TA\_EN bit, in the PCI\_TI2O\_CTL register, is set TADDR[15:0] replaces the PCI bus upper address bits, up to the size of the image.

# 13.5.62 I2O Control and Status Register

### Table 157: I2O Control and Status Register

| Registe     | r Name: I2O_CSR       |      |     | Reg | ister Offse              | t: 0x508            |       |  |
|-------------|-----------------------|------|-----|-----|--------------------------|---------------------|-------|--|
| PCI<br>Bits | Function              |      |     |     |                          |                     |       |  |
| 31-24       | PowerSpan II Reserved |      |     |     |                          |                     |       |  |
| 23-16       | PowerSpan II Reserved |      |     |     |                          |                     |       |  |
| 15-08       | PowerSpan II Reserved |      |     |     |                          |                     |       |  |
| 07-00       | HOPL_SIZE             | EMTR | OFL | IPL | XI <sub>2</sub> O_<br>EN | I <sub>2</sub> O_EN | 24-31 |  |

#### I2O\_CSR Description

| Name                 | Туре | Reset<br>By | Reset<br>State | Function                                                                                                                    |
|----------------------|------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------|
| HOPL_SIZE<br>[2:0]   | R/W  | PRI_RST     | 0              | Host Outbound Post List Size                                                                                                |
| EMTR                 | R/W  | PRI_RST     | 0              | Empty FIFO Read Response<br>0 = return pointer on read when FIFO empty<br>1 = return 0xFFFF_FFFF on read when FIFO<br>empty |
| OFL                  | R    | PRI_RST     | 0              | Outbound Free List<br>0 = empty<br>1 = not empty                                                                            |
| IPL                  | R    | PRI_RST     | 0              | Inbound Post List<br>0 = empty<br>1 = not empty                                                                             |
| XI <sub>2</sub> O_EN | R/W  | PRI_RST     | 0              | Extended MFA Enabled                                                                                                        |
| I <sub>2</sub> O_EN  | R/W  | PRI_RST     | 0              | I <sub>2</sub> O Enabled<br>0 = I2O disabled<br>1 = I2O enabled                                                             |

**HOPL\_SIZE:** This field specifies the size of the Host Outbound Post List circular FIFO in the Host memory. The IOP must program this field when PowerSpan II

extended Outbound Option support is enabled.

| HOPL_SIZE<br>[2:0] | Max No. of MFAs<br>per FIFO | Memory<br>Required per<br>FIFO<br>(Kbytes) | PowerSpan II IOP<br>Host Outbound<br>Index Register bits<br>incremented |
|--------------------|-----------------------------|--------------------------------------------|-------------------------------------------------------------------------|
| 000<br>001         | 256                         | 1                                          | IOP_OI [9:2]                                                            |
| 010                | 1K                          | 4                                          | IOP_OI [11:2]                                                           |
| 100                | 4K                          | 16                                         | IOP_OI [13:2]                                                           |

 Table 158: Host Outbound Post List Size

**EMTR:** The Empty FIFO Read Response bit determines the PowerSpan II response to an IOP read of the Inbound Post List Bottom Pointer Register or the Outbound Free List Bottom Pointer Register. If the EMTR bit is set, a read from either of these registers when their corresponding FIFO is empty will return 0xffff\_ffff as read data to the IOP. If the bit is not set, the contents of the corresponding Pointer Register will be returned as read data.

**OFL:** Indicates status of the Outbound Free List FIFO. If this bit is set, at least one Outbound Message Frame is available in Host memory.

**IPL:** Indicates status of the Inbound Post List FIFO. If this bit is set, there are Inbound Message Frames for the IOP to process.

**XI2O\_EN:** The IOP programs this bit to enable the PowerSpan II I<sup>2</sup>O Extended Capabilities support for the Outbound Option. The Host Outbound Index Offset Register needs to be programmed with the offset in the PCI I2O target Image where the Host Outbound Index Register can be located for the Outbound Option Support. This can be accomplished through the Host Outbound Index Alias register.

The IOP will need to program the following registers to support I<sup>2</sup>O extended capabilities:

- I2O IOP Outbound Index register
- I2O Host Outbound Index Offset register
- I2O Host Outbound Index Alias register

I2O\_EN: The local processor sets this bit to enable the PowerSpan II I2O Shell Interface support. The IOP must initialize the I2O Inbound Free list and Post list FIFO's before enabling the PowerSpan II I<sup>2</sup>O Shell Interface. When this bit is cleared, all Px\_BSI2O accesses on Primary PCI are retried.

### 13.5.63 I2O Queue Base Address Register

This register specifies the location and size of the Inbound and Outbound Queues in processor memory space. The IOP must program this register before enabling the PowerSpan II I2O Shell Interface.

### Table 159: I2O Queue Base Address Register

| Registe     | r Name: I2O_QUEUE_BS  |   | Register Offse        | t: 0x50C |
|-------------|-----------------------|---|-----------------------|----------|
| PCI<br>Bits |                       |   |                       |          |
| 31-24       | PB_I2O_BS             |   |                       | 0-7      |
| 23-16       | PB_I2O_BS             | F | PowerSpan II Reserved | 8-15     |
| 15-08       | PowerSpan II Reserved |   |                       | 16-23    |
| 07-00       | PowerSpan II Reserved |   | FIFO_SIZE             | 24-31    |

### I2O\_QUEUE\_BS Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------------|------|-------------|----------------|--------------------------------|
| PB_I2O_BS<br>[11:0] | R/W  | PRI_RST     | 0              | Processor Bus I2O Base Address |
| FIFO_SIZE<br>[2:0]  | R/W  | PRI_RST     | 0              | FIFO Size                      |

**PB\_I2O\_BS:** The PB\_I2O\_BS field specifies the base address of the 1 MB block of embedded PowerPC memory that contains the four FIFOs (Inbound Free List, Inbound Post List, Outbound Free List, Outbound Post List). The four FIFOs are of equal size, but do not need to be in contiguous memory locations. The PB\_I2O\_BS field is aliased in the most significant 12 bits of each of the PowerSpan II I<sup>2</sup>O Bottom and Top Pointer Registers.

**FIFO\_SIZE:** This field specifies the size of the circular FIFOs in the IOP local memory. Total FIFO memory allocation is four times the single FIFO size.

### Table 160: I2O FIFO Sizes

| FIFO_SIZE [2:0] | Max No. of MFAs per<br>FIFO | Memory Required per<br>FIFO (Kbytes) | PowerSpan II I2O<br>Pointer bits<br>incremented |
|-----------------|-----------------------------|--------------------------------------|-------------------------------------------------|
| 000             | 256                         | 1                                    | I2O_PTR [9:2]                                   |
| 001             | 1K                          | 4                                    | I2O_PTR [11:2]                                  |
| 010             | 4K                          | 16                                   | I2O_PTR [13:2]                                  |
| 011             | 16K                         | 64                                   | I2O_PTR [15:2]                                  |
| 100             | 64K                         | 256                                  | I2O_PTR [17:2]                                  |

I2O\_PTR is one of the following:

- IFL\_BOT
- IFL\_TOP
- IPL\_BOT
- IPL\_TOP
- OFL\_BOT
- OFL\_TOP
- OPL\_BOT
- OPL\_TOP

# 13.5.64 I2O Inbound Free List Bottom Pointer Register

### Table 161: I2O Inbound Free List Bottom Pointer Register

| Registe     | r Name: IFL_BOT |  | Regi | ster Offset | :: 0x510 |
|-------------|-----------------|--|------|-------------|----------|
| PCI<br>Bits | Function        |  |      |             |          |
| 31-24       | PB_I2O_BS       |  |      |             |          |
| 23-16       | PB_I2O_BS BOT   |  |      |             |          |
| 15-08       | вот             |  |      |             | 16-23    |
| 07-00       | BOT 0 0         |  |      | 0           | 24-31    |

**IFL\_BOT Description** 

| Name                | Туре | Reset<br>By | Reset<br>State | Function                         |
|---------------------|------|-------------|----------------|----------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address   |
| BOT [17:0]          | R/W  | PRI_RST     | 0              | Inbound Free List Bottom Pointer |

**BOT:** This pointer gives the address offset for the Inbound Free List Bottom Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and maintained by PowerSpan II. This pointer is incremented by four for each PCI read from the Inbound Queue.



If the initial values of the Inbound Free List Bottom and Top pointers are the same, the inbound free list is empty. The user can program the Top pointer to be four less than the Bottom pointer and then write to the INCR bit in the IFL\_TOP\_INC register to make the inbound free list full.

# 13.5.65 I2O Inbound Free List Top Pointer Register

Table 162: I2O Inbound Free List Top Pointer Register

| Registe     | r Name: IFL_TOP |       | Regi | ster Offset | : 0x514    |
|-------------|-----------------|-------|------|-------------|------------|
| PCI<br>Bits | Fun             | ction |      |             | PB<br>Bits |
| 31-24       | PB_I2O_BS       |       |      |             |            |
| 23-16       | PB_I2O_BS TOP   |       |      |             |            |
| 15-08       | ТОР             |       |      |             | 16-23      |
| 07-00       | TOP 0 0         |       |      | 24-31       |            |

### **IFL\_TOP Description**

| Name                | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------------|------|-------------|----------------|--------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address |
| TOP [17:0]          | R/W  | PRI_RST     | 0              | Inbound Free List Top Pointer  |

**TOP:** This pointer gives the address offset for the Inbound Free List Top Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and can be incremented by four by writing a 1 to the INCR bit in the IFL\_TOP\_INC register.



If the initial values of the Inbound Free List Bottom and Top pointers are the same, the inbound free list is empty. The user can program the Top pointer to be four less than the Bottom pointer and then set the INCR bit in the IFL\_TOP\_INC register to make the inbound free list full.

# 13.5.66 Inbound Free List Top Pointer Increment Register

### Table 163: I2O Inbound Free List Top Pointer Increment Register

| Registe     | r Name: IFL_TOP_INC        | Regi  | ster Offset | : 0x518    |
|-------------|----------------------------|-------|-------------|------------|
| PCI<br>Bits | Fund                       | ction |             | PB<br>Bits |
| 31-24       | PowerSpan II Reserved      |       |             |            |
| 23-16       | PowerSpan II Reserved      |       |             |            |
| 15-08       | PowerSpan II Reserved      |       |             |            |
| 07-00       | PowerSpan II Reserved INCR |       |             |            |

#### IFL\_TOP\_INC Description

| Name | • | Туре              | Reset<br>By | Reset<br>State | Function                                                                             |
|------|---|-------------------|-------------|----------------|--------------------------------------------------------------------------------------|
| INCR |   | Write 1 to<br>set | PRI_RS<br>T | 0              | Inbound Free List Top Pointer Increment<br>Write 1 to increment the pointer by four. |

# 13.5.67 I2O Inbound Post List Bottom Pointer Register

Table 164: I2O Inbound Post List Bottom Pointer Register

| Registe     | r Name: IPL_BOT |  | Regis | ster Offset | : 0x51C |  |
|-------------|-----------------|--|-------|-------------|---------|--|
| PCI<br>Bits |                 |  |       |             |         |  |
| 31-24       | PB_I2O_BS       |  |       |             | 0-7     |  |
| 23-16       | PB_I2O_BS BOT   |  |       |             | 8-15    |  |
| 15-08       | вот             |  |       |             | 16-23   |  |
| 07-00       | BOT 0 0         |  |       | 24-31       |         |  |

### **IPL\_BOT** Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                         |
|---------------------|------|-------------|----------------|----------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address   |
| BOT [17:0]          | R/W  | PRI_RST     | 0              | Inbound Post List Bottom Pointer |

**BOT:** This pointer gives the address offset for the Inbound Post List Bottom Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and can be incremented by four by setting the INCR bit in the IPL\_BOT\_INC register.



The initial values of the Inbound Post List Bottom and Top pointers must be the same. After these pointers are initialized, the inbound post list is empty.

# 13.5.68 I2O Inbound Post List Bottom Pointer Increment Register

| Table 165: I2O Inbound Post List Botton | n Pointer Increment Register |
|-----------------------------------------|------------------------------|
|-----------------------------------------|------------------------------|

| Register Name: IPL_BOT_INC |                            | Register Offset: 0x52 |       |            |
|----------------------------|----------------------------|-----------------------|-------|------------|
| PCI<br>Bits                | Fund                       | ction                 |       | PB<br>Bits |
| 31-24                      | PowerSpan II Reserved      |                       | 0-7   |            |
| 23-16                      | PowerSpan II Reserved      |                       | 8-15  |            |
| 15-08                      | PowerSpan II Reserved      |                       | 16-23 |            |
| 07-00                      | PowerSpan II Reserved INCR |                       | 24-31 |            |

### IPL\_BOT\_INC Description

| Name | Туре              | Reset<br>By | Reset<br>State | Function                                                                                |
|------|-------------------|-------------|----------------|-----------------------------------------------------------------------------------------|
| INCR | Write 1 to<br>set | PRI_RST     | 0              | Inbound Post List Bottom Pointer Increment<br>Write 1 to increment the pointer by four. |

п

# 13.5.69 I2O Inbound Post List Top Pointer Register

#### Table 166: I2O Inbound Post List Top Pointer Register

| Registe     | r Name: IPL_TOP |       | Regi | ster Offset | : 0x524    |
|-------------|-----------------|-------|------|-------------|------------|
| PCI<br>Bits | Fun             | ction |      |             | PB<br>Bits |
| 31-24       | PB_I2O_BS       |       |      | 0-7         |            |
| 23-16       | PB_I2O_BS TOP   |       |      | 8-15        |            |
| 15-08       | ТОР             |       |      | 16-23       |            |
| 07-00       | TOP 0 0         |       |      | 24-31       |            |

#### **IPL\_TOP** Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------------|------|-------------|----------------|--------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address |
| TOP [17:0]          | R/W  | PRI_RST     | 0              | Inbound Post List Top Pointer  |

**TOP:** This pointer gives the address offset for the Inbound Post List Top Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and maintained by PowerSpan II. This pointer is incremented by four for each PCI write to the Inbound Queue.



The initial values of the Inbound Post List Bottom and Top pointers should be the same. After these pointers are initialized, the inbound post list is empty.

# 13.5.70 I2O Outbound Free List Bottom Pointer Register

### Table 167: I2O Outbound Free List Bottom Pointer Register

| Registe     | r Name: OFL_BOT | Register Offset: 0x528 |       |       |            |
|-------------|-----------------|------------------------|-------|-------|------------|
| PCI<br>Bits | Fun             | ction                  |       |       | PB<br>Bits |
| 31-24       | PB_I2O_BS       |                        |       | 0-7   |            |
| 23-16       | PB_I2O_BS       | В                      | ТС    |       | 8-15       |
| 15-08       | вот             |                        |       | 16-23 |            |
| 07-00       | BOT 0 0         |                        | 24-31 |       |            |

**OFL\_BOT** Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                          |
|---------------------|------|-------------|----------------|-----------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address    |
| BOT [17:0]          | R/W  | PRI_RST     | 0              | Outbound Free List Bottom Pointer |

**BOT:** This pointer gives the address offset for the Outbound Free List Bottom Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and can be incremented by four by writing a 1 to the INCR bit in the OFL\_BOT\_INC register.



The initial values of the Outbound Free List Bottom and Top pointers must be the same. After these pointers are initialized, the outbound free list is empty.

## 13.5.71 I2O Outbound Free List Bottom Pointer Increment Register

### Table 168: I2O Outbound Free List Bottom Pointer Increment Register

| Register Name: OFL_BOT_INC |                            | Register Offset: |       |            |
|----------------------------|----------------------------|------------------|-------|------------|
| PCI<br>Bits                | Fun                        | ction            |       | PB<br>Bits |
| 31-24                      | PowerSpan II Reserved      |                  |       | 0-7        |
| 23-16                      | PowerSpan II Reserved      |                  |       | 8-15       |
| 15-08                      | PowerSpan II Reserved      |                  | 16-23 |            |
| 07-00                      | PowerSpan II Reserved INCR |                  |       |            |

#### **OFL\_BOT\_INC** Description

| Name | Туре              | Reset<br>By | Reset<br>State | Function                                                                                 |
|------|-------------------|-------------|----------------|------------------------------------------------------------------------------------------|
| INCR | Write 1 to<br>set | PRI_RST     | 0              | Outbound Free List Bottom Pointer Increment<br>Write 1 to increment the pointer by four. |

## 13.5.72 I2O Outbound Free List Top Pointer Register

#### Table 169: I2O Outbound Free List Top Pointer Register

| Registe     | r Name: OFL_TOP |  | Regi | ster Offset | :: 0x530   |
|-------------|-----------------|--|------|-------------|------------|
| PCI<br>Bits | Function        |  |      |             | PB<br>Bits |
| 31-24       | PB_I2O_BS       |  |      |             | 0-7        |
| 23-16       | PB_I2O_BS TOP   |  |      | 8-15        |            |
| 15-08       | ТОР             |  |      | 16-23       |            |
| 07-00       | TOP 0 0         |  |      | 24-31       |            |

**OFL\_TOP** Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------------|------|-------------|----------------|--------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address |
| TOP [17:0]          | R/W  | PRI_RST     | 0              | Outbound Free List Top Pointer |

**TOP:** This pointer gives the address offset for the Outbound Free List Top Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and maintained by PowerSpan II. This pointer is incremented by four for each PCI write to the Outbound Queue.



The initial values of the Outbound Free List Bottom and Top pointers must be the same. After these pointers are initialized, the outbound free list is empty.

## 13.5.73 I2O Outbound Post List Bottom Pointer Register

#### Table 170: I2O Outbound Post List Bottom Pointer Register

| Register Name: OPL_BOT |               |  | Regi | ster Offset | : 0x534    |
|------------------------|---------------|--|------|-------------|------------|
| PCI<br>Bits Function   |               |  |      |             | PB<br>Bits |
| 31-24                  | PB_I2O_BS     |  |      |             | 0-7        |
| 23-16                  | PB_I2O_BS BOT |  |      |             | 8-15       |
| 15-08                  | BOT           |  |      |             | 16-23      |
| 07-00                  | BOT 0 0       |  |      | 24-31       |            |

#### **OPL\_BOT** Description

| Name                | Туре | Reset<br>By | Reset<br>State | Function                          |
|---------------------|------|-------------|----------------|-----------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address    |
| BOT [17:0]          | R/W  | PRI_RST     | 0              | Outbound Post List Bottom Pointer |

**BOT:** This pointer gives the address offset for the Outbound Post List Bottom Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and maintained by PowerSpan II. This pointer is incremented by four for each PCI read from the Outbound Queue.



The initial values of the Outbound Post List Bottom and Top pointers must be the same. After these pointers are initialized, the outbound post list is empty.

## 13.5.74 I2O Outbound Post List Top Pointer Register

#### Table 171: I2O Outbound Post List Top Pointer Register

| Registe     | r Name: OPL_TOP |  | Regi | ster Offset | : 0x538 |
|-------------|-----------------|--|------|-------------|---------|
| PCI<br>Bits |                 |  |      |             |         |
| 31-24       | PB_I2O_BS       |  |      |             | 0-7     |
| 23-16       | PB_I2O_BS TOP   |  |      | 8-15        |         |
| 15-08       | ТОР             |  |      |             | 16-23   |
| 07-00       | TOP 0 0         |  |      | 24-31       |         |

**OPL\_TOP Description** 

| Name                | Туре | Reset<br>By | Reset<br>State | Function                       |
|---------------------|------|-------------|----------------|--------------------------------|
| PB_I2O_BS<br>[11:0] | R    | PRI_RST     | 0              | Processor Bus I2O Base Address |
| TOP [17:0]          | R/W  | PRI_RST     | 0              | Outbound Post List Top Pointer |

**TOP:** This pointer gives the address offset for the Outbound Post List Top Pointer from PB\_I2O\_BS. This pointer is initialized by the IOP and can be incremented by four by writing 1 to the INCR bit in the OPL\_TOP\_INC register.



The initial values of the Outbound Post List Bottom and Top pointers must be the same. After these pointers are initialized, the outbound post list is empty.

## 13.5.75 I2O Outbound Post List Top Pointer Increment Register

### Table 172: I2O Outbound Post List Top Pointer Increment Register

| Register Name: OPL_TOP_INC |                            | Regi | ster Offset | t: 0x53C   |
|----------------------------|----------------------------|------|-------------|------------|
| PCI<br>Bits                |                            |      |             | PB<br>Bits |
| 31-24                      | PowerSpan II Reserved      |      |             | 0-7        |
| 23-16                      | PowerSpan II Reserved      |      |             | 8-15       |
| 15-08                      | PowerSpan II Reserved      |      |             | 16-23      |
| 07-00                      | PowerSpan II Reserved INCR |      |             |            |

#### **OPL\_TOP\_INC** Description

| Name | Туре              | Reset<br>By | Reset<br>State | Function                                                                              |
|------|-------------------|-------------|----------------|---------------------------------------------------------------------------------------|
| INCR | Write 1 to<br>set | PRI_RST     | 0              | Outbound Post List Top Pointer Increment<br>Write 1 to increment the pointer by four. |

## 13.5.76 I2O Host Outbound Index Offset Register

#### Table 173: I2O Host Outbound Index Offset Register

| Registe     | r Name: HOST_OIO          |     | Regi | ster Offset | : 0x540 |  |
|-------------|---------------------------|-----|------|-------------|---------|--|
| PCI<br>Bits |                           |     |      |             |         |  |
| 31-24       | PowerSpan II Reserved     |     |      |             |         |  |
| 23-16       | PowerSpan II Reserved     |     |      |             |         |  |
| 15-08       | PowerSpan II Reserved OIO |     |      |             | 16-23   |  |
| 07-00       | 010                       | 010 |      |             | 24-31   |  |

#### HOST\_OIO Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function                   |
|----------|------|-------------|----------------|----------------------------|
| OIO[9:0] | R/W  | PRI_RST     | 0              | Host Outbound Index Offset |

**OIO[9:0]:** Specifies the I2O Target Image Offset where the I2O Host Outbound Index Register is located within the PowerSpan II I2O Target Image. The I2O Host Outbound Index register must be in the first 4 Kbytes of the PowerSpan II I2O Target Image and be aligned to a 4-byte boundary.



This register must not be programmed with the following values: 0x030, 0x034, 0x040, 0x044.

## 13.5.77 I2O Host Outbound Index Alias Register

This register is required for PowerSpan II I<sup>2</sup>O Outbound Option support. This is an alias to the I2O Host Outbound Index Register in the PowerSpan II I2O Target Image. The Host maintains this register.

This register indicates the address in Host memory from which the Host is to retrieve the next Outbound XMFA. This register is initialized by the IOP with an index received from the Host in an I2O message. The register will be written by the Host during I2O Outbound Option message passing.

| Registe     | r Name: HOST_OIA |       | Reg | ister Offse | t: 0x544   |
|-------------|------------------|-------|-----|-------------|------------|
| PCI<br>Bits | Fun              | ction |     |             | PB<br>Bits |
| 31-24       | OIA              |       |     |             |            |
| 23-16       | 23-16 OIA        |       |     |             |            |
| 15-08       | B OIA            |       |     |             | 16-23      |
| 07-00       | 0 0 OIA          |       |     | 24-31       |            |

#### **HOST\_OIA** Description

| Name      | Туре | Reset<br>By | Reset<br>State | Function                           |
|-----------|------|-------------|----------------|------------------------------------|
| OIA[29:0] | R/W  | PRI_RST     | 0              | Host Outbound Index Alias Register |

If the I2O Host Outbound Index Register and the I2O IOP Outbound Index Register differ, then the Outbound Post List Interrupt Status bit is set in the OPL\_IS register at offset 0x30 of the PCI I2O target Image. When these registers contain the same Host memory address, the Interrupt is cleared.

This feature is only supported when the I2O Outbound Option is enabled with I2O\_CSR[XI2O\_EN].

I2O\_CSR[HOPL\_SIZE] determines the alignment of this Index Register.

## 13.5.78 I2O IOP Outbound Index Register

This register is required for PowerSpan II I2O Outbound Option support. This register indicates the address in Host memory to which the IOP is to post the next Outbound XMFA. The IOP maintains this register.

| Table 175: I2O IOF | POutbound Index Register |
|--------------------|--------------------------|
|--------------------|--------------------------|

| Register Name: IOP_OI |         | Register Offset: 0x5 |   |   |            |
|-----------------------|---------|----------------------|---|---|------------|
| PCI<br>Bits           | Fun     | ction                |   |   | PB<br>Bits |
| 31-24                 | OI      |                      |   |   | 0-7        |
| 23-16                 | 3-16 OI |                      |   |   |            |
| 15-08                 | 08 OI   |                      |   |   | 16-23      |
| 07-00                 | OI      |                      | 0 | 0 | 24-31      |

#### **IOP\_OI** Description

| Name     | Туре | Reset<br>By | Reset<br>State | Function           |
|----------|------|-------------|----------------|--------------------|
| OI[29:0] | R/W  | PRI_RS<br>T | 0              | IOP Outbound Index |

If the I2O Host Outbound Index Register and the I2O IOP Outbound Index Register differ, then the Outbound Post List Interrupt Status bit is set in the OPL\_IS register at offset 0x30 of the PCI I2O target Image. When these registers contain the same Host memory address, the Interrupt is cleared.

This feature is only supported when the I2O Outbound Option is enabled with the XI2O\_EN bit in the I2O\_CSR register.

The HOPL\_SIZE bit in the I2O\_CSR register determines the alignment of this Index Register

## 13.5.79 I2O IOP Outbound Index Increment Register

The IOP writes 1 to INCR to increment the IOP Outbound Index Register.

#### Table 176: I2O IOP Outbound Index Increment Register

| Register Name: IOP_OI_INC |                            | Regis | ster Offset | : 0x54C    |
|---------------------------|----------------------------|-------|-------------|------------|
| PCI<br>Bits               | Fun                        | ction |             | PB<br>Bits |
| 31-24                     | PowerSpan II Reserved      |       |             |            |
| 23-16                     | PowerSpan II Reserved      |       |             |            |
| 15-08                     | PowerSpan II Reserved      |       |             |            |
| 07-00                     | PowerSpan II Reserved INCR |       |             |            |

#### IOP\_OI\_INC Description

| Name | Туре              | Reset<br>By | Reset<br>State | Function                                                                  |
|------|-------------------|-------------|----------------|---------------------------------------------------------------------------|
| INCR | Write 1 to<br>set | PRI_RST     | 0              | IOP Outbound Index Increment<br>Write 1 to increment the pointer by four. |

## 13.5.80 PCI-2 Configuration Registers

### Table 177: PCI-2 Configuration Registers

Register Offset: 0x800-0x8FC

#### **PCI-2** Configuration

Function

The PCI-2 Configuration Registers are functionally identical to the PCI-1 Configuration Registers from offsets 0x000-0FC. Documentation of the PCI-2 Configuration Space is the same as the PCI-1 Interface, shifting the register offsets up by 0x800 and swapping PCI-1 and PCI-2 everywhere.

## 13.5.81 PCI-2 Target Image Control and Status Registers

Table 178: PCI-2 Target Image Control and Status Registers

Register Offset: 0x900-0x9FC

#### PCI-2 Target Image

Function

The PCI-2 Target Image Control and Status Registers are functionally identical to the PCI-1 Target Image Control and Status Registers from offsets 0x100-1FC. Documentation of the PCI-2 Target Images is the same as the PCI-1 Images, shifting the register offsets up by 0x800 and swapping PCI-1 and PCI-2 everywhere.



## **A. Package Information**

This appendix discusses PowerSpan II's packaging (mechanical) features. The following topics are discussed:

- "Package Characteristics" on page 443
- "Thermal Characteristics" on page 450

## A.1 Package Characteristics

PowerSpan II's package characteristics are summarized in the following sections.

## A.1.1 Single PCI PowerSpan II 420 HSBGA

Figure 28 illustrates the top, side, and bottom views of the PowerSpan II package.

#### Table 179: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 420 HSBGA                    |
| Package Body Size   | 35mm                         |
| JEDEC Specification | JEDEC MO-151 Variation BAT-1 |

#### Figure 28: 420 HSBGA



#### A.1.1.1 Package Notes

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M 1994
- 3. Conforms to JEDEC MS-034 Variation BAR-1

## A.1.2 Single PCI PowerSpan II 484 HSBGA

Figure 29 illustrates the top, side, and bottom views of the PowerSpan II package.

#### Table 180: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 484 HSBGA                    |
| Package Body Size   | 23mm                         |
| JEDEC Specification | JEDEC MS-034 Variation AAJ-1 |

#### Figure 29: 484 PBGA



#### A.1.2.1 Package Notes

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M 1994
- 3. Conforms to JEDEC MS-034 Variation AAJ-1

### A.1.3 Dual PCI PowerSpan II 480 HSBGA

Figure 30 illustrates the top, side, and bottom views of the PowerSpan II package.

#### Table 181: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 480 HSBGA                    |
| Package Body Size   | 37.5mm                       |
| JEDEC Specification | JEDEC MO-151 Variation BAT-1 |

\_\_\_\_0.15 C

- 2.33±0.13

0.50~0.70

0.56 REF.

0.56 REF.

/// 0.15 C

Detail A

#### Figure 30: 480 HSBGA



#### **Package Notes** A.1.3.1

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M - 1994
- Conforms to JEDEC MO-151 Variation BAT-1 3.

## A.1.4 Dual PCI PowerSpan II 504 HSBGA

Figure 31 illustrates the top, side, and bottom views of the PowerSpan II package.

### Table 182: Package Characteristics

| Feature             | Description                  |
|---------------------|------------------------------|
| Package Type        | 504 HSBGA                    |
| Package Body Size   | 27mm                         |
| JEDEC Specification | JEDEC MO-151 Variation AAL-1 |

2.23±0.13

-0.40~0.60

Detail A

#### Figure 31: 504 HSBGA





- 2. All dimension and tolerances conform to ANSI
- 3. Conforms to JEDEC MO-151 Variation AAL-1.

#### **Package Notes** A.1.4.1

- 1. All dimensions in mm
- 2. All dimensions and tolerance conform to ANSI Y14.5M - 1994
- 3. Conforms to JEDEC MO-151 Variation AAL-1

## A.2 Thermal Characteristics

The thermal performance of PowerSpan II package is represented by the following parameters:

1.  $\theta_{JA}$ , Thermal resistance from junction to ambient

$$\theta_{JA} = (T_J - T_A) / P$$

Where,

 $T_J$  is the junction temperature

T<sub>A</sub> is the ambient temperature

P is the power dissipation

 $\theta_{JA}$  represents the resistance to the heat flows from the chip to ambient air. It is an index of heat dissipation capability. Lower  $\theta_{JA}$  means better thermal performance.

2.  $\psi_{JT}$ , Thermal characterization parameter from junction-to-top center

 $\psi_{JT} = (T_J - T_T) / P$ 

Where  $T_T$  is the temperature of the top-center of the package

 $\psi_{JT}$  is used to estimate junction temperature by measuring  $T_T$  in actual environment.

3. 3.  $\theta_{JC}$ , Thermal resistance from junction to case

$$\theta_{JC} = (T_J - T_C) / H$$

Where,

 $T_C$  is the case temperature

 $\theta_{JC}$  is a measure of package internal thermal resistance from chip to package exterior.

The value is dependent upon package material and package geometry.

 $\theta_{JA,}$   $\theta_{JC}$  and  $\psi_{JT}$  simulation are carried out to show the thermal performance of the PowerSpan II.

## A.2.1 Single PCI 420 HSBGA Package

The thermal characteristic estimates for the 420 package are based on the parameters in Table 183.

| Package Conditions                          |                            |  |  |  |
|---------------------------------------------|----------------------------|--|--|--|
| Package type                                | HSBGA 420                  |  |  |  |
| Package size 35 x 35 x 2.33 mm <sup>3</sup> |                            |  |  |  |
| Pitch                                       | 1.27 mm                    |  |  |  |
| Pad size                                    | 318 x 318 mil <sup>2</sup> |  |  |  |
| Chip size                                   | 232 x 232 mil <sup>2</sup> |  |  |  |
| Substrate (layers)                          | 4 L                        |  |  |  |
| Substrate thickness                         | 0.56 mm                    |  |  |  |
| PCB Condition                               | s (JEDEC JESD51-7)         |  |  |  |
| PCB Layers                                  | 4L                         |  |  |  |
| PCB dimensions                              | 101.6 x 114.3 mm           |  |  |  |
| PCB thickness                               | 1.6 mm                     |  |  |  |
| Simulation conditions                       |                            |  |  |  |
| Power dissipation                           | 1.9 watts                  |  |  |  |
| Ambient temperature                         | 85 °C                      |  |  |  |

#### Table 183: Thermal Estimate Parameters

Table 184 shows the thermal estimates and the thermal characterization parameters from junction-to-top center ( $\Psi_{JT}$ ) and the thermal resistance from junction to case for the 420 package. These estimates are based on the parameters described in Table 183.

#### Table 184: 420 HSBGA Package Performance

|       | Theta ja (C/W) |       |                         |                |
|-------|----------------|-------|-------------------------|----------------|
| 0 m/s | 1 m/s          | 2 m/s | Psi <sub>jt</sub> (C/W) | Theta jc (C/W) |
| 17.1  | 14.5           | 13.1  | 5.35                    | 6.60           |

## A.2.2 Single PCI 484 PBGA Package

The thermal characteristic estimates for the 484 package are based on the parameters in Table 185.

| Package Conditions              |                                |  |  |  |
|---------------------------------|--------------------------------|--|--|--|
| Package type                    | HSBGA 484                      |  |  |  |
| Package size                    | 23 x 23 x 2.03 mm <sup>3</sup> |  |  |  |
| Pitch                           | 1.00 mm                        |  |  |  |
| Pad size                        | 357 x 357 mil <sup>2</sup>     |  |  |  |
| Chip size                       | 207 x 207 mil <sup>2</sup>     |  |  |  |
| Substrate (layers)              | 4 L                            |  |  |  |
| Substrate thickness             | 1.60 mm                        |  |  |  |
| PCB Conditions (JEDEC JESD51-7) |                                |  |  |  |
| PCB Layers                      | 4L                             |  |  |  |
| PCB dimensions                  | 101.6 x 114.3 mm               |  |  |  |
| PCB thickness                   | 1.6 mm                         |  |  |  |
| Simulation conditions           |                                |  |  |  |
| Simulation Conditions           |                                |  |  |  |
| Power dissipation               | 1.9 watts                      |  |  |  |
| Ambient temperature             | 85 °C                          |  |  |  |

#### **Table 185: Thermal Estimate Parameters**

Table 186 shows the thermal estimates and the thermal characterization parameters from junction-to-top center ( $\Psi_{JT}$ ) and the thermal resistance from junction to case for the 484 package. These estimates are based on the parameters described in Table 185.

Table 186: 484 PBGA Package Performance

|       | Theta ja (C/W) |       |                         |                |
|-------|----------------|-------|-------------------------|----------------|
| 0 m/s | 1 m/s          | 2 m/s | Psi <sub>jt</sub> (C/W) | Theta jc (C/W) |
| 21.4  | 18.7           | 17.0  | 4.87                    | 6.00           |

### A.2.3 Dual PCI 480 HSBGA Package

The thermal characteristic estimates for the 480 package are based on the parameters in Table 187.

| Package Conditions                                      |                            |  |  |  |
|---------------------------------------------------------|----------------------------|--|--|--|
| Package type                                            | HSBGA 480L                 |  |  |  |
| Package size         37.5 x 37.5 x 2.33 mm <sup>3</sup> |                            |  |  |  |
| Pitch                                                   | 1.27 mm                    |  |  |  |
| Pad size                                                | 303 x 303 mil <sup>2</sup> |  |  |  |
| Chip size                                               | 253 x 253 mil <sup>2</sup> |  |  |  |
| Substrate (layers)                                      | 4 L                        |  |  |  |
| Substrate thickness                                     | 0.56 mm                    |  |  |  |
| PCB Condition                                           | s (JEDEC JESD51-7)         |  |  |  |
| PCB Layers                                              | 4L                         |  |  |  |
| PCB dimensions                                          | 101.6 x 114.3 mm           |  |  |  |
| PCB thickness                                           | 1.6 mm                     |  |  |  |
| Simulation Conditions                                   |                            |  |  |  |
| Power dissipation                                       | 3.0 watts                  |  |  |  |
| Ambient temperature                                     | 85 °C                      |  |  |  |

#### Table 187: Thermal Estimate Parameters

Table 188 shows the thermal estimates and the thermal characterization parameters from junction-to-top center ( $\Psi_{JT}$ ) and the thermal resistance from junction to case for the 480 package. These estimates are based on the parameters described in Table 187.

#### Table 188: 480 PBGA Package Performance

|       | Theta ja (C/W) |       |                         |                |
|-------|----------------|-------|-------------------------|----------------|
| 0 m/s | 1 m/s          | 2 m/s | Psi <sub>jt</sub> (C/W) | Theta jc (C/W) |
| 15.1  | 13.2           | 11.8  | 4.87                    | 6.00           |

### A.2.4 Dual PCI 504 HSBGA Package.

The Thermal Characteristic estimates for the 504 package are based on the parameters in Table 189.

| Package Conditions              |                                |  |  |  |
|---------------------------------|--------------------------------|--|--|--|
| Package type                    | HSBGA 504L                     |  |  |  |
| Package size                    | 27 x 27 x 2.33 mm <sup>3</sup> |  |  |  |
| Pitch                           | 1.00 mm                        |  |  |  |
| Pad size                        | 309 x 309 mil <sup>2</sup>     |  |  |  |
| Chip size                       | 259 x 259 mil <sup>2</sup>     |  |  |  |
| Substrate (layers)              | 4 L                            |  |  |  |
| Substrate thickness             | 0.56 mm                        |  |  |  |
| PCB Conditions (JEDEC JESD51-7) |                                |  |  |  |
| PCB Layers                      | 4L                             |  |  |  |
| PCB dimensions                  | 101.6 x 114.3 mm               |  |  |  |
| PCB thickness                   | 1.6 mm                         |  |  |  |
| Simulation Conditions           |                                |  |  |  |
| Power dissipation               | 3.0 watts                      |  |  |  |
| Ambient temperature             | 85 °C                          |  |  |  |

#### **Table 189: Thermal Estimate Parameters**

Table 190 shows the thermal estimates and the thermal characterization parameters from junction-to-top center ( $\Psi_{JT}$ ) and the thermal resistance from junction to case for the 504 package. These estimates are based on the parameters described in Table 189.

#### Table 190: 504 PBGA Package Performance

|       | Theta ja (C/W) |       |                         |                |
|-------|----------------|-------|-------------------------|----------------|
| 0 m/s | 1 m/s          | 2 m/s | Psi <sub>jt</sub> (C/W) | Theta jc (C/W) |
| 16.4  | 14.7           | 11.8  | 4.10                    | 5.90           |



# **B. Ordering Information**

This appendix discusses PowerSpan II's ordering information.

## **B.1** Ordering Information

Tundra products are designated by a part number. When ordering, refer to products by their full part number. For detailed mechanical drawings or alternative packaging requirements, please contact Tundra Semiconductor directly (see "Contact Information" on page 5).

| Table 191: Standard Ordering Informatio | Table 191: | 91: Standard | d Ordering | Information |
|-----------------------------------------|------------|--------------|------------|-------------|
|-----------------------------------------|------------|--------------|------------|-------------|

| Part Number            | Description              | Frequency | Voltage<br>(IO/<br>CORE) | Temperature  | Package   | Diameter<br>(mm)      |
|------------------------|--------------------------|-----------|--------------------------|--------------|-----------|-----------------------|
| CA91L8200B-<br>100CEZ2 | Dual PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | 0° to 70°C   | 480 HSBGA | 37.5 x 37.5 x<br>1.27 |
| CA91L8200B-<br>100CLZ2 | Dual PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | 0° to 70°C   | 504 HSBGA | 27 x 27 x<br>1.00     |
| CA91L8200B-<br>100IEZ2 | Dual PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | -40° to 85°C | 480 HSBGA | 37.5 x 37.5 x<br>1.27 |
| CA91L8200B-<br>100ILZ2 | Dual PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | -40° to 85°C | 504 HSBGA | 27 x 27 x<br>1.00     |

| Part Number          | Description                | Frequency | Voltage<br>(IO/<br>CORE) | Temperature  | Package   | Diameter<br>(mm)  |
|----------------------|----------------------------|-----------|--------------------------|--------------|-----------|-------------------|
| CA91L8260B-<br>100CE | Single PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | 0° to 70°C   | 420 HSBGA | 35 x 35 x<br>1.27 |
| CA91L8260B-<br>100CL | Single PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | 0° to 70°C   | 484 PBGA  | 23 x 23 x<br>1.00 |
| CA91L8260B-<br>100IE | Single PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | -40° to 85°C | 420 HSBGA | 35 x 35 x<br>1.27 |
| CA91L8260B-<br>100IL | Single PCI<br>PowerSpan II | 100MHz    | 3.3/2.5                  | -40° to 85°C | 484 PBGA  | 23 x 23 x<br>1.00 |



# C. AC Timing

This chapter describes PowerSpan II's AC Timing parameters. The following topics are discussed:

- "Single PCI PowerSpan II Timing Parameters" on page 458
- "Dual PCI PowerSpan II Timing Parameters" on page 464
- "Timing Diagrams" on page 470

## C.1 Overview

This chapter describes the timing information for the PowerSpan II device. The timing for the both the Single and the Dual PCI PowerSpan II's Processor Bus Interface is 100 MHz, while the PCI Interface(s) can operate either at 33 MHz or 66 MHz.

## C.2 Single PCI PowerSpan II Timing Parameters

The timing parameters specified in this document are guaranteed by design. Test conditions for timing parameters in Table 192 to Table 196 are:

- Commercial (C): 0°C to 70°C, 3.15 3.45V, 2.38 2.63V
- Industrial (I): -40°C to 85°C, 3.15 3.45V, 2.38 2.63V

#### Table 192: Reset, and Clock Timing Parameters

| Timing              |                                                            | CE/IE |     |         |      |
|---------------------|------------------------------------------------------------|-------|-----|---------|------|
| Timing<br>Parameter | Description                                                | Min   | Max | Units   | Note |
| Reset Timing        |                                                            |       |     |         |      |
| t <sub>100</sub>    | Power-up reset pulse width                                 | 500   |     | ns      | 1    |
| t <sub>101</sub>    | Back end power stable to back end power-up reset released. | 500   |     | ns      |      |
| t <sub>102</sub>    | Clock frequency stable before release of power-up reset    | 0     |     | ns      | 2    |
| t <sub>103</sub>    | PLL lock time                                              | 100   | 400 | us      | 3    |
| t <sub>104</sub>    | Reset propagation delay                                    |       | 20  | ns      |      |
| t <sub>428</sub>    | TRST_ pulse width                                          | 500   |     | ns      | 4    |
| Power-up Optic      | on Timing                                                  |       |     |         |      |
| t <sub>110</sub>    | Power-up option setup time on multiplexed system pins      | 10    |     | ns      |      |
| t <sub>111</sub>    | Power-up option hold time on multiplexed system pins       | 3.0   | 10  | ns      | 5    |
| t <sub>112</sub>    | Power-up option setup time to PB_RSTCONF_                  | 10    |     | ns      |      |
| t <sub>113</sub>    | Power-up option hold time from<br>PB_RSTCONF_              | 5     |     | ns      |      |
| t <sub>114</sub>    | PB_RSTCONF_ pulse width                                    | 1     |     | PB_CLKs |      |
| Processor Cloc      | k Timing                                                   |       |     |         |      |
| t <sub>120</sub>    | PB_CLK period                                              | 10    | 40  | ns      |      |
|                     | PB_CLK frequency                                           | 25    | 100 | MHz     |      |
| t <sub>121</sub>    | PB_CLK high time                                           | 4     |     | ns      |      |
| t <sub>122</sub>    | PB_CLK low time                                            | 4     |     | ns      |      |

| Timina              |                                      | CE/IE    |     |       |      |
|---------------------|--------------------------------------|----------|-----|-------|------|
| Timing<br>Parameter | Description                          | Min      | Мах | Units | Note |
| t <sub>123</sub>    | PB_CLK slew rate                     | 2        |     | V/ns  |      |
| t <sub>124</sub>    | PB_CLK cycle to cycle jitter         |          | 300 | ps    |      |
| PCI Clock Timi      | ng                                   | <u>.</u> |     |       |      |
| t <sub>130</sub>    | P1_CLK, P2_CLK period                | 15       | 40  | ns    |      |
|                     | P1_CLK, P2_CLK frequency             | 25       | 66  | MHz   |      |
| t <sub>131</sub>    | P1_CLK, P2_CLK high time             | 6        |     | ns    |      |
| t <sub>132</sub>    | P1_CLK, P2_CLK low time              | 6        |     | ns    |      |
| t <sub>133</sub>    | P1_CLK, P2_CLK slew rate             | 2        |     | V/ns  |      |
| t <sub>134</sub>    | P1_CLK, P2_CLK cycle to cycle jitter |          | 300 | ps    |      |
| Clock to Clock      | Relationships                        | -        | -   |       |      |
| t <sub>140</sub>    | Clock period ratio                   | 1        | < 4 | -     | 6    |

| <b>Table 192</b> : | Reset, | and | Clock | Timing | Parameters |
|--------------------|--------|-----|-------|--------|------------|
|--------------------|--------|-----|-------|--------|------------|

1. Pulse width measured from Vdd Core (2.5V), Vdd I/O (3.3V), and Px\_VDDA supplies in specification

2. Required for PB\_CLK, P1\_CLK and P2\_CLK. This parameter ensures that each PLL locks. If a frequency change is required, a new power-up sequence must be initiated.

3. This parameter is a function of the slowest frequency of PB\_CLK, P1\_CLK, and P2\_CLK. The minimum occurs at 100 MHz, the maximum at 25 MHz. After this time, PowerSpan II is synchronized to external buses and able to participate in transactions once externally applied resets are released.

4. Assertion of TRST\_ is required at power-up to initialize the JTAG controller and configure the Boundary Scan Register for normal system operation.

5. The maximum specification ensures correct power-up levels on PB\_FAST, P1\_M66EN and P2\_M66EN and ensures stable system levels on INT[5:1]\_ before the power-up reset sequence completes.

6. The ratio of largest to smallest clock period for PB\_CLK, P1\_CLK, P2\_CLK must be strictly less than four. For example, if PB\_CLK period is 12 ns, the periods of P1\_CLK and P2\_CLK must be each less than 48 ns.

PowerSpan II's PCI interface can be configured for operating frequencies between 25 and 33 MHz by ensuring that the pin Px\_M66EN is connected to logic zero. Table 193 summarizes the timing behavior of a PowerSpan II PCI interface configured in this way. This table is valid for operation in 3.3V or 5.0V signaling environments.

| Timina              |                                 | CE/IE |     |         |      |
|---------------------|---------------------------------|-------|-----|---------|------|
| Timing<br>Parameter | Description                     | Min   | Max | Units   | Note |
| t <sub>200</sub>    | Float to active delay           | 2     |     | ns      |      |
| t <sub>201</sub>    | Active to float delay           |       | 28  | ns      |      |
| t <sub>202</sub>    | Signal valid delay              | -     |     |         |      |
|                     | Bussed signals                  | 2     | 11  | ns      |      |
|                     | Point to point signals          | 2     | 12  | ns      | 1    |
| t <sub>203</sub>    | Input setup time                | -     |     |         |      |
|                     | Bussed signals                  | 7     |     | ns      |      |
|                     | Point to point signals          | 10    |     | ns      | 2    |
| t <sub>204</sub>    | Input hold time                 | 0     |     | ns      |      |
| t <sub>205</sub>    | P1_REQ64# to P1_RST# setup time | •     |     |         |      |
|                     | Adapter scenario                | 10    |     | PB_CLKs | 3    |
|                     | Host scenario                   | 10    |     | PB_CLKs | 5    |
| t <sub>206</sub>    | P1_RST# to P1_REQ64# hold time  |       |     |         |      |
|                     | Adapter scenario                | 2.3   |     | ns      | 3, 4 |
|                     | Host scenario                   | 0     | 50  | ns      | 5    |
| t <sub>207</sub>    | Reset to float                  |       | 40  | ns      |      |

Table 193: PCI 33 MHz Timing Parameters

1. This group of point to point signals include: P1\_REQ[1]#, P2\_REQ[1]#, P1\_GNT[4:1]#, P2\_GNT[4:1]# and PCI\_GNT[7:5]#.

2. This group of point to point signals include: P1\_GNT[1]#, P2\_GNT[1]#, P1\_REQ[4:1]#, P2\_REQ[4:1#], and PCI\_REQ[7:5]#.

3. In the adapter scenario, an external agent controls both P1\_REQ64# and P1\_RST#.

4. In the *PCI Local Bus Specification (Revision 2.2)* this value is required to be 0 ns.

5. In the host scenario, PowerSpan II controls both P1\_REQ64# and P1\_RST#.

Each PowerSpan II PCI interface can be configured for 66 MHz operating frequencies by ensuring that the pin Px\_M66EN is connected to logic one. Table 194 summarizes the timing behavior of a PowerSpan II PCI interface configured in this way. This table is valid for operation in a 3V signaling environment.

Table 194: PCI 66 MHz Timing Parameters

| Timing           |                                 | CE  | E/IE |         |      |
|------------------|---------------------------------|-----|------|---------|------|
| Parameter        | Description                     | Min | Max  | Units   | Note |
| t <sub>200</sub> | Float to active delay           | 1   |      | ns      |      |
| t <sub>201</sub> | Active to float delay           |     | 14   | ns      |      |
| t <sub>202</sub> | Signal valid delay              | -   |      |         |      |
|                  | Bussed signals                  | 1   | 6.0  | ns      |      |
|                  | Point to point signals          | 1   | 6.0  | ns      | 1    |
| t <sub>203</sub> | Input setup time                | -   |      |         |      |
|                  | Bussed signals                  | 3.0 |      | ns      |      |
|                  | Point to point signals          | 5   |      | ns      | 2    |
| t <sub>204</sub> | Input hold time                 | 0   |      | ns      |      |
| t <sub>205</sub> | P1_REQ64# to P1_RST# setup time |     |      |         |      |
|                  | Adapter scenario                | 10  |      | PB_CLKs | 3    |
|                  | Host scenario                   | 10  |      | PB_CLKs | 4    |
| t <sub>206</sub> | P1_RST# to P1_REQ64# hold time  | -   |      | -       |      |
|                  | Adapter scenario                | 2.3 |      | ns      | 3    |
|                  | Host scenario                   | 0   | 50   | ns      | 4    |
| t <sub>207</sub> | Reset to float                  |     | 40   | ns      |      |

This group of point to point signals include: P1\_REQ[1]#, P2\_REQ[1]#, P1\_GNT[4:1]#, P2\_GNT[4:1]# and PCI\_GNT[7:5]#. 1.

2. This group of point to point signals include: P1\_GNT[1]#, P2\_GNT[1]#, P1\_REQ[4:1]#, P2\_REQ[4:1]#, and PCI\_REQ[7:5]#.

In the adapter scenario, an external agent controls both P1\_REQ64# and P1\_RST#. 3.

4. In the host scenario, PowerSpan II controls both P1\_REQ64# and P1\_RST#.

| Table | 195: | PΒ | Timing | Parameters |
|-------|------|----|--------|------------|
|-------|------|----|--------|------------|

| Timing              |                              | CE  | CE/IE |       |      |
|---------------------|------------------------------|-----|-------|-------|------|
| Timing<br>Parameter | Description                  | Min | Max   | Units | Note |
| t <sub>302</sub>    | PB_CLK to output valid delay | -   |       |       |      |
|                     | Parameter group outputs      | 1.0 | 5.0   | ns    | 1,2  |
|                     | Control group outputs        | 1.0 | 5.0   | ns    | 1,3  |
|                     | PB_ARTRY_                    | 1.0 | 5.0   | ns    | 1    |
|                     | Arbitration group outputs    | 1.0 | 5.0   | ns    | 1, 4 |
| t <sub>303</sub>    | Input setup time             |     |       |       |      |
|                     | Bussed signals               | 3.0 |       | ns    |      |
|                     | PB_AP                        | 2.0 |       | ns    |      |
|                     | Point to point signals       | 3.0 |       | ns    | 5    |
| t <sub>304</sub>    | Input hold time              | 0.3 |       | ns    |      |

1. Numbers measured into lumped 35 pF load.

2. The transaction parameter group of signals includes: PB\_A[0:31], PB\_AP[0:3], PB\_TSIZ[0:3], PB\_TT[0:4], PB\_TBST\_, PB\_GBL\_, PB\_CI\_, PB\_D[0:63], PB\_DP[0:7].

3. The transaction control group of signals includes: PB\_TS\_, PB\_ABB\_, PB\_DBB\_, PB\_TA\_, PB\_DVA\_L, PB\_TEA\_, PB\_AACK\_.

4. The transaction arbitration group outputs includes: PB\_BR[1]\_, PB\_BG[1:3]\_, PB\_DBG[1:3]\_

5. The point to point signals include: PB\_BG[1]\_, PB\_BR[1:3]\_, PB\_DBG[1]\_

| Timing                  |                            | CE/IE |      |         |      |
|-------------------------|----------------------------|-------|------|---------|------|
| Parameter               | Description                | Min   | Max  | Units   | Note |
| Interrupt Tim           | ing                        |       |      |         |      |
| t <sub>400</sub>        | Float to active delay      | 2     | 15   | ns      | 1    |
| t <sub>401</sub>        | Active to float delay      | 2     | 15   | ns      | 1    |
| t <sub>402</sub>        | Input setup time           | 3     |      | ns      | 2    |
| t <sub>403</sub>        | Input hold time            | 0.5   |      | ns      | 2    |
| t <sub>404</sub>        | Pulse width                | 4     |      | PB_CLKs | 3    |
| I <sup>2</sup> C Timing |                            |       |      |         |      |
| t <sub>410</sub>        | I2C_SCLK period            | 1024  | 1024 | PB_CLKs |      |
| t <sub>411</sub>        | I2C_SCLK high time         | 512   | 512  | PB_CLKs |      |
| t <sub>412</sub>        | I2C_SCLK low time          | 512   | 512  | PB_CLKs |      |
| t <sub>413</sub>        | STOP condition setup time  | 512   | 512  | PB_CLKs |      |
| t <sub>414</sub>        | Bus free time              | 512   |      | PB_CLKs |      |
| t <sub>415</sub>        | START condition setup time | 1024  |      | PB_CLKs |      |
| t <sub>416</sub>        | START condition hold time  | 512   | 512  | PB_CLKs |      |
| t <sub>417</sub>        | Data output valid time     | 256   | 256  | PB_CLKs |      |
| t <sub>418</sub>        | Data output hold time      | 256   | 256  | PB_CLKs |      |
| t <sub>419</sub>        | Data sample time           | 256   | 256  | PB_CLKs |      |

#### **Table 196: Miscellaneous Timing Parameters**

1. Numbers measured into 35 pF load.

2. PowerSpan II synchronizes these inputs before using them. This parameter must be met for deterministic response time.

3. PowerSpan II filters these inputs to ensure spurious low going pulses are not recognized as active interrupts. An interrupt pin is considered valid if three PB\_CLK samples yield the same result.

## C.3 Dual PCI PowerSpan II Timing Parameters

The timing parameters specified in this document are guaranteed by design. Test conditions for timing parameters in Table 197 to Table 201 are:

- Commercial (C): 0°C to 70°C, 3.15 3.45V, 2.38 2.63V
- Industrial (I): -40°C to 85°C, 3.15 3.45V, 2.38 2.63V

#### Table 197: Reset, and Clock Timing Parameters

| Timina              |                                                            | CE/IE |     |         |      |
|---------------------|------------------------------------------------------------|-------|-----|---------|------|
| Timing<br>Parameter | Description                                                | Min   | Max | Units   | Note |
| Reset Timing        |                                                            |       |     |         |      |
| t <sub>100</sub>    | Power-up reset pulse width                                 | 500   |     | ns      | 1    |
| t <sub>101</sub>    | Back end power stable to back end power-up reset released. | 500   |     | ns      |      |
| t <sub>102</sub>    | Clock frequency stable before release of power-up reset    | 0     |     | ns      | 2    |
| t <sub>103</sub>    | PLL lock time                                              | 100   | 400 | us      | 3    |
| t <sub>104</sub>    | Reset propagation delay                                    |       | 20  | ns      |      |
| t <sub>428</sub>    | TRST_ pulse width                                          | 500   |     | ns      | 4    |
| Power-up Optic      | on Timing                                                  |       |     |         |      |
| t <sub>110</sub>    | Power-up option setup time on multiplexed system pins      | 10    |     | ns      |      |
| t <sub>111</sub>    | Power-up option hold time on multiplexed system pins       | 3.0   | 10  | ns      | 5    |
| t <sub>112</sub>    | Power-up option setup time to PB_RSTCONF_                  | 10    |     | ns      |      |
| t <sub>113</sub>    | Power-up option hold time from<br>PB_RSTCONF_              | 5     |     | ns      |      |
| t <sub>114</sub>    | PB_RSTCONF_ pulse width                                    | 1     |     | PB_CLKs |      |
| Processor Cloc      | k Timing                                                   |       | •   |         |      |
| t <sub>120</sub>    | PB_CLK period                                              | 10    | 40  | ns      |      |
|                     | PB_CLK frequency                                           | 25    | 100 | MHz     |      |
| t <sub>121</sub>    | PB_CLK high time                                           | 4     |     | ns      |      |
| t <sub>122</sub>    | PB_CLK low time                                            | 4     |     | ns      |      |

| Timina              |                                      | CE/IE |     |       |      |
|---------------------|--------------------------------------|-------|-----|-------|------|
| Timing<br>Parameter | Description                          | Min   | Max | Units | Note |
| t <sub>123</sub>    | PB_CLK slew rate                     | 2     |     | V/ns  |      |
| t <sub>124</sub>    | PB_CLK cycle to cycle jitter         |       | 300 | ps    |      |
| PCI Clock Timi      | ng                                   |       | -   |       |      |
| t <sub>130</sub>    | P1_CLK, P2_CLK period                | 15    | 40  | ns    |      |
|                     | P1_CLK, P2_CLK frequency             | 25    | 66  | MHz   |      |
| t <sub>131</sub>    | P1_CLK, P2_CLK high time             | 6     |     | ns    |      |
| t <sub>132</sub>    | P1_CLK, P2_CLK low time              | 6     |     | ns    |      |
| t <sub>133</sub>    | P1_CLK, P2_CLK slew rate             | 2     |     | V/ns  |      |
| t <sub>134</sub>    | P1_CLK, P2_CLK cycle to cycle jitter |       | 300 | ps    |      |
| Clock to Clock      | Relationships                        | -     | -   | -     |      |
| t <sub>140</sub>    | Clock period ratio                   | 1     | < 4 | -     | 6    |

| Table 197: | Reset, | and | Clock | Timing | Parameters |
|------------|--------|-----|-------|--------|------------|
|------------|--------|-----|-------|--------|------------|

1. Pulse width measured from Vdd Core (2.5V), Vdd I/O (3.3V), and Px\_VDDA supplies in specification

2. Required for PB\_CLK, P1\_CLK and P2\_CLK. This parameter ensures that each PLL locks. If a frequency change is required, a new power-up sequence must be initiated.

3. This parameter is a function of the slowest frequency of PB\_CLK, P1\_CLK, and P2\_CLK. The minimum occurs at 100 MHz, the maximum at 25 MHz. After this time, PowerSpan II is synchronized to external buses and able to participate in transactions once externally applied resets are released.

4. Assertion of TRST\_ is required at power-up to initialize the JTAG controller and configure the Boundary Scan Register for normal system operation.

5. The maximum specification ensures correct power-up levels on PB\_FAST, P1\_M66EN and P2\_M66EN and ensures stable system levels on INT[5:1]\_ before the power-up reset sequence completes.

6. The ratio of largest to smallest clock period for PB\_CLK, P1\_CLK, P2\_CLK must be strictly less than four. For example, if PB\_CLK period is 12 ns, the periods of P1\_CLK and P2\_CLK must be each less than 48 ns.

PowerSpan II's PCI interface can be configured for operating frequencies between 25 and 33 MHz by ensuring that the pin Px\_M66EN is connected to logic zero. Table 198 summarizes the timing behavior of a PowerSpan II PCI interface configured in this way. This table is valid for operation in 3.3V or 5.0V signaling environments.

| Timina              |                                 | CE/IE |     |         |      |
|---------------------|---------------------------------|-------|-----|---------|------|
| Timing<br>Parameter | Description                     | Min   | Мах | Units   | Note |
| t <sub>200</sub>    | Float to active delay           | 2     |     | ns      |      |
| t <sub>201</sub>    | Active to float delay           |       | 28  | ns      |      |
| t <sub>202</sub>    | Signal valid delay              | •     |     |         |      |
|                     | Bussed signals                  | 2     | 11  | ns      |      |
|                     | Point to point signals          | 2     | 12  | ns      | 1    |
| t <sub>203</sub>    | Input setup time                | •     |     |         |      |
|                     | Bussed signals                  | 7     |     | ns      |      |
|                     | Point to point signals          | 10    |     | ns      | 2    |
| t <sub>204</sub>    | Input hold time                 | 0     |     | ns      |      |
| t <sub>205</sub>    | P1_REQ64# to P1_RST# setup time |       |     |         |      |
|                     | Adapter scenario                | 10    |     | PB_CLKs | 3    |
|                     | Host scenario                   | 10    |     | PB_CLKs | 4    |
| t <sub>206</sub>    | P1_RST# to P1_REQ64# hold time  |       |     |         |      |
|                     | Adapter scenario                | 2.3   |     | ns      | 3    |
|                     | Host scenario                   | 0     | 50  | ns      | 4    |
| t <sub>207</sub>    | Reset to float                  |       | 40  | ns      |      |

Table 198: PCI 33 MHz Timing Parameters

1. This group of point to point signals include: P1\_REQ[1]#, P2\_REQ[1]#, P1\_GNT[4:1]#, P2\_GNT[4:1]#, and PCI\_GNT[7:5]#.

2. This group of point to point signals include: P1\_GNT[1]#, P2\_GNT[1]#, P1\_REQ[4:1]#, P2\_REQ[4:1]#, and PCI\_REQ[7:5]#.

3. In the adapter scenario, an external agent controls both P1\_REQ64# and P1\_RST#.

4. In the host scenario, PowerSpan II controls both P1\_REQ64# and P1\_RST#.

Each PowerSpan II PCI interface can be configured for 66 MHz operating frequencies by ensuring that the pin Px\_M66EN is connected to logic one. Table 199 summarizes the timing behavior of a PowerSpan II PCI interface configured in this way. This table is valid for operation in a 3V signaling environment.

| Timina              |                                 | CE/IE |     |         |      |
|---------------------|---------------------------------|-------|-----|---------|------|
| Timing<br>Parameter | Description                     | Min   | Max | Units   | Note |
| t <sub>200</sub>    | Float to active delay           | 1     |     | ns      |      |
| t <sub>201</sub>    | Active to float delay           |       | 14  | ns      |      |
| t <sub>202</sub>    | Signal valid delay              | -     |     |         |      |
|                     | Bussed signals                  | 1     | 6.0 | ns      |      |
|                     | Point to point signals          | 1     | 6.0 | ns      | 1    |
| t <sub>203</sub>    | Input setup time                |       |     |         |      |
|                     | Bussed signals                  | 3.0   |     | ns      |      |
|                     | Point to point signals          | 5     |     | ns      | 2    |
| t <sub>204</sub>    | Input hold time                 | 0     |     | ns      |      |
| t <sub>205</sub>    | P1_REQ64# to P1_RST# setup time |       |     |         |      |
|                     | Adapter scenario                | 10    |     | PB_CLKs | 3    |
|                     | Host scenario                   | 10    |     | PB_CLKs | 4    |
| t <sub>206</sub>    | P1_RST# to P1_REQ64# hold time  |       |     |         |      |
|                     | Adapter scenario                | 2.3   |     | ns      | 3    |
|                     | Host scenario                   | 0     | 50  | ns      | 4    |
| t <sub>207</sub>    | Reset to float                  |       | 40  | ns      |      |

Table 199: PCI 66 MHz Timing Parameters

1. This group of point to point signals include: P1\_REQ[1]#, P2\_REQ[1]#, P1\_GNT[4:1]#, P2\_GNT[4:1]#, and PCI\_GNT[7:5]#.

2. This group of point to point signals include: P1\_GNT[1]#, P2\_GNT[1]#, P1\_REQ[4:1]#, P2\_REQ[4:1]#, and PCI\_REQ[7:5]#.

3. In the adapter scenario, an external agent controls both P1\_REQ64# and P1\_RST#.

4. In the host scenario, PowerSpan II controls both P1\_REQ64# and P1\_RST#.

| Table 2 | 00: PB | Timing | Parameters |
|---------|--------|--------|------------|
|---------|--------|--------|------------|

| Timing              |                              | CE  | E/IE |       |      |
|---------------------|------------------------------|-----|------|-------|------|
| Timing<br>Parameter | Description                  | Min | Max  | Units | Note |
| t <sub>302</sub>    | PB_CLK to output valid delay | -   |      |       |      |
|                     | Parameter group outputs      | 1.0 | 5.0  | ns    | 1,2  |
|                     | Control group outputs        | 1.0 | 5.0  | ns    | 1,3  |
|                     | PB_ARTRY_                    | 1.0 | 5.0  | ns    | 1    |
|                     | Arbitration group outputs    | 1.0 | 5.0  | ns    | 1, 4 |
| t <sub>303</sub>    | Input setup time             |     |      |       |      |
|                     | Bussed signals               | 3.0 |      | ns    |      |
|                     | PB_AP                        | 2.0 |      | ns    |      |
|                     | Point to point signals       | 3.0 |      | ns    | 5    |
|                     | PB_BG[1]_                    | 3.5 |      | ns    |      |
| t <sub>304</sub>    | Input hold time              | _   |      |       |      |
|                     | PB_DBG[1]_                   | 0.2 |      | ns    |      |
|                     | All other inputs             | 0.3 |      | ns    |      |

1. Numbers measured into lumped 35 pF load.

2. The transaction parameter group of signals includes: PB\_A[0:31], PB\_AP[0:3], PB\_TSIZ[0:3], PB\_TT[0:4], PB\_TBST\_, PB\_GBL\_, PB\_CI\_, PB\_D[0:63], PB\_DP[0:7].

3. The transaction control group of signals includes: PB\_TS\_, PB\_ABB\_, PB\_DBB\_, PB\_TA\_, PB\_DVA\_L, PB\_TEA\_, PB\_AACK\_.

4. The transaction arbitration group outputs includes: PB\_BR[1]\_, PB\_BG[1:3]\_, PB\_DBG[1:3]\_

5. The point to point signals include: PB\_BR[1:3]\_, and PB\_DBG[1]\_

| Timing                  |                            | CE   | E/IE |         |      |
|-------------------------|----------------------------|------|------|---------|------|
| Parameter               | Description                | Min  | Max  | Units   | Note |
| Interrupt Tim           | ing                        |      |      |         |      |
| t <sub>400</sub>        | Float to active delay      | 2    | 15   | ns      | 1    |
| t <sub>401</sub>        | Active to float delay      | 2    | 15   | ns      | 1    |
| t <sub>402</sub>        | Input setup time           | 3    |      | ns      | 2    |
| t <sub>403</sub>        | Input hold time            | 0.5  |      | ns      | 2    |
| t <sub>404</sub>        | Pulse width                | 4    |      | PB_CLKs | 3    |
| I <sup>2</sup> C Timing |                            |      |      |         |      |
| t <sub>410</sub>        | I2C_SCLK period            | 1024 | 1024 | PB_CLKs |      |
| t <sub>411</sub>        | I2C_SCLK high time         | 512  | 512  | PB_CLKs |      |
| t <sub>412</sub>        | I2C_SCLK low time          | 512  | 512  | PB_CLKs |      |
| t <sub>413</sub>        | STOP condition setup time  | 512  | 512  | PB_CLKs |      |
| t <sub>414</sub>        | Bus free time              | 512  |      | PB_CLKs |      |
| t <sub>415</sub>        | START condition setup time | 1024 |      | PB_CLKs |      |
| t <sub>416</sub>        | START condition hold time  | 512  | 512  | PB_CLKs |      |
| t <sub>417</sub>        | Data output valid time     | 256  | 256  | PB_CLKs |      |
| t <sub>418</sub>        | Data output hold time      | 256  | 256  | PB_CLKs |      |
| t <sub>419</sub>        | Data sample time           | 256  | 256  | PB_CLKs |      |

#### **Table 201: Miscellaneous Timing Parameters**

1. Numbers measured into 35 pF load.

2. PowerSpan II synchronizes these inputs before using them. This parameter must be met for deterministic response time.

3. PowerSpan II filters these inputs to ensure spurious low going pulses are not recognized as active interrupts. An interrupt pin is considered valid if three PB\_CLK samples yield the same result.

# C.4 Timing Diagrams

The timing diagrams in this section apply to both the Single PCI PowerSpan II and the Dual PCI PowerSpan II.





Notes:

- 1. P1\_RST# configured as input
- 2. PB\_RST\_ and P2\_RST# configured as output
- 3. If JTAG is not used, the TRST\_ signal can be pulled low through a resistor (~2.5 KOhm).



Figure 33: Power-up Options: Multiplexed System Pin Approach





Notes:

- 1. The power-up options latched by the MPC8260 Configuration Slave mode take precedence over those latched by the Multiplexed System Pins mode.
- 2. The MPC8260 configuration master runs configuration cycles as part of each HRESET\_ sequence.



# **E. Typical Applications**

This chapter describes typical applications for PowerSpan II as well as PowerPC direct connection to PowerSpan II. The following topics are discussed:

- "PowerSpan II and the Processor Bus" on page 481
- "CompactPCI Adapter Card" on page 483
- "CompactPCI Host Card" on page 485

# E.1 Overview

Motorola's family of embedded PowerPC processors are widely used in the deployment of communications products. The introduction of the MPC8260, with its unsurpassed levels of integration and performance, enhances the role of PowerPC in communications systems. PowerSpan II has a general purpose Processor Bus (PB) Interface to Motorola's PowerPC embedded processor family, which enables the design of PCI based communication products.

This section highlights the use of PowerSpan II in PowerPC and CompactPCI applications.

# E.2 PowerSpan II and the Processor Bus

The PowerSpan II PB Interface provides direct connect support for a number of PowerPC embedded processors. The block diagram in Figure 45 illustrates a system where the PowerSpan II and the MPC8260 and MPC740 are directly connected.

The MPC740 is a 64-bit bus master in this system. It can only interact with agents that have a 64-bit port size. Since the MPC740 does not generate the extended transaction types of the MPC8260, it needs to be configured to meet MPC8260 constraints.



Figure 45: PowerSpan II in Multi-processor 60x system

The MPC8260 is the system memory controller being used in this application in order to manage 64-bit wide SDRAM. The MPC8260 has processor bus master and slave capability. As a bus master in this system it can access SDRAM and PCI. The address latch and multiplexor allow the external processor bus agents, the MPC740, and PowerSpan II to access MPC8260 controlled memory. Additionally, the MPC740 and PowerSpan II can program MPC8260 registers and master the MPC8260 local bus.

Figure 45 illustrates the system where PowerSpan II provides the following support:

Processor bus

Address and data bus arbitration

Processor bus Master/Slave capability

- Single or dual PCI access
- Four channel DMA

The PowerSpan II PB Interface fully supports the multi processing cache coherent aspects of the processor bus. The PowerSpan II PB Interface can only interact with 64-bit port size agents.

The presence of the MPC740 limits the extent of extended cycle support in the system depicted in Figure 45.



The SIZ[0] pin is hardwired on PowerSpan II and the MPC8260. PowerSpan II must operate with extended cycles disabled. It is still possible for the MPC8260 bus master to target SDRAM with extended cycles.

The PowerSpan II processor bus arbiter controls system boot. Boot can be selected from PCI by configuring the arbiter at power-up to ignore all external requests on Bus Request (PB\_BR[3:1]\_). This allows an external PCI master to configure the MPC8260 memory controller and load system boot code before enabling recognition of requests on PB\_BR[3:1]\_.

Alternatively, at power-up the processor bus arbiter is configured to recognize requests on PB\_BR[1]\_ and ignore requests on PB\_BR[3:2]\_. In this case the processor connected to PB\_BR[1]\_ enables recognition of requests from other masters when its system configuration tasks are complete.

# E.3 CompactPCI Adapter Card

A common PowerSpan II application is the support of MPC8260 based CompactPCI adapter cards. These cards are installed in peripheral slots of the CompactPCI chassis.

In Figure 46 PowerSpan II is in a dual MPC8260 application. One processor is selected to be the Configuration master (RSTCONF\_ is tied low) while the second processor, and PowerSpan II, are configuration slaves.

Optionally, the second processor could have the PowerPC core disabled and be used strictly to provide more serial interface capability.

PowerSpan II's PCI-1 Interface is designated as the Primary Interface, through power-up option, and is connected to the CompactPCI backplane. It is possible to designate either PCI-1 or PCI-2 as the Primary Interface with a power-up option. The backplane supplies reset, clock and central resource functionality. The Secondary PCI Interface, PCI- 2, connects to a secondary PCI system on the card and provides reset and arbitration for the secondary bus.





All PowerSpan II resources are reset when PO\_RST\_ is asserted by the card's power on reset logic. PB\_RST\_ and P2\_RST# are configured as outputs and are asserted during the power on reset sequence (PO\_RST\_) or during a CompactPCI reset (P1\_RST#). The connection between PowerSpan II PB\_RST\_ and MPC8260 HRESET\_is required for PowerSpan II to load its power-up options during Configuration activity generated by the Configuration master.

The adapter card has two basic configuration scenarios — MPC8260 system boots from local FLASH or from PCI.

When the MPC8260 system boots from local FLASH there are two possible scenarios which can occur. In the first case, after reset, PowerSpan II retries all accesses to its Primary PCI target. The MPC8260 configures the PowerSpan II Primary and Secondary Base Address Registers and then configures all agents on the Secondary bus. The MPC8260 then enables accesses to the PowerSpan II Primary PCI target. The CompactPCI Host then completes the configuration of all Primary PCI agents.

In the second scenario, an agent on the PCI secondary bus configures all agents there. The PowerSpan II Secondary PCI target retries all accesses until the MPC8260 completed configuration of PowerSpan II Secondary Base Address Registers.



PowerSpan II supports system boot from PCI with the processor bus arbiter.

# **E.4**

# **CompactPCI Host Card**

PowerSpan II supports the MPC8260 as a Host in a CompactPCI system. The application illustration, Figure 47, shows a directly connected PowerSpan II in a MPC8260 system, which is supported by the MPC740.

PowerSpan II has reset and arbitration functionality for the Primary and Secondary PCI bus segments. PB\_RST\_ is configured as an input while both P1\_RST# and P2\_RST# are outputs. A processor power-on reset or hard reset resets both Primary and Secondary PCI bus segments.

The card provides clocks for the embedded PowerPCs, PowerSpan II's PB Interface, all secondary PCI agents, as well as the multiple clocks required for the CompactPCI backplane.

PowerSpan II's bidirectional interrupt pins are used to handle all four CompactPCI interrupts and the Hot Swap system enumeration interrupt. All interrupts are routed to the MPC740 through PowerSpan II pin INT[5]\_.

The MPC8260 system boots from local FLASH on the card. The MPC8260 uses PowerSpan II to configure all PCI agents on the Primary and Secondary PCI buses.

EEPROM MPC8260 (master) MPC8260 F (slave) MPC740 **CLOCKGENERATOR and PLL** Flash RSTCONF RSTCONF PORESET HRESET PORESET HRFSFT HRESET SYSCLK CLKIN CLKIN A[0:6] Ł <sup>5</sup>ower on Reset A[0] 33MHZ 33MHZ 66MHZ 66MHZ A[1] #∀1NI #LNÐ ыео# сгк ← PO\_RST PB\_RST PB\_RST\_DIR PB\_RSTCONF <u>INT[5]</u>-HEALTHY -PB\_CLK Agents ь5-сгк ► #T2A PowerSpan ATNI\_S , D 2\_GNT[2] Secondary #ATNI P2\_REQ[2] P2\_GNT[1] ► #1N9 DIR вео# P2\_REQ[1] СГК ← ВЗЦ<sup>#</sup> ← S FOR P1\_RST\_ INT[4] P1\_INTA P1\_RST PI\_CLK TSA\_SS <u>INT[0]</u> INT[1] INT[2] INT[3] P2\_RST\_DIR Compact PCI P1/11 INLD# INLC# #8TNI #∀⊥NI Compact PCI Peripheral Slots ŧ REQ# -GNT# -ENUM# -INTA# -RST# CLK REQ# GNT# INTA# RST# CLK REQ64# RST# CLK REQ64# REQ# GNT# INTA# RST# CLK REQ# GNT# INTA# ENUM# Peripheral Slot 4 Peripheral Slot 5 Peripheral Slot 3 Peripheral Slot 2

Figure 47: PowerSpan II in CompactPCI System Slot



# Glossary

| ATPG                  | Automatic Test Pattern Generation.                                                                                                                                            |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BAR                   | Base Address Register.                                                                                                                                                        |
| BD                    | Buffer Descriptor. Each serial port in the MPC8260 uses BDs to indicate to the SDMA channel the location of packet data in system memory.                                     |
| Big-endian            | A byte ordering method in memory where the address of a word corresponds to the most significant byte.                                                                        |
| BIST                  | Built-in Self Test.                                                                                                                                                           |
| CompactPCI            | CompactPCI is an adaptation of the PCI Specification for Industrial and/or<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.                                                                                          |
| DDM                   | Device Driver Module. A module that abstracts the service of an I/O device and registers it as an I2O Device.                                                                 |
| Device                | An I/O object that refers to an I/O facility or service. Adapters are the objects of hardware configuration, while logical devices are the objects of software configuration. |
| DMA                   | Direct Memory Access. A process for transferring data from main memory to a device without passing it through the Host processor.                                             |
| DRAM                  | Dynamic Random Access Memory.                                                                                                                                                 |
| Dual PCI PowerSpan II | PowerSpan II variant with dual PCI interfaces.                                                                                                                                |

| FLASH                 | Writable non-volatile memory, often used to store code in embedded systems.                                                                                                                                                                                                         |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Host Node             | A node composed of one or more application processors and their associated resources. Host nodes execute a single homogeneous operating system and are dedicated to processing applications. The host node is responsible for configuring and initializing the IOP into the system. |
| Host Operating System | The control program executing on the host. This may be the BIOS code, the host bootstrap code, or the final operating system for application programs. Also called the host or OS.                                                                                                  |
| Hot Swap              | Refers to the orderly insertion and extraction of CompactPCI boards without adversely affecting system operation.                                                                                                                                                                   |
| 12C                   | Inter-IC Bus                                                                                                                                                                                                                                                                        |
| 120                   | Intelligent I/O                                                                                                                                                                                                                                                                     |
| Inbound Queue         | A message queue of a particular I/O platform that receives messages from any sender (host or another IOP).                                                                                                                                                                          |
| ЮР                    | I/O platform. A platform consisting of processor, memory, I/O adapters and I/O devices. They are managed independently from other processors within the system, solely for processing I/O transactions.                                                                             |
| Little-endian         | A byte ordering method in memory where the address of a word corresponds to the least significant byte                                                                                                                                                                              |
| Master                | Master (initiator) is the owner of the PCI bus. It is used for both the processor (60x) bus and the PCI bus.                                                                                                                                                                        |
| MF                    | Message Frame                                                                                                                                                                                                                                                                       |
| MFA                   | Message Frame Address                                                                                                                                                                                                                                                               |
| MPC8260               | Motorola Integrated Communications Controller with 603ev PowerPC core and external bus                                                                                                                                                                                              |
| Outbound Queue        | A message queue for a specific I/O platform for posting messages to the local host, in lieu of the host's Inbound Queue.                                                                                                                                                            |
| PowerPC 740           | Embedded PowerPC processor.                                                                                                                                                                                                                                                         |
| PowerPC 750           | Embedded PowerPC processor.                                                                                                                                                                                                                                                         |

| PowerPC 7400                            | Embedded PowerPC processor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prefetchable                            | A range of <i>Memory</i> space is prefetchable if there are no side effects on reads.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Peripheral Slot                         | Slots on a CompactPCI bus segment that may contain simple boards, intelligent slaves, or PCI bus masters.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| РМС                                     | PCI Mezzanine Card. A mechanical format for adding PCI based mezzanine cards to a VMEbus card.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Primary PCI Interface                   | Adds extra functionality to the PCI Interface that is designated as the Primary PCI Interface.The features are associated with the Primary PCI Interface include: CompactPCI Hot Swap Support, Vital Product Data support and I <sub>2</sub> O Shell Interface.                                                                                                                                                                                                                                                                                                                 |
| SDMA                                    | Serial DMA. Used to support the movement of serial data to/from the serial ports of the MPC8260.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Secondary PCI Interfac                  | <b>e</b> In the Dual PCI PowerSpan II, this interface is the interface that is not designated as the Primary PCI Interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Single PCI PowerSpan                    | I PowerSpan II variant with a single PCI interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Single PCI PowerSpan<br>Slave           | <ul><li>I PowerSpan II variant with a single PCI interface.</li><li>Slave (target) is the device which is accessed by the bus master. It is used to refer to the address accessed by the master on the processor (60x) bus.</li></ul>                                                                                                                                                                                                                                                                                                                                           |
|                                         | Slave (target) is the device which is accessed by the bus master. It is used to refer to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Slave                                   | Slave (target) is the device which is accessed by the bus master. It is used to refer to the address accessed by the master on the processor (60x) bus.<br>A memory access model that requires exclusive access to an address before making                                                                                                                                                                                                                                                                                                                                     |
| Slave<br>Strong ordering                | <ul><li>Slave (target) is the device which is accessed by the bus master. It is used to refer to the address accessed by the master on the processor (60x) bus.</li><li>A memory access model that requires exclusive access to an address before making an update, to prevent another device from using stale data.</li><li>The slot on a CompactPCI bus segment that provides arbitration, clock distribution,</li></ul>                                                                                                                                                      |
| Slave<br>Strong ordering<br>System Slot | <ul> <li>Slave (target) is the device which is accessed by the bus master. It is used to refer to the address accessed by the master on the processor (60x) bus.</li> <li>A memory access model that requires exclusive access to an address before making an update, to prevent another device from using stale data.</li> <li>The slot on a CompactPCI bus segment that provides arbitration, clock distribution, and reset functions for all boards on the segment</li> <li>Target (slave) is the device which is accessed by the bus master. It is used to refer</li> </ul> |

# Index

#### **Numerics**

42361 H1 Chapter 14 AC Timing 457

## Α

AD[31:0] 236, 239 Address Bus Arbitration PB arbiter 169 Address Only Cycles 171 Address Parity PB master 126 PB slave 112 PCI target 54 Address Phase PB master 123 PB slave 104 PCI master 62 PCI target 50 Address Pipelining PB master 125 Address Retry Window address bus tenure 110 defined 103 multi-processor environment 124 negating address bus request 124 PB slave terminations 122 Address Tenure PB Slave 109 Address Translation PB master 125 PB slave 110 PCI master 63 PCI target 54 Arbiters PCI 163 system boot 171 Arbitration 163 PB master 123

PCI master 61

# В

BM 60 BM\_PARK[2:0] 168 Bus Errors interrupts 174 PB master 134 PB slave 121 PCI master 66 PCI target 58 Bus Parking PB 123, 169 PCI 168, 169 Bus Request PCI bus 237, 240

## С

C/BE#[3:0] 236, 239 Cache Coherency 124 CHAIN 140 Chip Select 237, 239 Clean Block 108 CLINE[1:0] 65 Clocks **PCI 44 Command Encoding** PCI master 62 PCI target 51 **Command Packet Contents 146** CompactPCI Hot Swap Primary PCI 44 Concurrent Reads 38, 55 **Configuration Cycle Generation** PCI-to-PCI 295 PowerPC-to-PCI 296 Configuration Read 62 Configuration Slave Approach 209 Configuration Write 62 contact information 5 customer support information 5

## D

D\_PE 58, 65 **DACT 140** Data Alignment PB master 130 PB slave 114 Data Bus Arbitration and Tenure PB master 126 PB slave 113 Data Parity PB master 133 PB slave 120 PCI master 65 PCI target 58 Data Phase PB master 126 PB Slave 113 PCI master 63 design support tools (DST) 5 DEST 56 DEVSEL# 236, 239 Direct Mode DMA initializing 142 terminating 145 transfer acknowledgment 145 Discard Timer 119 DMA command packet addressing 139 command packet contents 146 direct mode 142 error handling 150, 198 interrupts 149 linked-list mode 145 overview 38 register description 138 source and destination addresses 139 transfer control 139 DMA Controllers 137 document conventions 26 document feedback 6 document ordering 6 **DONE 141** DONE EN 141 DST (design support tools) 5 Dual Address Cycle 62

### E

EEPROM 153 overview 38 power-up 154 SCL signal 243 SDA signal 243

vital product data 75, 161 eieio 108 Electrical Characteristics 277, 477 email 6 END 215 Endian Mapping 213 big endian 219 conventions 214 little endian 221 munging/unmunging 217 PowerPC little endian 215, 223 PowerPC to PCI 219 register accesses 215 ENID 242 Error Handling 187 DMA 150, 198 PB Interface 188 PCI interface 192 Error Logging and Interrupts PB master 135 PB slave 122 PCI master 66 PCI target 59 Even Parity PB master 126 EXTCYC 134 Extended Cycles 128

## F

FAQ support database 5 fax support 6 Flush Block 108 FRAME# 236, 239 Frequency PCLK 237, 240 QCLK QUICC 231 QUICC IDMA fast termination 231 Functional Overview 29

# G

GNT# 236, 237, 239 GO 140

# Η

HALT 141 HALT\_EN 141 HALT\_REQ 140 Hot Swap card insertion 68 LED 67

#### 

I/O Read 62 I/O Write 62 I2C / EEPROM Interface 153 I2C\_SCL 154 I20 base address register 77 inbound messages 84 **IOP** functionality 78 messaging interface 79 outbound messages 85 outbound option 90 pull capability 86 I2O Shell Interface Primary PCI 44 IACK Cycle Generation PCI-to-PCI 295 PowerPC-to-PCI 296 icbi 108 IDSEL 237, 239 INT# 237, 239 Interrupt Acknowledge 62 Interrupts 173 **DMA 149** enabling 179 mapping 181 normal operations 174 pins 183 register description 175 sources 173 status 177 transfer exceptions 174 IRDY# 237, 240

# Κ

Kill Block 108

## L

LAST 146 Linked-List Mode DMA initializing 147 terminating 149 LOO 67 lwarx 108

#### Μ

mailing address 6 Master Interface PCI 60 Master-Abort 66 MAX\_RETRY 66, 135 MDP\_D 65 mechanical information 443 Memory Read 62 Memory Read Line 62 Memory Read Multiple 62 Memory Write 62 Memory Write and Invalidate 62 MODE 54 MPC8260 Configuration Slave 209 MRA 57 Munging/Unmunging 217

### Ν

NCP[31:5] 146 Non-transparent PCI-to-PCI 36

### 0

Odd Parity PB master 126 PB slave 121 OFF 140 ordering information 455

### Ρ

P1 ERR 141 P1\_ERR\_EN 141 P1\_R64\_EN 45 P2\_ERR 141 P2\_ERR\_EN 141 packaging information 443 PAR 237, 240 Parity Monitoring and Generation PCI Master 65 **PARK 168 PB** Arbiters address bus arbitration 169 address only cycles 171 data bus arbitration 170 **PB** Interface address phase 104 address retry window 103 bus errors 188 defined 101 overview 37 slave interface 103 terms 103 window of opportunity 103 PB Master address bus arbitration and tenure 123 address parity 126 address phase 123 address pipelining 125 address translation 125

cache coherency 124 data alignment 130 data bus arbitration and tenure 126 data parity 133 data phase 126 terminations 134 transaction length 127 transaction mapping 125 window of opportunity 124 PB Slave address parity 112 address tenure 109 data alignment 114 data parity 120 data phase 113 discard timer 119 errors 122 terminations 121 transaction length 113 writes 120 PB\_ERR 141 PB ERR EN 141 **PCI** Arbiters arbitration levels 165 bus parking 168 disabling 164 enabling 164 overview 163 PCI Interface 43 bus parking 168, 169 clock frequencies 44 data width 45 errors 192 interface descriptions 47 overview 35 target interface 50 PCI Master address phase 62 address translation 63 arbitration 61 command encoding 62 data phase 63 error logging and interrupts 66 parity monitoring and generation 65 termination phase 66 PCI Target address parity 54 address phase 50 address translation 54 command encoding 51 data transfer 55 transaction code mapping 54

PCLK 237, 240 **PERESP 54, 65** PERR# 237, 240 phone support 6 PowerPC PB defined 101 Power-up Options configuration slave approach 209 PWRUP\_P1\_ARB\_EN 207 PWRUP\_P1\_R64\_EN 45 PWRUP\_P2\_ARB\_EN 207 PWRUP\_PB\_ARB\_EN 207 PWRUP\_Px\_ARB\_EN 167 Primary PCI defined 44 PRKEEP 57, 118 Processor Bus Interface 101 Px\_PB\_ERR\_EN 65

## R

RD\_AMT[2:0] 57, 118 Read Atomic 108 Read with intent to modify 108 Read with intent to modify atomic 108 Read with no intent to cache 108 **Register Accesses** endian mapping 215 Register Map 93 Registers DMA x Attributes Register 141 DMA x Command Packet Pointer Register 139 LAST 146 NCP[31:5] 146 DMA x Destination Address Register 139 DMA x General Control and Status Register CHAIN 140 **DACK 140 DONE 141** DONE\_EN 141 GO 140 **HALT 141** HALT EN 141 HALT REQ 140 OFF 140 P1 ERR 141 P1 ERR EN 141 P2 ERR 141 P2 ERR EN 141 **PB ERR 141** PB ERR EN 141 **STOP 141** STOP EN 141

STOP\_REQ 140 DMA x Source Address Register 139 Interrupt Status Register 0 177, 179 Interrupt Status Register 1 177, 179 Miscellaneous Control and Status Register VPD\_EN 75 PCI 1 Compact PCI Hot Swap Control and Status Register LOO 67 PCI 1 Control and Status Register BM 60 D PE 58, 65 MDP D 65 PERESP 54, 58, 65 R MA 66 R\_TA 66 S\_TA 59 SERR\_EN 54 PCI 1 Miscellaneous 0 Register CLINE[1:0] 65 PCI 1 Miscellaneous Control and Status Register MAX\_RETRY 66 PCI 1 Target Image x Base Address Register BAR\_EN 52 BS[3:0] 52 CI\_52 DEST 52 END[1:0] 53 GBL\_ 52 IMG\_EN 52 MODE 52 **MRA 53** PRKEEP 53 RD\_AMT[2:0] 53 RTT[4:0] 52 **TA EN 52** WTT[4:0] 53 PCI 1 Target Image x Control Register DEST 56 **MRA 57** PRKEEP 57 RD\_AMT[2:0] 57 **TA EN 63** PCI 1 Vital Product Data Capability Register 75 PCI 1 Vital Product Data Data Register 75 PCI x Bus Arbiter Control Register BM\_PARK[2:0] 168 Mx\_PRI 167 **PARK 168** PCI x Target Image x Control Register MODE 54

RTT[4:0] 125 WTT[4:0] 125 PCI x to PCI y Configuration Cycle Data Register 295 PCI x to PCI y Configuration Cycle Information Register 295 PCI x to PCI y Interrupt Acknowledge Cycle **Generation Register 295** PCI-1 Control and Status Register **DEV66 44** Processor Bus Miscellaneous Control and Status Register EXTCYC 134 MAX\_RETRY 135 Processor Bus PCI Configuration Cycle Information Register 296 Processor Bus Register Image Base Address Register **END 215** Processor Bus Slave Image x Control Register BS[4:0] 106 **DEST 106** END[1:0] 106 IMG EN 106 **MODE 106** PRKEEP 106, 118 RD\_AMT[2:0] 106, 118 TA\_EN 106 Reset Control and Status Register P1\_R64\_EN 45 related documentation 28 REQ# 237, 240 Reset from PCI bus 238, 240 timing parameters 460, 461, 466, 467 Resets direction control 202 generation 204 pins 201 RST# 238, 240 RTT[4:0] 125

### S

sales support 5 SCL 243 SDA 243 SERR# 238, 240 SERR\_EN 54 Signal Descriptions 227 Signals AACK 103 AD[31:0] 65

ARTRY 103, 124 description 227 ENUM 67 HEALTHY 67, 201 INT[5:0] 183 interrupts 183 LED 67 miscellaneous 242 P1 64EN 45, 67 P1\_INTA 183 P1\_REQ64 45 P1\_RST 45, 202 P1 RST DIR 202 P2\_INTA 183 P2\_RST 202 P2\_RST\_DIR 202 PB\_A[] 104 PB\_AACK 108, 109, 123 **PB\_ABB 123** PB\_ARTRY 109, 110, 121, 123, 127, 134 PB\_BG 125 PB CI 106, 124, 142 **PB\_DBB** 126 PB\_DP[0:7] 121, 134 PB\_DVAL 121, 134 PB\_GBL 106, 124, 142 **PB\_RST 201** PB\_RST\_DIR 202 PB\_TA 121, 134 **PB\_TEA 134** PB\_TS 109, 126 PB\_TT[] 104 PCI-1 236 PCI-2 239 PO\_RST 201 PowerPC (PB) 229 Px\_AD[31:0] 58 Px\_C/BE[3:0] 58, 65 Px\_DEVSEL 66 Px\_FRAME 66 Px\_IRDY 66 Px M66EN 45 Px\_PAR 58, 65 Px PERR 65 Px\_TRDY 66 test 244 SIZ[1:0] 235 Special Cycle 62 **STOP 141** STOP# 236, 237, 238, 240 STOP\_EN 141 STOP\_REQ 140

support information 5 Sync Block 108 System Boot 171

#### Т

Target-Abort 66 Target-Disconnect 55, 66 Target-Retry 66 technical support 6 **Termination Phase** PB master 134 PB slave 121 PCI master 66 PCI target 58 Test Signals 244 tlb invalidate 108 tlb sync 108 Transaction Length PB master 127 PB slave 113 Transaction Mapping PB master 125 PCI master 62 PCI target 54 TRDY# 238, 240, 244, 245 **Typical Applications 481** 

#### V

Vital Product Data defined 75 EEPROM 75 Primary PCI 44 reading 76 writing 76 VPD\_EN 75

### W

webpages 5 website 5 Window of Opportunity 124 defined 103 Write with Flush 54 Write with flush 108 Write with flush atomic 108 Write with flush atomic 108 Write with kill 108 WTT[4:0] 125