

# Intel<sup>®</sup> 80331 I/O Processor

**Developer's Manual** 

October 2003



Information in this document is provided in connection with Intel® products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel's Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel products are not intended for use in medical, life saving, or life sustaining applications.

Intel may make changes to specifications and product descriptions at any time, without notice.

Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.

Intel® internal code names are subject to change.

THIS SPECIFICATION, THE Intel® 80331 I/O Processor IS PROVIDED "AS IS" WITH NO WARRANTIES WHATSOEVER, INCLUDING ANY WARRANTY OF MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR ANY PARTICULAR PURPOSE, OR ANY WARRANTY OTHERWISE ARISING OUT OF ANY PROPOSAL, SPECIFICATION OR SAMPLE.

Intel disclaims all liability, including liability for infringement of any proprietary rights, relating to use of information in this specification. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted herein.

Copyright © Intel Corporation, 2003

AlertVIEW, i960, AnyPoint, AppChoice, BoardWatch, BunnyPeople, CablePort, Celeron, Chips, Commerce Cart, CT Connect, CT Media, Dialogic, DM3, EtherExpress, ETOX, FlashFile, GatherRound, i386, i486, iCat, iCOMP, Insight960, InstantIP, Intel, Intel Iogo, Intel386, Intel486, Intel740, IntelDX2, IntelDX4, IntelSX2, Intel ChatPad, Intel Create&Share, Intel Dot.Station, Intel GigaBlade, Intel Inside, Intel Inside, Intel Inside, Intel NetStructure, Intel Play, Intel Play Iogo, Intel Pocket Concert, Intel SingleDriver, Intel SpeedStep, Intel StrataFlash, Intel TeamStation, Intel WebOutfitter, Intel Xeon, Intel XScale, Itanium, JobAnalyst, LANDesk, LanRover, MCS, MMX, MMX logo, NetPort, NetportExpress, Optimizer logo, OverDrive, Paragon, PC Dads, PC Parents, Pentium, Pentium II Xeon, Pentium III Xeon, Performance at Your Command, ProShare, RemoteExpress, Screamline, Shiva, SmartDie, Solutions960, Sound Mark, StorageExpress, The Computer Inside, The Journey Inside, This Way In, TokenExpress, Trillium, Vivonic, and VTune are trademarks or registered trademarks of Intel Corporation or its subsidiaries in the United States and other countries

\*Other names and brands may be claimed as the property of others.

2 October, 2003 Document Number: 273942-002



| 1 | Intro | duction            |                                                         | 35 |  |
|---|-------|--------------------|---------------------------------------------------------|----|--|
|   | 1.1   | About <sup>1</sup> | About This Document                                     |    |  |
|   |       | 1.1.1              | How To Read This Document                               | 35 |  |
|   |       | 1.1.2              | Other Relevant Documents                                |    |  |
|   | 1.2   | About t            | the Intel <sup>®</sup> 80331 I/O Processor              | 36 |  |
|   | 1.3   | Feature            | es                                                      | 38 |  |
|   |       | 1.3.1              | Intel <sup>®</sup> XScale <sup>™</sup> Core             | 38 |  |
|   |       | 1.3.2              | PCI-to-PCI Bridge Unit                                  |    |  |
|   |       | 1.3.3              | Address Translation Units                               | 39 |  |
|   |       | 1.3.4              | Memory Controller                                       | 39 |  |
|   |       | 1.3.5              | Application Accelerator Unit                            | 39 |  |
|   |       | 1.3.6              | Peripheral Bus Interface                                | 39 |  |
|   |       | 1.3.7              | DMA Controller                                          | 39 |  |
|   |       | 1.3.8              | I <sup>2</sup> C Bus Interface Unit                     | 40 |  |
|   |       | 1.3.9              | Messaging Unit                                          | 40 |  |
|   |       | 1.3.10             | Internal Bus                                            | 40 |  |
|   |       | 1.3.11             | UART Unit                                               | 40 |  |
|   |       | 1.3.12             | Interrupt Controller Unit                               | 40 |  |
|   |       | 1.3.13             | GPIO                                                    | 40 |  |
|   | 1.4   | Termin             | ology and Conventions                                   | 41 |  |
|   |       | 1.4.1              | Representing Numbers                                    | 41 |  |
|   |       | 1.4.2              | Fields                                                  | 41 |  |
|   |       | 1.4.3              | Specifying Bit and Signal Values                        | 41 |  |
|   |       | 1.4.4              | Signal Name Conventions                                 | 42 |  |
|   |       | 1.4.5              | Terminology                                             | 42 |  |
| 2 | PCI-  | to-PCI B           | ridge                                                   | 43 |  |
|   | 2.1   | Introdu            | iction                                                  | 43 |  |
|   |       | 2.1.1              | Product Overview                                        |    |  |
|   |       | 2.1.2              | Features List                                           |    |  |
|   |       | 2.1.3              | Related External Specifications                         |    |  |
|   | 2.2   |                    | peration                                                |    |  |
|   |       | 2.2.1              | RESET                                                   |    |  |
|   |       | 2.2.2              | Pre-Boot Component Initialization                       |    |  |
|   |       | 2.2.3              | Pin Strap Configuration                                 |    |  |
|   |       |                    | 2.2.3.1 Secondary Bus Maximum Allowable Frequency       |    |  |
|   |       |                    | 2.2.3.2 Bridge Disable                                  |    |  |
|   |       |                    | 2.2.3.3 Arbiter and Central Resource                    | 46 |  |
|   |       | 2.2.4              | Bus Mode and Frequency Initialization                   | 46 |  |
|   |       |                    | 2.2.4.1 Primary Bus Mode and Frequency Initialization   | 47 |  |
|   |       |                    | 2.2.4.2 Secondary Bus Mode and Frequency Initialization | 47 |  |
|   |       | 2.2.5              | Private Devices on the Secondary Interface              | 49 |  |
|   |       |                    | 2.2.5.1 Private Type 0 Commands on Secondary Interface  |    |  |
|   |       |                    | 2.2.5.2 Private Memory Space                            |    |  |
|   |       | 2.2.6              | Device Select Timing                                    |    |  |
|   |       | 2.2.7              | 64-Bit Operation                                        |    |  |
|   |       | 2.2.8              | PCI Power Management Support                            | 51 |  |



| 2.2.9    | Overview   | v of Bus Transactions                                  |    |
|----------|------------|--------------------------------------------------------|----|
|          | 2.2.9.1    | PCI-to-PCI                                             | 52 |
|          | 2.2.9.2    | PCI to PCI-X                                           | 53 |
|          | 2.2.9.3    | PCI-X to PCI                                           | 53 |
|          | 2.2.9.4    | PCI-X to PCI-X                                         | 53 |
| 2.2.10   | Bus Inter  | face Data Flow                                         | 54 |
|          | 2.2.10.1   |                                                        |    |
|          |            | 2.2.10.1.1As the PCI Target                            | 54 |
|          |            | 2.2.10.1.2As the PCI-X Target                          |    |
|          |            | 2.2.10.1.3PCI-X Receiving Data                         |    |
|          | 2.2.10.2   |                                                        |    |
|          |            | 2.2.10.2.1As the PCI Master                            |    |
|          |            | 2.2.10.2.2As the PCI-X Master                          |    |
| 2.2.11   | Exclusive  | e Access                                               |    |
|          |            | ional PCI Mode                                         |    |
|          |            | Posted Memory Write Transactions                       |    |
|          |            | Fast Back-to-Back Transactions                         |    |
|          |            | Write Flow-Through                                     |    |
|          |            | Delayed Write Transactions                             |    |
|          | 2.2.12.7   | 2.2.12.4.1Delayed Write Transaction Time-out Errors    | 07 |
|          |            | on the Destination Bus                                 | 57 |
|          |            | 2.2.12.4.2Delayed Write Transaction Time-out Errors    | 07 |
|          |            | on the Origination Bus                                 | 57 |
|          | 2 2 1 2 5  | Read Transactions                                      | 58 |
|          | 2.2.12.0   | 2.2.12.5.1Delayed Read Transactions                    |    |
|          |            | 2.2.12.5.2Non-prefetchable Reads                       |    |
|          |            | 2.2.12.5.3Read Flow Through                            |    |
|          |            | 2.2.12.5.4Prefetching                                  |    |
|          | 2.2.12.6   | Transaction Ordering                                   | 62 |
| 2 2 13   |            | us Mode                                                |    |
|          |            | Attributes                                             |    |
|          |            | Special Notes for Burst Transactions                   |    |
|          |            | Split Transactions                                     |    |
|          | 2.2.10.0   | 2.2.13.3.1Completer Attributes                         | 64 |
|          |            | 2.2.13.3.2Requirements for Accepting Split Completions |    |
|          |            | 2.2.13.3.3Split Completion Messages                    | 64 |
|          | 2.2.13.4   | Transaction Ordering                                   | 65 |
|          |            | Transaction Termination as a PCI-X Target              |    |
|          |            | 2.2.13.5.1Retry                                        |    |
|          |            | 2.2.13.5.2Split Response                               | 66 |
|          |            | 2.2.13.5.2Split Response                               | 66 |
|          | 2.2.13.6   | Bridge Buffer Requirements                             | 66 |
| Arbitrat |            |                                                        |    |
| 2.3.1    |            | on Events                                              |    |
| _        | 2.3.1.1    | Arbitrating in Traffic                                 |    |
|          | 2.3.1.2    | Bus Parking                                            |    |
|          | 2.3.1.3    | Grant Time-Out                                         |    |
| 2.3.2    |            | Insaction Timer (MTT)                                  |    |
| 2.0.2    | 2.3.2.1    | MTT Rules                                              |    |
| 2.3.3    |            | ventional Mode Arbitration                             |    |
|          |            |                                                        |    |
| 2.3.4    |            | bitration                                              |    |
|          | 2.3.4.1    | Fair Internal Arbitration                              | 12 |
| <b>.</b> | 2.3.4.2    | Retry or Disconnected Request                          |    |
| ⊨rror D  | etection a | ind Reporting                                          | 73 |

2.3

2.4



|     | 2.4.1   | Normal C                                    | Operation                                                              | 73              |  |  |  |
|-----|---------|---------------------------------------------|------------------------------------------------------------------------|-----------------|--|--|--|
|     | 2.4.2   | Respons                                     | e Enabled                                                              | 74              |  |  |  |
|     | 2.4.3   |                                             | # Assertion                                                            |                 |  |  |  |
| 2.5 | Prograi |                                             | erface                                                                 |                 |  |  |  |
|     | 2.5.1   | Standard PCI Configuration Header Registers |                                                                        |                 |  |  |  |
|     |         | (Offset 00                                  | 0H-3FH)                                                                | 76              |  |  |  |
|     |         | 2.5.1.1                                     | Identifiers - ID                                                       |                 |  |  |  |
|     |         | 2.5.1.2                                     |                                                                        |                 |  |  |  |
|     |         | 2.5.1.3                                     | Primary Status Register - PSR                                          |                 |  |  |  |
|     |         | 2.5.1.4                                     | Revision ID Register - RID                                             | 82              |  |  |  |
|     |         | 2.5.1.5                                     | Class Code Register - CCR                                              | 83              |  |  |  |
|     |         | 2.5.1.6                                     | Cacheline Size Register - CLSR                                         | 84              |  |  |  |
|     |         | 2.5.1.7                                     | Primary Latency Timer Register - PLTR                                  | 85              |  |  |  |
|     |         | 2.5.1.8                                     | Header Type Register - HTR                                             | 86              |  |  |  |
|     |         | 2.5.1.9                                     | Bus Number Register - BNR                                              |                 |  |  |  |
|     |         | 2.5.1.10                                    | , ,                                                                    |                 |  |  |  |
|     |         |                                             | I/O Base and Limit Register - IOBL                                     |                 |  |  |  |
|     |         |                                             | Secondary Status Register - SSR                                        |                 |  |  |  |
|     |         |                                             | Memory Base and Limit Register - MBL                                   |                 |  |  |  |
|     |         |                                             | Prefetchable Memory Base and Limit Register - PMBL                     |                 |  |  |  |
|     |         |                                             | Prefetchable Memory Base Upper 32 Bits - PMBU32                        |                 |  |  |  |
|     |         |                                             | Prefetchable Memory Limit Upper 32 Bits - PMLU32                       |                 |  |  |  |
|     |         |                                             | I/O Base and Limit Upper 16 Bits - IOBLU16                             |                 |  |  |  |
|     |         |                                             | Capabilities Pointer Register - Cap_Ptr                                |                 |  |  |  |
|     |         | 2.5.1.19                                    | Interrupt Information - INTR                                           | 91              |  |  |  |
|     | 0.5.0   |                                             | Bridge Control Register - BCR                                          |                 |  |  |  |
|     | 2.5.2   |                                             | pecific Registers                                                      |                 |  |  |  |
|     |         | 2.5.2.1                                     | Secondary Arbiter Control/Status Register - SACSR                      |                 |  |  |  |
|     |         | 2.5.2.2                                     | Bridge Control Register 0 - BCR0                                       |                 |  |  |  |
|     |         | 2.5.2.3                                     | Bridge Control Register 1 - BCR1                                       |                 |  |  |  |
|     |         | 2.5.2.4                                     | Bridge Control Register 2 - BCR2                                       |                 |  |  |  |
|     |         | 2.5.2.5                                     | Bridge Status Register - BSR                                           | 107             |  |  |  |
|     |         | 2.5.2.6                                     | Bridge Multi-Transaction Timer Register - BMTTR                        | 108             |  |  |  |
|     |         | 2.5.2.7                                     | Read Prefetch Policy Register - RPPR                                   |                 |  |  |  |
|     |         | 2.5.2.8<br>2.5.2.9                          | P_SERR# Assertion Control - SERR_CTL                                   | <u>/</u><br>115 |  |  |  |
|     |         | 2.5.2.9                                     | Pre-Boot Status Register - PBSRSecondary Decode Enable Register - SDER |                 |  |  |  |
|     |         | 2.5.2.10                                    |                                                                        |                 |  |  |  |
|     | 2.5.3   | -                                           | nded Capabilities List                                                 |                 |  |  |  |
|     | 2.5.5   |                                             |                                                                        |                 |  |  |  |
|     |         | 2.5.3.1                                     | PCI Bus Power Management                                               |                 |  |  |  |
|     |         |                                             | 2.5.3.1.2 Next Item Pointer - PM_NXTP                                  |                 |  |  |  |
|     |         |                                             | 2.5.3.1.3 Power Management Capabilities Register - PMCR                |                 |  |  |  |
|     |         |                                             | 2.5.3.1.4 Power Management Control / Status Register - PMCSR           |                 |  |  |  |
|     |         |                                             | 2.5.3.1.5 Power Management Control / Status PCI-to-PCI Bridge Sup      |                 |  |  |  |
|     |         |                                             | - PMCSR_BSE                                                            |                 |  |  |  |
|     |         |                                             | 2.5.3.1.6 Power Management Data Register - PMDR                        | 12              |  |  |  |
|     |         | 2.5.3.2                                     | PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a.      |                 |  |  |  |
|     |         | 2.0.0.2                                     | 2.5.3.2.1 PCI-X Capabilities Identifier - PX_CAPID                     |                 |  |  |  |
|     |         |                                             | 2.5.3.2.2 Next Item Pointer - PX_NXTP                                  | 127             |  |  |  |
|     |         |                                             | 2.5.3.2.3 PCI-X Secondary Status - PX_SSTS                             | . 128           |  |  |  |
|     |         |                                             | 2.5.3.2.4 PCI-X Bridge Status - PX_BSTS                                |                 |  |  |  |
|     |         |                                             | 2.5.3.2.5 PCI-X Upstream Split Transaction Control - PX_USTC           | . 130           |  |  |  |
|     |         |                                             | 2.5.3.2.6 PCI-X Downstream Split Transaction Control - PX_DSTC         | 131             |  |  |  |
|     |         |                                             |                                                                        | -               |  |  |  |



| 3.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3 | Addr | ess Tra | nslation l           | Jnit                                                         | 133 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|---------|----------------------|--------------------------------------------------------------|-----|
| 3.2. ATU Address Translation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   | 3.1  | Overvi  | ew                   |                                                              | 133 |
| 3.2.1.1 Inbound Address Translation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   | 3.2  |         |                      |                                                              |     |
| 3.2.1.1 Inbound Address Translation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |      | 3.2.1   | Inbound              | Transactions                                                 | 138 |
| 3.2.1.2 Inbound Write Transaction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |      |         |                      |                                                              |     |
| 3.2.1.4   Inbound Configuration Cycle Translation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |      |         | 3.2.1.2              |                                                              |     |
| 3.2.1.5 Discard Timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |      |         | 3.2.1.3              | Inbound Read Transaction                                     | 144 |
| 3.2.2   Outbound Transactions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |      |         | 3.2.1.4              | Inbound Configuration Cycle Translation                      | 147 |
| Internal Bus Transactions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |      |         | 3.2.1.5              | Discard Timers                                               | 148 |
| Internal Bus Transactions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |      | 3.2.2   | Outbour<br>Internal  | nd Transactions- Single Address Cycle (SAC) Bus Transactions | 149 |
| Internal Bus Transactions   150                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |      |         | 3.2.2.1              | Internal Bus Transactions                                    |     |
| (SAC) Transactions.       155         3.2.3 Outbound Write Transaction.       156         3.2.4 Outbound Write Transaction.       157         3.2.5 Outbound Configuration Cycle Translation.       160         3.3 Messaging Unit.       161         3.4 Expansion ROM Translation Unit       162         3.5 ATU Queue Architecture.       163         3.5.1 Inbound Queues       163         3.5.1.1 Inbound Write Queue Structure       163         3.5.1.2 Inbound Read Queue Structure       164         3.5.1.3 Inbound Delayed Write Queue.       165         3.5.1.4 Inbound Transaction Queues Command Translation Summary.       165         3.5.2 Outbound Queues       166         3.5.3 Transaction Ordering       167         3.5.3.1 Transaction Ordering Summary.       170         3.6.1 Private Device Control.       172         3.6.2 Private Memory Space       173         3.7.1 Address and Attribute Parity Errors on the PCI Interface       175         3.7.2 Data Parity Errors on the PCI Interface       176         3.7.2.1.1 Immediate Data Transfer       177         3.7.2.1.2 Split Response Termination       178         3.7.2.2 MSI Outbound Writes that are not MSI (Message Signaled Interrupts)       179         3.7.2.2.1 Inmediate Data Transfer<      |   |      |         | 3.2.2.2              | Internal Bus Transactions                                    |     |
| 3.2.2.4 Outbound DMA Transactions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |      |         | 3.2.2.3              |                                                              | 155 |
| 3.2.4       Outbound Configuration Cycle Translation.       159         3.2.5       Outbound Configuration Cycle Translation.       160         3.3       Messaging Unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |      |         | 3.2.2.4              | Outbound DMA Transactions                                    | 156 |
| 3.2.5       Outbound Configuration Cycle Translation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |      | 3.2.3   | Outbour              | nd Write Transaction                                         | 157 |
| 3.2.5 Outbound Configuration Cycle Translation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |      | 3.2.4   | Outbour              | nd Read Transaction                                          | 159 |
| 3.3       Messaging Unit       161         3.4       Expansion ROM Translation Unit       162         3.5       ATU Queue Architecture       163         3.5.1       Inbound Queues       163         3.5.1.2       Inbound Write Queue Structure       164         3.5.1.3       Inbound Delayed Write Queue       165         3.5.1.4       Inbound Transaction Queues Command Translation Summary       165         3.5.2       Outbound Queues       166         3.5.3       Transaction Ordering       167         3.5.3       Transaction Ordering Summary       170         3.6       Private Device Control       172         3.6.1       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1       Immediate Data Transfer       177         3.7.2.2.2       Outbound Writes that are not MSI (Message Signaled Interrupts)       178         3.7.2.2.1       Outbound Read Completions Data Parity Errors       181         3                                                                        |   |      | 3.2.5   |                      |                                                              |     |
| 3.4       Expansion ROM Translation Unit       162         3.5       ATU Queue Architecture       163         3.5.1       Inbound Queues       163         3.5.1.2       Inbound Write Queue Structure       164         3.5.1.3       Inbound Pead Queue Structure       164         3.5.1.4       Inbound Delayed Write Queue       165         3.5.2       Outbound Queues       166         3.5.3       Transaction Ordering       167         3.5.3.1       Transaction Ordering Summary       170         3.6       Private Device Control       172         3.6.1       Private Type 0 Commands on the Secondary Interface       172         3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.2       Split Response Termination       178         3.7.2.2.1       Outbound Write Request Data Parity Errors       179         3.7.2.2.2       MSI Outbound Writes that are not MSI       179         3.7.2.2.3 <td></td> <td>3.3</td> <td>Messa</td> <td></td> <td></td> <td></td>        |   | 3.3  | Messa   |                      |                                                              |     |
| 3.5       ATU Queue Architecture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   | 3.4  |         |                      |                                                              |     |
| 3.5.1.1 Inbound Write Queue Structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   | 3.5  | •       |                      |                                                              |     |
| 3.5.1.1 Inbound Write Queue Structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |      | 3.5.1   | Inbound              | Queues                                                       | 163 |
| 3.5.1.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |      |         |                      |                                                              |     |
| 3.5.1.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |      |         | 3.5.1.2              |                                                              |     |
| 3.5.1.4   Inbound Transaction Queues Command Translation Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |      |         | 3.5.1.3              |                                                              |     |
| 3.5.3       Transaction Ordering Summary       170         3.6       Private Device Control       172         3.6.1       Private Type 0 Commands on the Secondary Interface       172         3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.2       Split Response Termination       178         3.7.2.2.1       Outbound Write Request Data Parity Errors       179         3.7.2.2.1       Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2       MSI Outbound Writes       180         3.7.2.3       Inbound Read Completions Data Parity Errors       181         3.7.2.4       Inbound Configuration Write Completion Message Data Parity Errors 181         3.7.2.5       Inbound Read Request Data Parity Errors       181         3.7.2.5.1       Immediate Data Transfer       181         3.7.2.5.2       Split Response Termination       181         3.7.2.6       Inbound Write Request Data Parity Errors       181     <       |   |      |         | 3.5.1.4              | Inbound Transaction Queues Command Translation Summary       | 165 |
| 3.5.3.1   Transaction Ordering Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |      | 3.5.2   | Outbour              | nd Queues                                                    | 166 |
| 3.6       Private Device Control       172         3.6.1       Private Type 0 Commands on the Secondary Interface       172         3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.2       Split Response Termination       178         3.7.2.2.1       Outbound Write Request Data Parity Errors       179         3.7.2.2.1       Outbound Writes that are not MSI (Message Signaled Interrupts)       179         3.7.2.2.2       MSI Outbound Writes       180         3.7.2.3       Inbound Read Completions Data Parity Errors       181         3.7.2.4       Inbound Configuration Write Completion Message Data Parity Errors 181       181         3.7.2.5.1       Immediate Data Transfer       181         3.7.2.5.2       Split Response Termination       181         3.7.2.5.2       Split Response Termination       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.7       Outbound Read Completion Data Parity Errors       182<  |   |      | 3.5.3   | Transac              | tion Ordering                                                | 167 |
| 3.6.1       Private Type 0 Commands on the Secondary Interface       172         3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1 Immediate Data Transfer       177         3.7.2.2.2 Split Response Termination       178         3.7.2.2.1 Outbound Write Request Data Parity Errors       179         3.7.2.2.1 Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2 MSI Outbound Writes       180         3.7.2.3       Inbound Read Completions Data Parity Errors       181         3.7.2.4       Inbound Configuration Write Completion Message Data Parity Errors 181       181         3.7.2.5       Inbound Read Request Data Parity Errors       181         3.7.2.5.1 Immediate Data Transfer       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.6       Inbound Read Completion Data Parity Errors       181         3.7.2.7       Outbound Read Completion Data Parity Errors       182 |   |      |         | 3.5.3.1              | Transaction Ordering Summary                                 | 170 |
| 3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1       Immediate Data Transfer       179         3.7.2.2.2       Outbound Write Request Data Parity Errors       179         3.7.2.2.1       Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2       MSI Outbound Writes       180         3.7.2.3       Inbound Read Completions Data Parity Errors       181         3.7.2.4       Inbound Configuration Write Completion Message Data Parity Errors 181       3.7.2.5         3.7.2.5.1       Immediate Data Transfer       181         3.7.2.5.2       Split Response Termination       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.7       Outbound Read Completion Data Parity Errors       182                                                                                                                    |   | 3.6  | Private | Device C             | Control                                                      | 172 |
| 3.6.2       Private Memory Space       173         3.7       ATU Error Conditions       174         3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1       Immediate Data Transfer       179         3.7.2.2.2       Outbound Write Request Data Parity Errors       179         3.7.2.2.1       Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2       MSI Outbound Writes       180         3.7.2.3       Inbound Read Completions Data Parity Errors       181         3.7.2.4       Inbound Configuration Write Completion Message Data Parity Errors 181       3.7.2.5         3.7.2.5.1       Immediate Data Transfer       181         3.7.2.5.2       Split Response Termination       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.6       Inbound Write Request Data Parity Errors       181         3.7.2.7       Outbound Read Completion Data Parity Errors       182                                                                                                                    |   |      | 3.6.1   | Private <sup>-</sup> | Type 0 Commands on the Secondary Interface                   | 172 |
| 3.7       ATU Error Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |      | 3.6.2   |                      |                                                              |     |
| 3.7.1       Address and Attribute Parity Errors on the PCI Interface       175         3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1 Immediate Data Transfer       178         3.7.2.2       Outbound Write Request Data Parity Errors       179         3.7.2.2.1 Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2 MSI Outbound Writes       180         3.7.2.3 Inbound Read Completions Data Parity Errors       181         3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors 181         3.7.2.5 Inbound Read Request Data Parity Errors       181         3.7.2.5.1 Immediate Data Transfer       181         3.7.2.5.2 Split Response Termination       181         3.7.2.6 Inbound Write Request Data Parity Errors       181         3.7.2.7 Outbound Read Completion Data Parity Errors       182                                                                                                                                                                                                                                                                                                     |   | 3.7  | ATU E   |                      |                                                              |     |
| 3.7.2       Data Parity Errors on the PCI Interface       176         3.7.2.1       Outbound Read Request Data Parity Errors       177         3.7.2.1.1 Immediate Data Transfer       177         3.7.2.1.2 Split Response Termination       178         3.7.2.2.2 Outbound Write Request Data Parity Errors       179         3.7.2.2.1 Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2 MSI Outbound Writes       180         3.7.2.3 Inbound Read Completions Data Parity Errors       181         3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors 181       3.7.2.5 Inbound Read Request Data Parity Errors       181         3.7.2.5.1 Immediate Data Transfer       181         3.7.2.5.2 Split Response Termination       181         3.7.2.6 Inbound Write Request Data Parity Errors       181         3.7.2.7 Outbound Read Completion Data Parity Errors       182                                                                                                                                                                                                                                                                                                                                           |   |      | 3.7.1   | Address              | and Attribute Parity Errors on the PCI Interface             | 175 |
| 3.7.2.1       Outbound Read Request Data Parity Errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |      | 3.7.2   |                      | · · · · · · · · · · · · · · · · · · ·                        |     |
| 3.7.2.1.1 Immediate Data Transfer       177         3.7.2.1.2 Split Response Termination       178         3.7.2.2 Outbound Write Request Data Parity Errors       179         3.7.2.2.1 Outbound Writes that are not MSI       179         (Message Signaled Interrupts)       179         3.7.2.2.2 MSI Outbound Writes       180         3.7.2.3 Inbound Read Completions Data Parity Errors       181         3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors 181       181         3.7.2.5 Inbound Read Request Data Parity Errors       181         3.7.2.5.1 Immediate Data Transfer       181         3.7.2.5 Split Response Termination       181         3.7.2.6 Inbound Write Request Data Parity Errors       181         3.7.2.7 Outbound Read Completion Data Parity Errors       182                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |      |         |                      |                                                              |     |
| 3.7.2.1.2 Split Response Termination       178         3.7.2.2.1 Outbound Write Request Data Parity Errors       179         3.7.2.2.1 Outbound Writes that are not MSI       (Message Signaled Interrupts)       179         3.7.2.2.2 MSI Outbound Writes       180         3.7.2.3 Inbound Read Completions Data Parity Errors       181         3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors 181         3.7.2.5 Inbound Read Request Data Parity Errors       181         3.7.2.5.1 Immediate Data Transfer       181         3.7.2.5.2 Split Response Termination       181         3.7.2.6 Inbound Write Request Data Parity Errors       181         3.7.2.7 Outbound Read Completion Data Parity Errors       182                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |      |         |                      |                                                              |     |
| 3.7.2.2.1 Outbound Writes that are not MSI (Message Signaled Interrupts)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |      |         |                      |                                                              |     |
| (Message Signaled Interrupts)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |      |         | 3.7.2.2              | Outbound Write Request Data Parity Errors                    | 179 |
| 3.7.2.22 MSI Outbound Writes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |      |         |                      |                                                              |     |
| 3.7.2.3 Inbound Read Completions Data Parity Errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |      |         |                      | (Message Signaled Interrupts)                                | 179 |
| 3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors 181 3.7.2.5 Inbound Read Request Data Parity Errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |      |         |                      |                                                              |     |
| 3.7.2.5 Inbound Read Request Data Parity Errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |      |         |                      |                                                              |     |
| 3.7.2.5.1 Immediate Data Transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |      |         | -                    |                                                              |     |
| 3.7.2.5.2 Split Response Termination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |      |         | 3.7.2.5              |                                                              |     |
| 3.7.2.6 Inbound Write Request Data Parity Errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |      |         |                      |                                                              |     |
| 3.7.2.7 Outbound Read Completion Data Parity Errors182                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |      |         | 3726                 |                                                              |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |      |         |                      |                                                              |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |      |         |                      |                                                              |     |



|      |          | 3.7.2.9     | Inbound Configuration Write Request              |     |
|------|----------|-------------|--------------------------------------------------|-----|
|      |          |             | 3.7.2.9.1 Conventional PCI Mode                  | 184 |
|      |          |             | 3.7.2.9.2 PCI-X Mode                             | 185 |
|      |          | 3.7.2.10    | Split Completion Messages                        | 186 |
|      | 3.7.3    | Master A    | Aborts on the PCI Interface                      | 187 |
|      |          | 3.7.3.1     | Master Aborts for Outbound Read or Write Request |     |
|      |          | 3.7.3.2     | Inbound Read Completion or Inbound               |     |
|      |          |             | Configuration Write Completion Message           | 188 |
|      |          | 3.7.3.3     | Master-Aborts Signaled by the ATU as a Target    | 188 |
|      |          |             | 3.7.3.3.1 Address Parity Errors                  | 188 |
|      |          |             | 3.7.3.3.2 Internal Bus Master-Abort              |     |
|      | 3.7.4    | Target A    | Aborts on the PCI Interface                      |     |
|      |          | 3.7.4.1     | Target Aborts for Outbound Read Request          |     |
|      |          | 0.7.4.1     | or Outbound Write Request                        | 180 |
|      |          | 3.7.4.2     | Inbound Read Completion or Inbound               |     |
|      |          | 0.7.1.2     | Configuration Write Completion Message           | 190 |
|      |          | 3.7.4.3     | Target-Aborts Signaled by the ATU as a Target    | 190 |
|      |          | 0.7.1.0     | 3.7.4.3.1 Internal Bus Master Abort              | 190 |
|      |          |             | 3.7.4.3.2 Internal Bus Target Abort              |     |
|      |          |             | 3.7.4.3.3 Inbound EROM Memory Write              |     |
|      | 3.7.5    | Corrupte    | ed or Unexpected Split Completions               |     |
|      | 5.7.5    | 3.7.5.1     | Completer Address                                |     |
|      |          | 3.7.5.1     | Completer Address                                | 101 |
|      | 0.7.0    |             |                                                  |     |
|      | 3.7.6    |             | Assertion and Detection                          |     |
|      | 3.7.7    |             | Bus Error Conditions                             |     |
|      |          | 3.7.7.1     | Master Abort on the Internal Bus                 |     |
|      |          |             | 3.7.7.1.1 Inbound Write Request                  |     |
|      |          | 0770        | 3.7.7.1.2 Inbound Read Request                   |     |
|      |          | 3.7.7.2     | Target Abort on the Internal Bus                 |     |
|      |          |             | 3.7.7.2.1 Conventional Mode                      |     |
|      |          |             | 3.7.7.2.2 PCI-X Mode                             |     |
|      | 3.7.8    |             | or Summary                                       |     |
| 3.8  |          |             | ed Interrupts                                    |     |
| 3.9  | Vital Pr |             | ta                                               |     |
|      | 3.9.1    | Configu     | ring Vital Product Data Operation                | 201 |
|      | 3.9.2    | Accessi     | ng Vital Product Data                            | 202 |
|      |          | 3.9.2.1     | Reading Vital Product Data                       | 202 |
|      |          | 3.9.2.2     | Writing Vital Product Data                       | 203 |
| 3.10 | Registe  | er Definiti | ons                                              |     |
|      |          |             | ndor ID Register - ATUVID                        |     |
|      |          |             | vice ID Register - ATUDID                        |     |
|      |          |             | mmand Register - ATUCMD                          |     |
|      |          |             | atus Register - ATUSR                            |     |
|      |          |             |                                                  |     |
|      |          |             | vision ID Register - ATURID                      |     |
|      |          |             | ass Code Register - ATUCCR                       |     |
|      |          |             | cheline Size Register - ATUCLSR                  |     |
|      |          |             | tency Timer Register - ATULT                     |     |
|      |          |             | ader Type Register - ATUHTR                      |     |
|      | 3.10.10  | ATU BIS     | ST Register - ATUBISTR                           | 222 |
|      | 3.10.11  | Inbound     | ATU Base Address Register 0 - IABAR0             | 223 |
|      |          |             | ATU Upper Base Address Register 0 - IAUBAR0      |     |
|      |          |             | ATU Base Address Register 1 - IABAR1             |     |



| 3.10.14 Inbound ATU Upper Base Address Register 1 - IAUBAR1        | 226    |
|--------------------------------------------------------------------|--------|
| 3.10.15 Inbound ATU Base Address Register 2 - IABAR2               |        |
| 3.10.16 Inbound ATU Upper Base Address Register 2 - IAUBAR2        |        |
| 3.10.17 ATU Subsystem Vendor ID Register - ASVIR                   |        |
| 3.10.18 ATU Subsystem ID Register - ASIR                           |        |
| 3.10.19 Expansion ROM Base Address Register - ERBAR                |        |
| 3.10.20 ATU Capabilities Pointer Register - ATU_Cap_Ptr            |        |
| 3.10.21 Determining Block Sizes for Base Address Registers         |        |
| 3.10.22 ATU Interrupt Line Register - ATUILR                       |        |
| 3.10.23 ATU Interrupt Pin Register - ATUIPR                        |        |
| 3.10.24 ATU Minimum Grant Register - ATUMGNT                       |        |
| 3.10.25 ATU Maximum Latency Register - ATUMLAT                     |        |
| 3.10.26 Inbound ATU Limit Register 0 - IALR0                       |        |
| 3.10.27 Inbound ATU Translate Value Register 0 - IATVR0            |        |
| 3.10.28 Expansion ROM Limit Register - ERLR                        |        |
| 3.10.29 Expansion ROM Translate Value Register - ERTVR             |        |
| 3.10.30 Inbound ATU Limit Register 1 - IALR1                       |        |
| 3.10.31 Inbound ATU Limit Register 2 - IALR2                       |        |
| 3.10.32 Inbound ATU Translate Value Register 2 - IATVR2            |        |
| 3.10.33 Outbound I/O Window Translate Value Register - OIOWTVR     |        |
| 3.10.34 Outbound Memory Window Translate Value Register 0 - OMWT\  |        |
| 3.10.35 Outbound Upper 32-bit Memory Window                        | /1024/ |
| Translate Value Register 0 - OUMWTVR0                              | 248    |
| 3.10.36 Outbound Memory Window Translate Value Register 1 - OMWT\  |        |
| 3.10.37 Outbound Upper 32-bit Memory Window                        |        |
| Translate Value Register 1 - OUMWTVR1                              | 250    |
| 3.10.38 Outbound Upper 32-bit Direct Window                        |        |
| Translate Value Register - OUDWTVR                                 | 251    |
| 3.10.39 ATU Configuration Register - ATUCR                         | 252    |
| 3.10.40 PCI Configuration and Status Register - PCSR               | 253    |
| 3.10.41 ATU Interrupt Status Register - ATUISR                     | 257    |
| 3.10.42 ATU Interrupt Mask Register - ATUIMR                       | 259    |
| 3.10.43 Inbound ATU Base Address Register 3 - IABAR3               | 261    |
| 3.10.44 Inbound ATU Upper Base Address Register 3 - IAUBAR3        | 262    |
| 3.10.45 Inbound ATU Limit Register 3 - IALR3                       | 263    |
| 3.10.46 Inbound ATU Translate Value Register 3 - IATVR3            | 264    |
| 3.10.47 Outbound Configuration Cycle Address Register - OCCAR      | 265    |
| 3.10.48 Outbound Configuration Cycle Data Register - OCCDR         | 266    |
| 3.10.49 VPD Capability Identifier Register - VPD_CAPID             | 267    |
| 3.10.50 VPD Next Item Pointer Register - VPD_NXTP                  | 268    |
| 3.10.51 VPD Address Register - VPD_AR                              | 269    |
| 3.10.52 VPD Data Register - VPD_DR                                 | 270    |
| 3.10.53 Power Management Capability Identifier Register - PM_CAPID |        |
| 3.10.54 Power Management Next Item Pointer Register - PM_NXTP      |        |
| 3.10.55 Power Management Capabilities Register - PM_CAP            | 273    |
| 3.10.56 Power Management Control/Status Register - PM_CSR          | 274    |
| 3.10.57 MSI Capability Registers                                   | 275    |
| 3.10.58 PCI-X Capability Identifier Register - PX_CAPID            | 276    |
| 3.10.59 PCI-X Next Item Pointer Register - PX_NXTP                 |        |
| 3.10.60 PCI-X Command Register - PX_CMD                            | 278    |
| 3.10.61 PCI-X Status Register - PX_SR                              | 279    |



|   |      | 3.10.62 | 2 PCI Interrupt Routing Select Register - PIRSR         | 281 |
|---|------|---------|---------------------------------------------------------|-----|
|   |      |         | 3 Secondary PCIDrive Strength Control Register - SPDSCR |     |
|   |      |         | 4 Primary PCIDrive Strength Control Register - PPDSCR   |     |
| 4 | Mess | aging U | Init                                                    | 285 |
|   | 4.1  | Overvi  | ew                                                      | 285 |
|   | 4.2  |         | of Operation                                            |     |
|   |      | 4.2.1   | Transaction Ordering                                    |     |
|   | 4.3  | Messa   | ge Registers                                            |     |
|   |      | 4.3.1   | Outbound Messages                                       |     |
|   |      | 4.3.2   | Inbound Messages                                        |     |
|   | 4.4  | Doorbe  | ell Registers                                           |     |
|   |      | 4.4.1   | Outbound Doorbells                                      |     |
|   |      | 4.4.2   | Inbound Doorbells                                       | 291 |
|   | 4.5  | Circula | ır Queues                                               | 292 |
|   |      | 4.5.1   | Inbound Free Queue                                      | 296 |
|   |      | 4.5.2   | Inbound Post Queue                                      | 297 |
|   |      | 4.5.3   | Outbound Post Queue                                     | 298 |
|   |      | 4.5.4   | Outbound Free Queue                                     | 299 |
|   | 4.6  | Index F | Registers                                               | 300 |
|   | 4.7  | Messa   | ging Unit Error Conditions                              | 300 |
|   | 4.8  | Messa   | ge-Signaled Interrupts                                  | 301 |
|   |      | 4.8.1   | Level-Triggered Versus Edge-Triggered Interrupts        | 302 |
|   | 4.9  | Registe | er Definitions                                          | 303 |
|   |      | 4.9.1   | Inbound Message Register - IMRx                         | 304 |
|   |      | 4.9.2   | Outbound Message Register - OMRx                        | 305 |
|   |      | 4.9.3   | Inbound Doorbell Register - IDR                         | 306 |
|   |      | 4.9.4   | Inbound Interrupt Status Register - IISR                | 307 |
|   |      | 4.9.5   | Inbound Interrupt Mask Register - IIMR                  | 308 |
|   |      | 4.9.6   | Outbound Doorbell Register - ODR                        | 309 |
|   |      | 4.9.7   | Outbound Interrupt Status Register - OISR               | 310 |
|   |      | 4.9.8   | Outbound Interrupt Mask Register - OIMR                 | 311 |
|   |      | 4.9.9   | MU Configuration Register - MUCR                        | 312 |
|   |      | 4.9.10  | Queue Base Address Register - QBAR                      | 313 |
|   |      | 4.9.11  | Inbound Free Head Pointer Register - IFHPR              | 314 |
|   |      | 4.9.12  | Inbound Free Tail Pointer Register - IFTPR              | 315 |
|   |      | 4.9.13  | Inbound Post Head Pointer Register - IPHPR              | 316 |
|   |      | 4.9.14  | Inbound Post Tail Pointer Register - IPTPR              | 317 |
|   |      | 4.9.15  | Outbound Free Head Pointer Register - OFHPR             | 318 |
|   |      | 4.9.16  | Outbound Free Tail Pointer Register - OFTPR             | 319 |
|   |      | 4.9.17  | Outbound Post Head Pointer Register - OPHPR             | 320 |
|   |      | 4.9.18  | Outbound Post Tail Pointer Register - OPTPR             | 321 |
|   |      | 4.9.19  | Index Address Register - IAR                            |     |
|   |      | 4.9.20  | MSI Capability Identifier Register - MSI_CAPID          | 323 |
|   |      | 4.9.21  | MSI Next Item Pointer Register - MSI_NXTP               |     |
|   |      | 4.9.22  | MSI Message Control Register - MSI_MCR                  |     |
|   |      | 4.9.23  |                                                         |     |
|   |      | 4.9.24  | <u> </u>                                                |     |
|   |      | 4.9.25  | MSI Message Data Register- MSI_MDR                      |     |
|   | 4.10 | Power/  | /Default Status                                         | 329 |



| Inte | el <sup>®</sup> XScale <sup>™</sup> Core Bus Interface Unit | 331 |
|------|-------------------------------------------------------------|-----|
| 5.1  | Overview                                                    | 331 |
| 5.2  |                                                             |     |
|      | 5.2.1 Functional Blocks                                     |     |
|      | 5.2.1.1 Core Processor Port Address Decode                  | 333 |
|      | 5.2.1.2 Transaction Queues                                  |     |
| 5.3  | Addressing                                                  | 334 |
|      | 5.3.1 Bus Width                                             | 334 |
| 5.4  | Internal Bus Commands                                       | 335 |
| 5.5  | Features                                                    | 336 |
|      | 5.5.1 Multi-Transaction Timer                               |     |
|      | 5.5.2 ATU Accesses                                          | 336 |
| 5.6  | Interrupts and Error Conditions                             | 337 |
|      | 5.6.1 Internal Bus Errors                                   |     |
|      | 5.6.1.1 Internal Bus Master-Abort                           |     |
|      | 5.6.1.2 Internal Bus Target-Abort                           |     |
|      | 5.6.1.3 PCI Master-Abort                                    |     |
|      | 5.6.1.4 PCI Target-Abort                                    |     |
|      | 5.6.1.5 Split Transaction Errors                            |     |
|      | 5.6.2 Core MCU Errors                                       |     |
|      | 5.6.2.1 Multi-bit ECC Error                                 |     |
|      | 5.6.2.2 Invalid Address Region Error                        |     |
| 5.7  |                                                             |     |
|      | 5.7.1 Reset                                                 |     |
| - 0  | 5.7.2 Initialization                                        |     |
| 5.8  | •                                                           |     |
|      | 5.8.1 BIU Status Register - BIUSR                           |     |
|      | 5.8.2 BIU Error Address Register - BEAR                     |     |
|      | 5.8.3 BIU Control Register - BIUCR                          |     |
| DM.  | A Controller Unit                                           |     |
| 6.1  | Overview                                                    |     |
| 6.2  | , ,                                                         |     |
| 6.3  |                                                             |     |
|      | 6.3.1 Chain Descriptors                                     |     |
|      | 6.3.2 Chaining DMA Descriptors                              | 353 |
|      | 6.3.3 Initiating DMA Transfers                              | 354 |
|      | 6.3.4 Scatter Gather DMA Transfers                          |     |
|      | 6.3.5 Synchronizing a Program to Chained Transfers          | 356 |
|      | 6.3.6 Appending to The End of a Chain                       | 357 |
| 6.4  | Data Transfers                                              | 358 |
|      | 6.4.1 PCI-to-Local Memory Transfers                         | 358 |
|      | 6.4.2 Local Memory to PCI Transfers                         | 358 |
|      | 6.4.3 Local Memory to Local Memory DMA                      | 359 |
|      | 6.4.4 Exclusive Access                                      |     |
| 6.5  | Data Queues                                                 | 359 |
| 6.6  | Data Alignment                                              | 360 |
|      | 6.6.1 64-bit Unaligned Data Transfers                       |     |
|      | 6.6.2 64/32-bit Unaligned Data Transfers                    | 361 |
| 6.7  | CRC Generation                                              | 362 |
|      |                                                             |     |



|      | 6.7.1     | CRC Mod      | de Configuration and Operation        | 362 |
|------|-----------|--------------|---------------------------------------|-----|
|      | 6.7.2     | CRC-320      | CAlgorithm                            | 362 |
| 6.8  | Channe    | el Priority. |                                       | 363 |
| 6.9  | Prograi   | mming Mo     | del State Diagram                     | 364 |
| 6.10 | DMA C     | hannel Pro   | ogramming Examples                    | 365 |
|      | 6.10.1    | Software     | DMA Controller Initialization         | 365 |
|      | 6.10.2    | Software     | Start DMA Transfer                    | 365 |
|      | 6.10.3    | Software     | Suspend Channel                       | 366 |
| 6.11 | Interrup  | ots          | ···········                           | 367 |
| 6.12 | Error C   | onditions.   |                                       | 368 |
|      | 6.12.1    | PCI Error    | 'S                                    | 368 |
|      | 6.12.2    | Internal E   | Bus Errors                            | 369 |
| 6.13 | Power-    | up/Default   | Status                                | 370 |
| 6.14 |           |              | ns                                    |     |
|      |           |              | Control Register x - CCRx             |     |
|      |           |              | Status Register x - CSRx              |     |
|      |           |              | or Address Register x - DARx          |     |
|      |           |              | criptor Address Register x - NDARs    |     |
|      |           |              | ess Register x - PADRx                |     |
|      |           |              | er Address Register x - PUADRx        |     |
|      |           |              | dress Register x - LADRx              |     |
|      |           |              | nt Register x - BCRx                  |     |
|      |           |              | or Control Register x - DCRx          |     |
|      | 0.14.5    | •            | PCI Transactions Support              |     |
|      |           |              | • •                                   |     |
| Appl | ication A | Accelerato   | or Unit                               | 381 |
| 7.1  | Overvie   | ewwe         |                                       | 381 |
| 7.2  | Theory    | of Operat    | ion                                   | 382 |
| 7.3  | Hardwa    | are-Assist   | XOR Unit                              | 383 |
|      | 7.3.1     | Data Trai    | nsfer                                 | 383 |
|      | 7.3.2     |              | scriptors                             |     |
|      |           | 7.3.2.1      | Four-Source Descriptor Format         |     |
|      |           | 7.3.2.2      | Eight-Source Descriptor Format        |     |
|      |           | 7.3.2.3      | Sixteen-Source Descriptor Format      |     |
|      |           | 7.3.2.4      | Thirty-two-Source Descriptor Format   | 389 |
|      | 7.3.3     | Descripto    | or Chaining                           | 393 |
| 7.4  | AA Des    | scriptor Pro | ocessing                              | 394 |
|      | 7.4.1     | Scatter G    | ather Transfers                       | 396 |
|      | 7.4.2     |              | nizing a Program to Chained Operation |     |
|      | 7.4.3     |              | ng to The End of a Chain              |     |
| 7.5  | AA Ope    |              |                                       |     |
|      | 7.5.1     |              | eration                               |     |
|      | 7.5.2     |              | ult Buffer Check                      |     |
|      | 7.5.3     |              | Block Fill Operation                  |     |
| 7.6  |           | •            | del State Diagram                     |     |
| 7.7  |           |              | erator Priority                       |     |
| 7.8  |           |              | acking                                |     |
| 7.0  | 7.8.1     |              | aligned Data Transfers                |     |
| 7.9  | _         |              | Application Accelerator               |     |
| ι.5  | _         |              | on Accelerator Initialization         |     |
|      | 7.9.1     | Application  | JII ACCEIEI ALOI IIIILIAIIZALIOII     | 409 |



|   |      | 7.9.2   |                    | d Application Accelerator                                |     |
|---|------|---------|--------------------|----------------------------------------------------------|-----|
|   |      | 7.9.3   | Appendi            | ng Descriptor for XOR Operations                         | 410 |
|   |      | 7.9.4   |                    | ng Descriptor for Memory Block Fill Operations           |     |
|   |      | 7.9.5   |                    | ng Descriptor for Zero Result Buffer Check               |     |
|   | 7.10 | Interru | pts                |                                                          | 412 |
|   | 7.11 | Error C | Conditions         |                                                          | 413 |
|   | 7.12 | Power-  | ·up/Defau          | It Status                                                | 414 |
|   | 7.13 | Registe | er Definition      | ons                                                      | 414 |
|   |      | 7.13.1  | Accelera           | ator Control Register - ACR                              | 415 |
|   |      | 7.13.2  | Accelera           | ator Status Register - ASR                               | 416 |
|   |      | 7.13.3  | Accelera           | ator Descriptor Address Register - ADAR                  | 417 |
|   |      | 7.13.4  | Accelera           | ator Next Descriptor Address Register - ANDAR            | 418 |
|   |      |         |                    | ource Address Register1 - SAR1                           |     |
|   |      |         |                    | Address Register232 - SAR232                             |     |
|   |      | 7.13.7  | Destinat           | ion Address Register - DAR                               | 421 |
|   |      | 7.13.8  | Accelera           | ator Byte Count Register - ABCR                          | 422 |
|   |      |         |                    | ator Descriptor Control Register - ADCR                  |     |
|   |      |         |                    | d Descriptor Control Register 0 - EDCR0                  |     |
|   |      |         |                    | d Descriptor Control Register 1 - EDCR1                  |     |
|   |      |         |                    | d Descriptor Control Register 2 - EDCR2                  |     |
| _ |      |         |                    | ·                                                        |     |
| 8 | Mem  | ory Con | troller            |                                                          | 437 |
|   | 8.1  | Overvi  | ew                 |                                                          | 437 |
|   | 8.2  | Glossa  | ıry                |                                                          | 438 |
|   | 8.3  | Theory  | of Opera           | tion                                                     | 439 |
|   |      | 8.3.1   | Function           | nal Blocks                                               | 439 |
|   |      |         | 8.3.1.1            | Transaction Ports                                        | 440 |
|   |      |         |                    | 8.3.1.1.1 Core Processor Port                            |     |
|   |      |         |                    | 8.3.1.1.2 Internal Bus Port                              |     |
|   |      |         | 8.3.1.2            | Address Decode Blocks                                    |     |
|   |      |         |                    | 8.3.1.2.1 DDR SDRAM Memory Space                         |     |
|   |      |         |                    | 8.3.1.2.2 Memory-Mapped Register Space                   | 441 |
|   |      |         |                    | 8.3.1.2.3 Core Processor Port Address Decode             |     |
|   |      |         | 8.3.1.3            | Memory Transaction Queues                                |     |
|   |      |         | 0.5.1.5            | 8.3.1.3.1 Core Processor Memory Transaction Queue (CMTQ) |     |
|   |      |         |                    | 8.3.1.3.2 Internal Bus Memory Transaction Queue (IBMTQ)  |     |
|   |      |         | 8.3.1.4            | Configuration Registers                                  |     |
|   |      |         | 8.3.1.5            | Refresh Counter                                          |     |
|   |      |         | 8.3.1.6            | Memory Controller Arbiter (MARB)                         |     |
|   |      |         | 8.3.1.7            | DDR SDRAM Control Block                                  | 444 |
|   |      |         |                    | 8.3.1.7.1 Page Control Block                             | 444 |
|   |      |         |                    | 8.3.1.7.2 DDR SDRAM State Machine and Pipeline Queues    |     |
|   |      |         |                    | 8.3.1.7.3 Error Correction Logic                         |     |
|   |      | 8.3.2   |                    | bitration and Configuration                              |     |
|   |      |         | 8.3.2.1            | MCU Port Priority                                        |     |
|   |      |         | 8.3.2.2            | MCU Port Transaction Count                               |     |
|   |      |         | 8.3.2.3            | Core Processor Port Preemption                           |     |
|   |      |         | 8.3.2.4            | Core Port Transaction Ordering                           |     |
|   |      |         | 8.3.2.5<br>8.3.2.6 | IB Port Ordering MCU Port Coherency                      |     |
|   |      | 8.3.3   |                    | PRAM Memory Support                                      |     |
|   |      | 0.3.3   | 8.3.3.1            | DDR SDRAM Interface                                      |     |
|   |      |         | 0.3.3.1            | DDIX SDIXAWI IIILEHAGE                                   | 440 |



| 8.3.3.3 DDR SDRAM Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| 8.3.3.5 Page Hit/Miss Determination 8.3.3.6 On DIMM Termination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
| 8.3.3.6 On DIMM Termination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                        |
| 8.3.3.7 DDR SDRAM Commands 8.3.3.8 DDR SDRAM Initialization 8.3.3.9 DDR SDRAM Mode Programming 8.3.3.10 DDR SDRAM Read Cycle 8.3.3.11 DDR SDRAM Write Cycle 8.3.3.12 DDR SDRAM Refresh Cycle 8.3.4 Error Correction and Detection 8.3.4.1 ECC Generation                                                                                                                                                                                                                                                                                                                             |                                        |
| 8.3.3.8 DDR SDRAM Initialization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                        |
| 8.3.3.9 DDR SDRAM Mode Programming                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 464<br>468<br>471                      |
| 8.3.3.10 DDR SDRAM Read Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 468<br>471                             |
| 8.3.3.11 DDR SDRAM Write Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 471                                    |
| 8.3.3.12 DDR SDRAM Refresh Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                        |
| 8.3.4 Error Correction and Detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ······································ |
| 8.3.4.1 ECC Generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
| 0.5.4.2 LCC Generation for Fartial Writes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                        |
| 8.3.4.3 ECC Checking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                        |
| 8.3.4.4 Scrubbing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                        |
| 8.3.4.4.1 ECC Example Using the H-Matrix                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 485                                    |
| 8.3.4.5 ECC Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                        |
| 8.3.4.6 ECC Testing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                        |
| 8.3.5 Overlapping Memory Regions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                        |
| 8.3.6 DDR SDRAM Clocking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                        |
| 8.4 Power Failure Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                        |
| 8.4.1 Theory of Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                        |
| 8.4.2 Power Failure Sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                        |
| 8.4.2.1 Power Failure Impact on the System                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                        |
| 8.4.2.2 System Assumptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                        |
| 8.4.3 Memory Controller Response to P_RST#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                        |
| 8.4.3.1 External Logic Required for Power Failure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                        |
| 8.4.3.1.1 Assertion of <b>P_RST#</b> During Power I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                        |
| 8.4.3.1.2 Distinguishing Between a Power Up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                        |
| a Power Failure <b>P_RST#</b> Assertion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 102                                    |
| 8.4.3.2 P_RST# Usage Versus I_RST#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 492                                    |
| 8.5 Interrupts/Error Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
| 8.5.1 Single-Bit Error Detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                        |
| 8.5.2 Multi-bit Error Detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                        |
| 9.6 Poost Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                        |
| 8.6 Reset Conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 495                                    |
| 8.7 Register Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 495<br>496                             |
| 8.7 Register Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 495<br>496<br>497                      |
| 8.7 Register Definitions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                        |
| 8.7 Register Definitions  8.7.1 SDRAM Initialization Register - SDIR  8.7.2 SDRAM Control Register 0 - SDCR0  8.7.3 SDRAM Control Register 1 - SDCR1  8.7.4 SDRAM Base Register - SDBR  8.7.5 SDRAM Boundary Register 0 - SBR0  8.7.6 SDRAM Boundary Register 1 - SBR1  8.7.7 SDRAM 32-bit Region Size Register - S32SR  8.7.8 ECC Control Register - ECCR                                                                                                                                                                                                                           |                                        |
| 8.7 Register Definitions  8.7.1 SDRAM Initialization Register - SDIR  8.7.2 SDRAM Control Register 0 - SDCR0  8.7.3 SDRAM Control Register 1 - SDCR1  8.7.4 SDRAM Base Register - SDBR  8.7.5 SDRAM Boundary Register 0 - SBR0  8.7.6 SDRAM Boundary Register 1 - SBR1  8.7.7 SDRAM 32-bit Region Size Register - S32SR  8.7.8 ECC Control Register - ECCR  8.7.9 ECC Log Registers - ELOG0, ELOG1                                                                                                                                                                                   |                                        |
| 8.7 Register Definitions 8.7.1 SDRAM Initialization Register - SDIR 8.7.2 SDRAM Control Register 0 - SDCR0 8.7.3 SDRAM Control Register 1 - SDCR1 8.7.4 SDRAM Base Register - SDBR 8.7.5 SDRAM Boundary Register 0 - SBR0 8.7.6 SDRAM Boundary Register 1 - SBR1 8.7.7 SDRAM 32-bit Region Size Register - S32SR 8.7.8 ECC Control Register - ECCR 8.7.9 ECC Log Registers - ELOG0, ELOG1 8.7.10 ECC Address Registers - ECAR0, ECAR1                                                                                                                                                |                                        |
| 8.7 Register Definitions 8.7.1 SDRAM Initialization Register - SDIR 8.7.2 SDRAM Control Register 0 - SDCR0 8.7.3 SDRAM Control Register 1 - SDCR1 8.7.4 SDRAM Base Register - SDBR 8.7.5 SDRAM Boundary Register 0 - SBR0 8.7.6 SDRAM Boundary Register 1 - SBR1 8.7.7 SDRAM 32-bit Region Size Register - S32SR 8.7.8 ECC Control Register - ECCR 8.7.9 ECC Log Registers - ELOG0, ELOG1 8.7.10 ECC Address Registers - ECAR0, ECAR1 8.7.11 ECC Test Register - ECTST                                                                                                               |                                        |
| 8.7 Register Definitions 8.7.1 SDRAM Initialization Register - SDIR 8.7.2 SDRAM Control Register 0 - SDCR0 8.7.3 SDRAM Control Register 1 - SDCR1 8.7.4 SDRAM Base Register - SDBR 8.7.5 SDRAM Boundary Register 0 - SBR0 8.7.6 SDRAM Boundary Register 1 - SBR1 8.7.7 SDRAM 32-bit Region Size Register - S32SR 8.7.8 ECC Control Register - ECCR 8.7.9 ECC Log Registers - ELOG0, ELOG1 8.7.10 ECC Address Registers - ECAR0, ECAR1                                                                                                                                                |                                        |
| 8.7 Register Definitions 8.7.1 SDRAM Initialization Register - SDIR 8.7.2 SDRAM Control Register 0 - SDCR0 8.7.3 SDRAM Control Register 1 - SDCR1 8.7.4 SDRAM Base Register - SDBR 8.7.5 SDRAM Boundary Register 0 - SBR0 8.7.6 SDRAM Boundary Register 1 - SBR1 8.7.7 SDRAM 32-bit Region Size Register - S32SR 8.7.8 ECC Control Register - ECCR 8.7.9 ECC Log Registers - ELOG0, ELOG1 8.7.10 ECC Address Registers - ECAR0, ECAR1 8.7.11 ECC Test Register - ECTST 8.7.12 Memory Controller Interrupt Status Register - MCISR 8.7.13 MCU Port Transaction Count Register - MPTCR |                                        |
| 8.7 Register Definitions 8.7.1 SDRAM Initialization Register - SDIR 8.7.2 SDRAM Control Register 0 - SDCR0 8.7.3 SDRAM Control Register 1 - SDCR1 8.7.4 SDRAM Base Register - SDBR 8.7.5 SDRAM Boundary Register 0 - SBR0 8.7.6 SDRAM Boundary Register 1 - SBR1 8.7.7 SDRAM 32-bit Region Size Register - S32SR 8.7.8 ECC Control Register - ECCR 8.7.9 ECC Log Registers - ELOG0, ELOG1 8.7.10 ECC Address Registers - ECAR0, ECAR1 8.7.11 ECC Test Register - ECTST 8.7.12 Memory Controller Interrupt Status Register - MCISR                                                    |                                        |



|    |                    |          | DCAL Control and Status Register - DCALCSR       |     |
|----|--------------------|----------|--------------------------------------------------|-----|
|    |                    |          | DCAL Address Register - DCALADDR                 |     |
|    |                    | 8.7.18   | DCAL Data Registers 17:0 - DCALDATA[17:0]        |     |
|    |                    |          | 8.7.18.1 Opcode: EMRS OCD Adjust/Drive Commands  |     |
|    |                    |          | 8.7.18.2 Opcode: Receive Enable Calibration      |     |
|    |                    | 9710     | Receive Enable Delay Register - RCVDLY           |     |
|    |                    |          | Slave Low Mix 0 - SLVLMIX0                       |     |
|    |                    |          | Slave Low Mix 1 - SLVLMIX1                       |     |
|    |                    |          | Slave High Mix 0 - SLVHMIX0                      |     |
|    |                    |          | Slave High Mix 1 - SLVHMIX1                      |     |
|    |                    | 8 7 24   | Slave Length - SLVLEN                            | 526 |
|    |                    |          | Master Mix - MASTMIX                             |     |
|    |                    |          | Master Length - MASTLEN                          |     |
|    |                    |          | DDR Drive Strength Status Register - DDRDSSR     |     |
|    |                    |          | DDR Drive Strength Control Register - DDRDSCR    |     |
|    |                    |          | DDR Miscellaneous Pad Control Register - DDRMPCR |     |
| _  | Davis              |          | -                                                |     |
| 9  |                    |          | us Interface Unit                                |     |
|    | 9.1                |          | ew                                               |     |
|    | 9.2                | •        | eral Bus Signals                                 |     |
|    |                    | 9.2.1    | Address/Data Signal Definitions                  |     |
|    |                    | 9.2.2    | Control/Status Signal Definitions                |     |
|    |                    | 9.2.3    | Bus Width                                        |     |
|    |                    | 9.2.4    | Detailed Signal Descriptions                     |     |
|    |                    | 9.2.5    | Flash Memory Support                             |     |
|    |                    |          | 9.2.5.1 Flash Read Cycle                         |     |
|    | 9.3                | Intel® X | Scale <sup>™</sup> Core PCI Memory Boot Support  |     |
|    | 9.4                |          | er Definitions                                   |     |
|    | 0.1                | 9.4.1    | PBI Control Register - PBCR                      |     |
|    |                    | 9.4.2    | Determining Block Sizes for Memory Windows       |     |
|    |                    | 9.4.3    | PBI Base Address Register 0 - PBBAR0             |     |
|    |                    | 9.4.4    | PBI Limit Register 0 - PBLR0                     |     |
|    |                    | 9.4.5    | PBI Base Address Register 1 - PBBAR1             |     |
|    |                    | 9.4.6    | PBI Limit Register 1 - PBLR1                     |     |
|    |                    | 9.4.7    | PBI Memory-less Boot Registers 2:0 - PMBR[2:0]   |     |
|    |                    | 9.4.8    | PBI Drive Strength Control Register - PBDSCR     |     |
| 10 | I <sup>2</sup> C B | us Inter | face Units                                       | 551 |
|    | 10.1               | Overvie  | ew                                               | 551 |
|    | 10.2               | I2C Inte | erface                                           | 551 |
|    | 10.3               | Theory   | of Operation                                     | 552 |
|    |                    | 10.3.1   | Operational Blocks                               | 553 |
|    |                    | 10.3.2   | I <sup>2</sup> C Bus Interface Modes             | 555 |
|    |                    | 10.3.3   | Start and Stop Bus States                        | 556 |
|    |                    |          | 10.3.3.1 START Condition                         |     |
|    |                    |          | 10.3.3.2 No START or STOP Condition              |     |
|    | 40:                | 120 -    | 10.3.3.3 STOP Condition                          |     |
|    | 10.4               |          | s Operation                                      |     |
|    |                    | 10.4.1   | Serial Clock Line (SCL) Generation               | 558 |



|    |      | 10.4.2 | Data and Addressing Management                           | 559 |
|----|------|--------|----------------------------------------------------------|-----|
|    |      |        | 10.4.2.1 Addressing a Slave Device                       |     |
|    |      | 10.4.3 | I <sup>2</sup> C Acknowledge                             | 561 |
|    |      | 10.4.4 | Arbitration                                              | 562 |
|    |      |        | 10.4.4.1 SCL Arbitration                                 |     |
|    |      |        | 10.4.4.2 <b>SDA</b> Arbitration                          |     |
|    |      |        | Master Operations                                        |     |
|    |      |        | Slave Operations                                         |     |
|    |      |        | General Call Address                                     |     |
|    | 10.5 |        | Mode Programming Examples                                |     |
|    |      |        | Initialize Unit                                          |     |
|    |      |        | Write 1 Byte as a Slave                                  |     |
|    |      |        | Read 2 Bytes as a Slave                                  |     |
|    | 10.6 |        | Programming Examples                                     |     |
|    |      |        | Initialize Unit                                          |     |
|    |      |        | Write 1 Byte as a Master                                 |     |
|    |      |        | Read 1 Byte as a Master                                  |     |
|    |      |        | Write 2 Bytes and Repeated Start Read 1 Byte as a Master |     |
|    |      |        | Read 2 Bytes as a Master - Send STOP Using the Abort     |     |
|    | 10.7 |        | Suppression Logic                                        |     |
|    | 10.8 |        | Conditions                                               |     |
|    | 10.9 |        | er Definitions                                           |     |
|    |      |        | I <sup>2</sup> C Control Register x - ICRx               |     |
|    |      |        | I <sup>2</sup> C Status Register x - ISRx                |     |
|    |      |        | I <sup>2</sup> C Slave Address Register x - ISARx        |     |
|    |      |        | I <sup>2</sup> C Data Buffer Register x - IDBRx          |     |
|    |      | 10.9.5 | I <sup>2</sup> C Bus Monitor Register x - IBMRx          | 582 |
| 11 | UAR  | Гs     |                                                          | 583 |
|    | 11.1 |        | ew                                                       |     |
|    | 11.1 |        | Compatibility with 16550 and 16750                       |     |
|    | 11.2 |        | Descriptions                                             |     |
|    | 11.2 |        | of Operation                                             |     |
|    | 11.3 |        |                                                          |     |
|    |      | 11.3.1 | FIFO Interrupt Mode Operation                            |     |
|    |      |        | 11.3.1.2 Transmit Interrupt                              |     |
|    |      | 11 2 2 | Removing Trailing Bytes In Interrupt Mode                |     |
|    |      | 11.3.2 | 11.3.2.1 Character Timeout Interrupt                     |     |
|    |      | 11 2 2 | FIFO Polled Mode Operation                               |     |
|    |      | 11.3.3 | 11.3.3.1 Receive Data Service                            |     |
|    |      |        | 11.3.3.2 Transmit Data Service                           |     |
|    |      | 11 3 / | Autoflow Control                                         |     |
|    |      | 11.5.4 | 11.3.4.1 RTS Autoflow                                    |     |
|    |      |        | 11.3.4.2 CTS Autoflow                                    |     |
|    |      | 11 3 5 | Auto-Baud-Rate Detection                                 |     |
|    |      |        | Manual Baud Rate Selection                               |     |
|    | 11.4 |        | er Descriptions                                          |     |
|    | 11.7 |        | UART x Receive Buffer Register                           |     |
|    |      |        | UART x Transmit Holding Register                         |     |
|    |      |        | UART x Interrupt Enable Register                         |     |
|    |      |        | UART x Interrupt Identification Register                 |     |
|    |      | 11.4.4 | OAN EA HIGHUP INGHUHOAHUH INGYISIGI                      |     |



|    |                    | 11.4.5  | UART x FIFO Control Register                                 | 599 |
|----|--------------------|---------|--------------------------------------------------------------|-----|
|    |                    |         | UART x Line Control Register                                 |     |
|    |                    |         | UART x Modem Control Register                                |     |
|    |                    |         | UART x Line Status Register                                  |     |
|    |                    |         | UART x Modem Status Register                                 |     |
|    |                    |         | UART x Scratchpad Register                                   |     |
|    |                    |         | 1 Divisor Latch Registers                                    |     |
|    |                    |         | 2 UART x FIFO Occupancy Register                             |     |
|    |                    |         | BUART x Auto-Baud Control Register                           |     |
|    |                    |         | 4 UART x Auto-Baud Count Register                            |     |
| 12 | Intel <sup>®</sup> |         | I/O Processor Arbitration Unit                               |     |
|    | 12.1               |         | tion Overview                                                |     |
|    | 12.1               |         | Il Bus Arbiter Overview                                      |     |
|    | 12.2               |         | Theory of Operation                                          |     |
|    |                    | 12.2.1  | 12.2.1.1 Priority Mechanism                                  |     |
|    |                    |         | 12.2.1.1 Priority Mechanism                                  |     |
|    |                    |         | 12.2.1.3 Priority Example with Timee Bus Initiators          |     |
|    |                    |         | 12.2.1.4 Arbitration Signalling Protocol                     |     |
|    |                    |         | 12.2.1.5 Internal Bus Arbitration Parking                    |     |
|    |                    | 12.2.2  | Intel <sup>®</sup> XScale <sup>™</sup> Core Arbitration      | 622 |
|    |                    |         | 12.2.2.1 Multi-Transaction Timers                            | 622 |
|    | 12.3               | Reset ( | Conditions                                                   |     |
|    | 12.4               |         | er Definitions                                               |     |
|    |                    | 12 4 1  | Internal Arbitration Control Register - IACR                 | 624 |
|    |                    |         | Multi-Transaction Timer Register 1 - MTTR1                   |     |
|    |                    | 12.4.3  | Multi-Transaction Timer Register 2 - MTTR2                   | 626 |
| 13 | Intol®             |         | <sup>™</sup> Core and Core Performance Monitoring            |     |
| 13 |                    |         |                                                              |     |
|    | 13.1               |         | evel Overview of Intel <sup>®</sup> XScale <sup>™</sup> Core |     |
|    |                    |         | ARM Compatibility                                            |     |
|    |                    | 13.1.2  | Features                                                     |     |
|    |                    |         | 13.1.2.1 Multiply/ACcumulate (MAC)                           |     |
|    |                    |         | 13.1.2.2 Memory Management                                   |     |
|    |                    |         | 13.1.2.3 Instruction Cache                                   |     |
|    |                    |         | 13.1.2.4 Branch Target Buffer                                |     |
|    | 12.2               | CD14 B  | Registers                                                    |     |
|    | 13.2               | 12 2 1  | Registers 0-3: Performance Monitoring                        | 630 |
|    |                    |         | Register 1: Clock Count Register CCNT                        |     |
|    |                    |         | Register 6: Core Clock Configuration Register CCLKCFG        |     |
|    |                    |         | Registers 8-15: Software Debug                               |     |
|    | 122                |         | S S                                                          |     |
|    | 13.3               |         | Registers                                                    |     |
|    |                    |         | Register 0: ID and Cache Type Registers                      |     |
|    |                    |         | Register 1: Control and Auxiliary Control Registers          |     |
|    |                    |         | Register 2: Translation Table Base Register                  |     |
|    |                    |         | Register 3: Domain Access Control Register                   |     |
|    |                    |         | Register 5: Fault Status Register                            |     |
|    |                    |         | Register 6: Fault Address Register                           |     |
|    |                    |         | Register 7: Cache Functions                                  |     |
|    |                    | 13.3.8  | Register 8: TLB Operations                                   | 642 |



|    |        | 13.3.9 Register 9: Cache Lock Down                           | 642        |
|----|--------|--------------------------------------------------------------|------------|
|    |        | 13.3.10 Register 10: TLB Lock Down                           | 643        |
|    |        | 13.3.11 Register 13: Process ID                              | 644        |
|    |        | 13.3.11.1 The PID Register Affect On Addresses               | 644        |
|    |        | 13.3.12 Register 14: Breakpoint Registers                    |            |
|    |        | 13.3.13 Register 15: Coprocessor Access Register             |            |
|    | 13.4   | Core Performance Monitoring Unit (CPMON)                     |            |
|    |        | 13.4.1 CPMON Overview                                        |            |
|    |        | 13.4.2 Performance Monitoring Events                         |            |
|    |        | 13.4.2.1 Instruction Cache Efficiency Mode                   |            |
|    |        | 13.4.2.2 Data Cache Efficiency Mode                          |            |
|    |        | 13.4.2.3 Instruction Fetch Latency Mode                      |            |
|    |        | 13.4.2.4 Data/Bus Request Buffer Full Mode                   | 650        |
|    |        | 13.4.2.5 Stall/Writeback Statistics                          | 651        |
|    |        | 13.4.2.6 Instruction TLB Efficiency Mode                     |            |
|    |        | 13.4.2.7 Data TLB Efficiency Mode                            |            |
|    |        | 13.4.3 Statistics from Multiple Performance Monitoring Runs  |            |
|    |        | 13.4.4 Examples                                              |            |
|    |        | 13.4.5 CPMON Registers                                       |            |
|    |        | 13.4.5.1 Clock Count Register CCNT                           |            |
|    |        | 13.4.5.2 Performance Count Registers PMNx                    |            |
|    |        | 13.4.5.2.1Extending Count Duration Beyond 32 Bits            |            |
|    |        | 13.4.5.3 Performance Monitor Control Register PMNC           |            |
|    |        | 13.4.5.4 Managing PMNC                                       |            |
|    |        |                                                              |            |
| 14 | Time   | 'S                                                           | 659        |
|    | 14.1   | Timer Operation                                              | 661        |
|    |        | 14.1.1 Basic Programmable Timer Operation                    |            |
|    |        | 14.1.2 Watch Dog Timer Operation                             |            |
|    |        | 14.1.3 Load/Store Access Latency for Timer Registers         |            |
|    | 14.2   | Timer Interrupts                                             |            |
|    | 14.3   | Timer State Diagram                                          |            |
|    | 14.4   | Timer Registers                                              |            |
|    | 14.4   | 14.4.1 Power Up/Reset Initialization                         |            |
|    |        |                                                              |            |
|    |        | 14.4.2 Timer Mode Registers – TMR0:1                         |            |
|    |        | 14.4.2.1 Bit 0 - Terminal Count Status Bit (TMRx.tc)         |            |
|    |        | 14.4.2.2 Bit 1 - Timer Enable (TMRx.enable)                  |            |
|    |        | 14.4.2.3 Bit 2 - Timer Auto Reload Enable (TMRx.reload)      |            |
|    |        | 14.4.2.5 Bits 4, 5 - Timer Input Clock Select (TMRx.csel1:0) | 009<br>033 |
|    |        | 14.4.3 Timer Count Register – TCR0:1                         |            |
|    |        | · · · · · · · · · · · · · · · · · · ·                        |            |
|    |        | 14.4.4 Timer Reload Register – TRR0:1                        |            |
|    |        | 14.4.5 Timer Interrupt Status Register – TISR                |            |
|    |        | 14.4.6 Watch Dog Timer Control Register – WDTCR              |            |
|    | 14.5   | Uncommon TCRX and TRRX Conditions                            | 674        |
| 15 | Interr | upt Controller Unit                                          | 675        |
|    | 15.1   | Overview                                                     | 675        |
|    | 15.2   | Theory of Operation                                          |            |
|    | 10.2   | 15.2.1 Interrupt Controller Unit                             |            |
|    | 15.3   | The Intel® XScale™ Core Exceptions Architecture              |            |
|    | 13.3   |                                                              |            |
|    |        | 15.3.1 CPSR and SPSR                                         | v//        |



|    |       | 15.3.2 The Exception Process                                                 | 677 |
|----|-------|------------------------------------------------------------------------------|-----|
|    |       | 15.3.3 Exception Priorities and Vectors                                      | 678 |
|    |       | 15.3.4 Software Requirements For Exception Handling                          | 678 |
|    |       | 15.3.4.1 Nesting FIQ and IRQ Exceptions                                      | 678 |
|    | 15.4  | Intel® 80331 I/O Processor External Interrupt Interface                      |     |
|    |       | 15.4.1 Interrupt Inputs                                                      |     |
|    |       | 15.4.2 Outbound Interrupts                                                   |     |
|    |       | 15.4.3 Interrupt Routing                                                     |     |
|    | 15.5  | Intel® 80331 I/O Processor Interrupt Controller Unit                         |     |
|    | 13.3  | 15.5.1 Programmer Model                                                      |     |
|    |       | 15.5.1.1 Active Interrupt Source Control and Status                          |     |
|    |       | 15.5.1.2 Prioritization and Vector Generation for Active Interrupt Sources   |     |
|    |       |                                                                              |     |
|    |       | 15.5.2 Operational Blocks                                                    |     |
|    |       | 15.5.3 Intel <sup>®</sup> 80331 I/O Processor: Internal Peripheral Interrupt |     |
|    |       | 15.5.3.1 Normal Interrupt Sources                                            |     |
|    |       | 15.5.3.2 Error Interrupt Sources                                             |     |
|    |       | 15.5.4 High-Priority Interrupt ( <b>HPI#</b> )                               |     |
|    |       | 15.5.5 Timer Interrupts                                                      |     |
|    |       | 15.5.6 Software Interrupts                                                   |     |
|    | 15.6  | Default Status                                                               |     |
|    | 15.7  | Interrupt Control Unit Registers                                             |     |
|    |       | 15.7.1 Interrupt Control Register 0 - INTCTL0                                | 693 |
|    |       | 15.7.2 Interrupt Control Register 1 - INTCTL1                                | 695 |
|    |       | 15.7.3 Interrupt Steering Register 0 - INTSTR0                               |     |
|    |       | 15.7.4 Interrupt Steering Register 1 - INTSTR1                               |     |
|    |       | 15.7.5 IRQ Interrupt Source Register 0 - IINTSRC0                            |     |
|    |       | 15.7.6 IRQ Interrupt Source Register 1 - IINTSRC1                            |     |
|    |       | 15.7.7 FIQ Interrupt Source Register 0 - FINTSRC0                            |     |
|    |       | 15.7.8 FIQ Interrupt Source Register 1 - FINTSRC1                            |     |
|    |       | 15.7.9 Interrupt Priority Register 0 - IPR0                                  |     |
|    |       |                                                                              |     |
|    |       | 15.7.10 Interrupt Priority Register 1 - IPR1                                 |     |
|    |       | 15.7.11 Interrupt Priority Register 2 - IPR2                                 |     |
|    |       | 15.7.12 Interrupt Priority Register 3 - IPR3                                 |     |
|    |       | 15.7.13 Interrupt Base Register - INTBASE                                    |     |
|    |       | 15.7.14 Interrupt Size Register - INTSIZE                                    | 714 |
|    |       | 15.7.15 IRQ Interrupt Vector Register - IINTVEC                              | 715 |
|    |       | 15.7.16 FIQ Interrupt Vector Register - FINTVEC                              |     |
|    |       | 15.7.17 PCI Interrupt Routing Select Register - PIRSR                        | 717 |
| 16 | Genei | al Purpose I/O Unit                                                          | 719 |
|    | 16.1  | General Purpose Input Output Support                                         | 719 |
|    | 10.1  | 16.1.1 General Purpose Inputs                                                |     |
|    |       | 16.1.2 General Purpose Outputs                                               |     |
|    |       | 16.1.3 Reset Initialization of General Purpose Input Output Function         |     |
|    |       |                                                                              |     |
|    | 400   | 16.1.4 GPIO Pin Multiplexing                                                 |     |
|    | 16.2  | Register Definitions                                                         |     |
|    |       | 16.2.1 GPIO Output Enable Register - GPOE                                    |     |
|    |       | 16.2.2 GPIO Input Data Register - GPID                                       |     |
|    |       | 16.2.3 GPIO Output Data Register - GPOD                                      | 724 |



| 17 | Perip | heral Registers                                                              | 725 |
|----|-------|------------------------------------------------------------------------------|-----|
|    | 17.1  | Overview                                                                     | 725 |
|    | 17.2  | Accessing the PCI Configuration Registers                                    |     |
|    | 17.3  | Accessing Peripheral Memory-Mapped Registers                                 |     |
|    | 17.4  | Accessing Peripheral Registers Using the Core Coprocessor Register Interface |     |
|    | 17.5  | Architecturally Reserved Memory Space                                        |     |
|    | 17.6  | PCI Configuration Register Address Space                                     |     |
|    | 17.7  | Peripheral Memory-Mapped Register Address Space                              |     |
|    | 17.8  | Coprocessor Register Space                                                   |     |
| 18 | Cloc  | king and Reset                                                               | 749 |
|    | 18.1  | Clocking Overview                                                            | 749 |
|    |       | 18.1.1 Clocking Theory of Operation                                          |     |
|    |       | 18.1.2 Clocking Region 1                                                     |     |
|    |       | 18.1.3 Clocking Region 2                                                     |     |
|    |       | 18.1.4 Clocking Region 3                                                     |     |
|    |       | 18.1.5 Clocking Region 4                                                     |     |
|    |       | 18.1.6 Clocking Region 5                                                     |     |
|    |       | 18.1.7 Clocking Region 6                                                     |     |
|    |       | 18.1.8 Output Clocks                                                         |     |
|    |       | 18.1.9 Clocking Region Summary                                               |     |
|    | 18.2  | Reset Overview                                                               |     |
|    |       | 18.2.1 Primary PCI Bus Reset Mechanism                                       |     |
|    |       | 18.2.2 Software PCI Reset Mechanism                                          |     |
|    |       | 18.2.3 I/O Processor Reset                                                   |     |
|    |       | 18.2.4 Internal Bus Reset                                                    |     |
|    |       | 18.2.5 Intel <sup>®</sup> XScale <sup>™</sup> core Reset Mechanism           | 761 |
|    |       | 18.2.6 Reset Summary                                                         | 761 |
|    | 18.3  | Reset Strapping Options                                                      |     |
| 40 |       | Logic Unit and Testability                                                   |     |
| 19 |       | ·                                                                            |     |
|    | 19.1  | Overview                                                                     |     |
|    | 19.2  | Test Control/Observe Pins                                                    |     |
|    | 19.3  | IEEE 1149.1 Standard Test Access Port (TAP)                                  |     |
|    |       | 19.3.1 TAP Pin Description                                                   |     |
|    |       | 19.3.1.1 Test Clock ( <b>TCK</b> )                                           |     |
|    |       | 19.3.1.2 Test Mode Select ( <b>TMS</b> )                                     |     |
|    |       | 19.3.1.3 Test Data Input (TDI)                                               |     |
|    |       | 19.3.1.5 Asynchronous Reset (TRST#)                                          |     |
|    |       | 19.3.2 TAP Controller                                                        |     |
|    |       | 19.3.2.1 Test-Logic-Reset State                                              |     |
|    |       | 19.3.2.2 Run-Test/Idle State                                                 |     |
|    |       | 19.3.2.3 Select-DR-Scan State                                                |     |
|    |       | 19.3.2.4 Capture-DR State                                                    |     |
|    |       | 19.3.2.5 Shift-DR State                                                      |     |
|    |       | 19.3.2.6 Exit1-DR State                                                      |     |
|    |       | 19.3.2.7 Pause-DR State                                                      |     |
|    |       | 19.3.2.8 Exit2-DR State                                                      |     |
|    |       | 19.3.2.9 Update-DR State                                                     |     |
|    |       | 19.3.2.10 Select-IR-Scan State                                               | 771 |



|        | 19.3.2.11 | 1 Capture-IR State             | 772 |
|--------|-----------|--------------------------------|-----|
|        | 19.3.2.12 | 2 Shift-IR State               | 772 |
|        |           | B Exit1-IR State               |     |
|        |           | Pause-IR State                 |     |
|        | 19.3.2.15 | 5 Exit2-IR State               | 772 |
|        |           | S Update-IR State              |     |
| 19.3.3 |           | troller Configuration          |     |
|        |           | ntroller Registers             |     |
|        | 19.3.4.1  | Instruction Register           | 775 |
|        |           | Instructions                   |     |
|        |           | 19.3.4.2.1High-Z               |     |
|        | 19.3.4.3  | Boundary-Scan Register         |     |
|        | 19.3.4.4  | Bypass Register                | 778 |
|        |           | Device Identification Register |     |



#### **Figures**

| 1        | Intel® 80331 I/O Processor Functional Block Diagram                   | 37         |
|----------|-----------------------------------------------------------------------|------------|
| 2        | Secondary IDSEL Example                                               |            |
| 3        | Arbitration Events                                                    |            |
| 4        | Multi-Transaction Timer Operation                                     |            |
| 5        | Two-Tiered Round Robin Rotating Scheme                                |            |
| 6        | PCI-X Priority Rings                                                  |            |
| 7        | ATU Block Diagram                                                     |            |
| 8        | ATU Queue Architecture Block Diagram                                  |            |
| 9        | Inbound Address Detection                                             |            |
| 10       | Inbound Translation Example                                           |            |
| 11       | Internal Bus Memory Map                                               |            |
| 12       | Outbound Address Translation Windows                                  |            |
| 13       | Direct Addressing Window                                              | 155        |
| 14       | Private Device Example                                                | 173        |
| 15       | ATU Interface Configuration Header Format                             | 204        |
| 16       | ATU Interface Extended Configuration Header Format (Power Management) | 205        |
| 17       | ATU Interface Extended Configuration Header Format (MSI Capability)   | 205        |
| 18       | ATU Interface Extended Configuration Header Format (PCI-X Capability) | 205        |
| 19       | ATU Interface Extended Configuration Header Format (VPD Capability)   |            |
| 20       | PCI Memory Map                                                        | 287        |
| 21       | Internal Bus Memory Map                                               |            |
| 22       | Overview of Circular Queue Operation                                  |            |
| 23       | Circular Queue Operation                                              |            |
| 24       | Intel® 80331 I/O Processor BIU and MCU Architecture                   |            |
| 25       | DDR SDRAM 64-bit Memory Address Map                                   |            |
| 26       | DMA Controller                                                        |            |
| 27       | DMA Channel Block Diagram                                             |            |
| 28       | DMA Chain Descriptor                                                  |            |
| 29       | DMA Chaining Operation                                                |            |
| 30       | Example of Gather Chaining                                            |            |
| 31       | Synchronizing to Chained Transfers                                    |            |
| 32       | Optimization of an Unaligned DMA                                      |            |
| 33       | Optimization of an Unaligned DMA                                      |            |
| 34       | CRC-32C Generator Polynomial                                          |            |
| 35       | DMA Programming Model State Diagram                                   |            |
| 36       | Software Example for Channel Initialization                           |            |
| 37       | Software Example for PCI-to-Local DMA Transfer                        |            |
| 38       | Software Example for Local Memory-to-Local Memory DMA Transfer        |            |
| 39       | Software Example for Channel Suspend                                  |            |
| 40       | Application Accelerator Block Diagram                                 |            |
| 41       | Chain Descriptor Format                                               |            |
| 42       | Chain Descriptor Format for Eight Source Addresses (XOR Function)     |            |
| 43       | Chain Descriptor Format for Sixteen Source Addresses (XOR Function)   |            |
| 44<br>45 | XOR Chaining Operation                                                |            |
| 46       | Example of Gather Chaining for Four Source Blocks                     |            |
| 47       | Synchronizing to Chained AA Operation                                 |            |
| 48       | The Bit-wise XOR Algorithm                                            |            |
| 40       | Hardware Assist YOP Unit                                              | 400<br>101 |



| 50 | An example of Zero Result Buffer Check                                        | 403 |
|----|-------------------------------------------------------------------------------|-----|
| 51 | Example of a Memory Block Fill Operation                                      | 404 |
| 52 | Application Accelerator Programming Model State Diagram                       | 405 |
| 53 | Optimization of an Unaligned Data Transfer                                    | 407 |
| 54 | Pseudo Code: Application Accelerator Initialization                           | 409 |
| 55 | Pseudo Code: Application Accelerator Chain Resume Initialization              | 409 |
| 56 | Pseudo Code: Suspend Application Accelerator                                  | 409 |
| 57 | Pseudo Code: XOR Transfer Operation                                           |     |
| 58 | Pseudo Code: Memory Block Fill Operation                                      |     |
| 59 | Pseudo Code: Zero Result Buffer Check Operation                               |     |
| 60 | Memory Controller Block Diagram                                               |     |
| 61 | Dual-Bank DDR SDRAM Memory Subsystem                                          |     |
| 62 | DDR SDRAM 64-bit Memory Address Map                                           | 454 |
| 63 | FDDR SDRAM 64-bit Physical Map                                                | 454 |
| 64 | Logical Memory Image of a DDR SDRAM Memory Subsystem                          |     |
| 65 | Supported DDR SDRAM Extended Mode Register Settings                           |     |
| 66 | Supported DDR-II SDRAM Extended Mode Register Settings                        |     |
| 67 | Supported DDR SDRAM Mode Register Settings                                    |     |
| 68 | DDR SDRAM Initialization Sequence (controlled with software)                  | 463 |
| 69 | MCU Active, Precharge, Refresh Command Timing Diagram                         |     |
| 70 | MCU DDR Read Command to Next Command Timing Diagram                           |     |
| 71 | MCU DDR Write Command to Next Command Timing Diagrams                         |     |
| 72 | DDR SDRAM Pipelined Reads                                                     |     |
| 73 | DDR SDRAM Read, 36 Bytes, ECC Enabled, BL=4                                   |     |
| 74 | DDR SDRAM Write, 36 Bytes, ECC Enabled, BL=4                                  |     |
| 75 | DDR SDRAM Pipelined Writes                                                    |     |
| 76 | Refresh While the Memory Bus is Not Busy                                      |     |
| 77 | ECC Write Flow                                                                |     |
| 78 | Intel® 80331 I/O Processor G-Matrix (generates the ECC)                       |     |
| 79 | Sub 64-bit DDR SDRAM Write (D <sub>0</sub> )                                  | 480 |
| 80 | ECC Read Data Flow                                                            |     |
| 81 | Intel® 80331 I/O Processor H-Matrix (indicates the single-bit error location) | 483 |
| 82 | Power Failure Sequence                                                        |     |
| 83 | Power Failure State Machine                                                   | 490 |
| 84 | Power Failure Sequence                                                        | 491 |
| 85 | The Peripheral Bus Interface Unit                                             | 533 |
| 86 | Data Width and Low Order Address Lines                                        | 536 |
| 87 | Four Mbyte Flash Memory System                                                | 538 |
| 88 | 120 ns Flash Read Cycle                                                       |     |
| 89 | 120 ns Flash Write Cycle                                                      |     |
| 90 | I <sup>2</sup> C Bus Configuration Example                                    | 552 |
| 91 | I <sup>2</sup> C Bus Interface Unit Block Diagram                             |     |
| 92 | Start and Stop Conditions                                                     |     |
| 93 | START and STOP Conditions                                                     |     |
| 94 | Data Format of First Byte in Master Transaction                               | 560 |
| 95 | Acknowledge on the I <sup>2</sup> C Bus                                       |     |
| 96 | Clock Synchronization During the Arbitration Procedure                        |     |
| 97 | Arbitration Procedure of Two Masters                                          | 563 |
| 98 | Master-Receiver Read from Slave-Transmitter                                   |     |
| 99 | Master-Receiver Read from Slave-Transmitter / Repeated Start                  |     |



|     | / Master-Transmitter Write to Slave-Receiver                                            | 567 |
|-----|-----------------------------------------------------------------------------------------|-----|
| 100 | A Complete Data Transfer                                                                | 567 |
| 101 | Master-Transmitter Write to Slave-Receiver                                              | 569 |
| 102 | Master-Receiver Read to Slave-Transmitter                                               | 569 |
| 103 | Master-Receiver Read to Slave-Transmitter / Repeated START                              |     |
|     | / Master-Transmitter Write to Slave-Receiver                                            | 569 |
|     | General Call Address                                                                    |     |
|     | Example UART Data Frame                                                                 |     |
|     | NRZ Bit Encoding Example – (0100 1011)                                                  |     |
| 107 | Intel® 80331 I/O Processor Arbitration Block Diagram                                    | 615 |
|     | Arbitration Example                                                                     |     |
|     | Arbitration Between Three Initiators                                                    |     |
|     | Intel <sup>®</sup> XScale <sup>™</sup> Core Back-to-Back Transactions with MTT1 Enabled |     |
| 111 | The Intel <sup>®</sup> XScale <sup>™</sup> Core Architecture Features                   | 628 |
| 112 | Programmable Timer Functional Diagram                                                   | 659 |
|     | Timer Unit State Diagram                                                                |     |
|     | Interrupt Controller Block Diagram (Active Interrupt Source Registers)                  |     |
|     | Interrupt Controller Block Diagram (FIQ/IRQ Interrupt Vector Generation)                |     |
| 116 | Intel® 80331 I/O Processor Interrupt Controller Connections                             | 686 |
|     | Memory Address Space                                                                    |     |
|     | Intel® 80331 I/O Processor Clocking Regions Diagram                                     |     |
|     | Intel® 80331 I/O Processor Reset Block Diagram                                          |     |
| 120 | IEEE 1149.1 Standard. Block Diagram                                                     | 766 |
| 121 | Timing of Actions in a TAP Controller State                                             | 768 |
| 122 | TAP Controller State Diagram                                                            | 769 |
| 123 | TAP Controller Configuration                                                            | 774 |
| 124 | Device ID Register                                                                      | 779 |



#### **Tables**

| 1        | Terminology                                               | 42  |
|----------|-----------------------------------------------------------|-----|
| 2        | PCI-to-PCI Bridge Configurations                          | 43  |
| 3        | Features List                                             | 44  |
| 4        | Reset Behavior Summary                                    | 45  |
| 5        | Device Mode/Frequency Capability Reporting                | 47  |
| 6        | Secondary Bus Frequency Initialization                    |     |
| 7        | PCI-X Initialization Pattern                              |     |
| 8        | Public/Private PCI Memory IDSEL Select Configurations     |     |
| 9        | DEVSEL# Timing                                            |     |
| 10       | Bus Terms Description                                     |     |
| 11       | Target Termination Returns                                |     |
| 12       | Prefetch Data Length                                      |     |
| 13       | Read Command Prefetch Size                                |     |
| 14       | Read Line Command Prefetch Size                           |     |
| 15       | Read Multiple Prefetch Size                               |     |
| 16       | Conventional PCI Ordering Rules                           |     |
| 17       | Bridge Implementation of Requester Attribute Fields       |     |
| 18       | Bridge Implementation Completer Attribute Fields          |     |
| 19       | PCI-X Ordering Rules                                      |     |
| 20       | Detected Error Types and Action Taken                     |     |
| 21       | Configuration Register Address Space Groupings and Ranges |     |
| 22       | PCI Enhanced Capabilities Supported                       |     |
| 23       | Standard PCI Type 1 Configuration Space Address Map       | /6  |
| 24       | Identifiers - ID                                          |     |
| 25       | Primary Command Register - PCR                            |     |
| 26<br>27 | Primary Status Register - PSR                             |     |
|          | Class Code Register - CCR                                 |     |
| 28       | Cacheline Size Register - CLSR                            |     |
| 29<br>30 | Primary Latency Timer Register - PLTR                     |     |
| 31       | Header Type Register - HTR                                |     |
| 32       | Bus Number Register - BNR                                 |     |
| 33       | Secondary Latency Timer Register - SLTR                   |     |
| 34       | I/O Base and Limit Register - IOBL                        |     |
| 35       | Secondary Status Register - SSR                           |     |
| 36       | Memory Base and Limit Register - MBL                      |     |
| 37       | Prefetchable Memory Base and Limit Register - PMBL        |     |
| 38       | Prefetchable Memory Base Upper 32 Bits - PMBU32           |     |
| 39       | Prefetchable Memory Limit Upper 32 Bits - PMLU32          |     |
| 40       | I/O Base and Limit Upper 16 Bits - IOBLU16                |     |
| 41       | Capabilities Pointer Register - Cap_Ptr                   |     |
| 42       | Interrupt Information - INTR                              |     |
| 43       | Bridge Control Register - BCR                             |     |
| 44       | Bridge Device-Specific Configuration Address Map          |     |
| 45       | Secondary Arbiter Control/Status Register - SACSR         |     |
| 46       | Bridge Control Register 0 - BCR0                          |     |
| 47       | Bridge Control Register 1 - BCR1                          |     |
| 48       | Bridge Control Register 2 - BCR2                          |     |
| 49       | Bridge Status Register - BSR                              | 107 |



| 50 | Bridge Multi-Transaction Timer Register - BMTTR                             |       |   |
|----|-----------------------------------------------------------------------------|-------|---|
| 51 | Read Prefetch Policy Register - RPPR                                        |       |   |
| 52 | P_SERR# Assertion Control - SERR_CTL                                        | .112  | 2 |
| 53 | Pre-Boot Status Register - PBSR                                             | .115  | 5 |
| 54 | Secondary Decode Enable Register - SDER                                     | .116  | 3 |
| 55 | Secondary IDSEL Select Register - SISR                                      | .117  | 7 |
| 56 | Enhanced Capabilities Register File                                         | .119  | 9 |
| 57 | Power Management Capabilities Identifier - PM_CAPID                         | .120  | ) |
| 58 | Next Item Pointer - PM_NXTP                                                 | .121  | 1 |
| 59 | Power Management Capabilities Register - PMCR                               | .122  | 2 |
| 60 | Power Management Control / Status - Register - PMCSR                        | .123  | 3 |
| 61 | Power Management Control / Status PCI to PCI Bridge Support - PMCSR_BSE     | .124  | 1 |
| 62 | Power Management Data Register - PMDR                                       | .125  | 5 |
| 63 | PCI-X Capabilities Identifier - PX_CAPID                                    | .126  | 3 |
| 64 | Next Item Pointer - PX_NXTP                                                 | .127  | 7 |
| 65 | PCI-X Secondary Status - PX_SSTS                                            | .128  | 3 |
| 66 | PCI-X Bridge Status - PX_BSTS                                               | .129  | ) |
| 67 | PCI-X Upstream Split Transaction Control - PX_USTC                          | .130  | ) |
| 68 | PCI-X Downstream Split Transaction Control - PX_DSTC                        | .131  | ١ |
| 69 | ATU Command Support                                                         | .137  | 7 |
| 70 | Outbound Address Translation Control                                        | .149  | ) |
| 71 | Internal Bus-to-PCI Command Translation for Two Memory Windows/DMA Channels | . 150 | ) |
| 72 | Internal Bus-to-PCI Command Translation for I/O Window                      | .151  | ١ |
| 73 | Inbound Queues                                                              | . 163 | 3 |
| 74 | Inbound Read Prefetch Data Sizes                                            | .164  | 1 |
| 75 | PCI to Internal Bus Command Translation for All Inbound Transactions        | . 165 | 5 |
| 76 | Outbound Queues                                                             | .166  | 3 |
| 77 | ATU Inbound Data Flow Ordering Rules                                        | .167  | 7 |
| 78 | ATU Outbound Data Flow Ordering Rules                                       | .168  | 3 |
| 79 | Inbound Transaction Ordering Summary                                        | .170  | ) |
| 80 | Outbound Transaction Ordering Summary                                       | .171  | 1 |
| 81 | ATU Error Reporting Summary - PCI Interface                                 | .196  | 3 |
| 82 | ATU Error Reporting Summary - Internal Bus Interface                        | . 199 | ) |
| 83 | Address Translation Unit Registers                                          | .207  | 7 |
| 84 | ATU PCI Configuration Register Space                                        | .210  | ) |
| 85 | ATU Vendor ID Register - ATUVID                                             | .212  | 2 |
| 86 | ATU Device ID Register - ATUDID                                             | .213  | 3 |
| 87 | ATU Command Register - ATUCMD                                               | .214  | 1 |
| 88 | ATU Status Register - ATUSR                                                 | .215  | 5 |
| 89 | ATU Revision ID Register - ATURID                                           | .217  | 7 |
| 90 | ATU Class Code Register - ATUCCR                                            | .218  | 3 |
| 91 | ATU Cacheline Size Register - ATUCLSR                                       | .219  | ) |
| 92 | ATU Latency Timer Register - ATULT                                          | . 220 | ) |
| 93 | ATU Header Type Register - ATUHTR                                           | . 221 | l |
| 94 | ATU BIST Register - ATUBISTR                                                | . 222 | 2 |
| 95 | Inbound ATU Base Address Register 0 - IABAR0                                |       |   |
| 96 | Inbound ATU Upper Base Address Register 0 - IAUBAR0                         | . 224 | 1 |
| 97 | Inbound ATU Base Address Register 1 - IABAR1                                | . 225 | 5 |
| 98 | Inbound ATU Upper Base Address Register 1 - IAUBAR1                         |       |   |
| 99 | Inbound ATU Base Address Register 2 - IABAR2                                | . 227 | 7 |



| 100  | Inbound ATU Upper Base Address Register 2 - IAUBAR2                      | 228        |
|------|--------------------------------------------------------------------------|------------|
| 101  | ATU Subsystem Vendor ID Register - ASVIR                                 | 229        |
|      | ATU Subsystem ID Register - ASIR                                         |            |
|      | Expansion ROM Base Address Register -ERBAR                               |            |
|      | ATU Capabilities Pointer Register - ATU_Cap_Ptr                          |            |
|      | Memory Block Size Read Response                                          |            |
|      | ATU Base Registers and Associated Limit Registers                        |            |
|      | ATU Interrupt Line Register - ATUILR                                     |            |
|      | ATU Interrupt Pin Register - ATUIPR                                      |            |
|      | ATU Minimum Grant Register - ATUMGNT                                     |            |
|      | ATU Maximum Latency Register - ATUMLAT                                   |            |
|      | Inbound ATU Limit Register 0 - IALR0                                     |            |
|      | Inbound ATU Translate Value Register 0 - IATVR0                          |            |
|      | Expansion ROM Limit Register - ERLR                                      |            |
|      | Expansion ROM Translate Value Register - ERTVR                           |            |
|      | Inbound ATU Limit Register 1 - IALR1                                     |            |
|      | Inbound ATU Limit Register 2 - IALR2                                     |            |
|      | Inbound ATU Translate Value Register 2 - IATVR2                          |            |
|      | Outbound I/O Window Translate Value Register - OIOWTVR                   |            |
|      | Outbound Memory Window Translate Value Register 0- OMWTVR0               |            |
|      | Outbound Upper 32-bit Memory Window Translate Value Register 0- OUMWTVR0 |            |
|      | Outbound Memory Window Translate Value Register 1- OMWTVR1               |            |
|      | Outbound Upper 32-bit Memory Window Translate Value Register 1- OUMWTVR1 |            |
|      | Outbound Upper 32-bit Direct Window Translate Value Register - OUDWTVR   |            |
|      | ATU Configuration Register - ATUCR                                       |            |
|      | PCI Configuration and Status Register - PCSR                             |            |
|      | ATU Interrupt Status Register - ATUISR                                   |            |
|      | ATU Interrupt Mask Register - ATUIMR                                     |            |
|      | Inbound ATU Base Address Register 3 - IABAR3                             |            |
|      | Inbound ATU Upper Base Address Register 3 - IAUBAR3                      |            |
|      | Inbound ATU Limit Register 3 - IALR3                                     |            |
|      | Inbound ATU Translate Value Register 3 - IATVR3                          |            |
|      | Outbound Configuration Cycle Address Register - OCCAR                    |            |
|      | Outbound Configuration Cycle Data Register - OCCDR                       |            |
|      | VPD Capability Identifier Register - VPD_CAPID                           |            |
|      | VPD Next Item Pointer Register - VPD_NXTP                                |            |
|      | VPD Address Register - VPD_AR                                            |            |
|      | VPD Data Register - VPD_DR                                               |            |
|      | Power Management Capability Identifier Register - PM_CAPID               |            |
|      | Power Management Next Item Pointer Register - PM_NXTP                    |            |
|      | Power Management Capabilities Register - PM_CAP                          |            |
|      | Power Management Control/Status Register - PM_CSR                        |            |
|      | PCI-X_Capability Identifier Register - PX_CAPID                          |            |
|      | PCI-X Next Item Pointer Register - PX_NXTP                               |            |
|      | PCI-X Command Register - PX_CMD                                          |            |
|      | PCI-X Status Register - PX_SR                                            |            |
|      | Secondary PCIDrive Strength Control Register - SPDSCR                    |            |
|      | Primary PCIDrive Strength Control Register - PPDSCR                      |            |
|      | MU Summary                                                               |            |
| 1/10 | Circular Queue Ordering Requirements                                     | 209<br>200 |
| 1+3  | Onodia: Adode Ordening itequirements                                     | 209        |



|   | 150 | Circular Queue Summary                         | 292 |
|---|-----|------------------------------------------------|-----|
|   | 151 | Queue Starting Addresses                       | 294 |
| • | 152 | Circular Queue Summary                         | 299 |
| • | 153 | Circular Queue Status Summary                  | 299 |
|   | 154 | Message Unit Register                          | 303 |
|   | 155 | Inbound Message Register - IMRx                | 304 |
|   |     | Outbound Message Register - OMRx               |     |
|   | 157 | Inbound Doorbell Register - IDR                | 306 |
|   | 158 | Inbound Interrupt Status Register - IISR       | 307 |
|   | 159 | Inbound Interrupt Mask Register - IIMR         | 308 |
|   | 160 | Outbound Doorbell Register - ODR               | 309 |
|   | 161 | Outbound Interrupt Status Register - OISR      | 310 |
|   | 162 | Outbound Interrupt Mask Register - OIMR        | 311 |
|   | 163 | MU Configuration Register - MUCR               | 312 |
|   | 164 | Queue Base Address Register - QBAR             | 313 |
|   | 165 | Inbound Free Head Pointer Register - IFHPR     | 314 |
|   | 166 | Inbound Free Tail Pointer Register - IFTPR     | 315 |
|   | 167 | Inbound Post Head Pointer Register - IPHPR     | 316 |
|   | 168 | Inbound Post Tail Pointer Register - IPTPR     | 317 |
|   | 169 | Outbound Free Head Pointer Register - OFHPR    | 318 |
|   | 170 | Outbound Free Tail Pointer Register - OFTPR    | 319 |
|   | 171 | Outbound Post Head Pointer Register - OPHPR    | 320 |
|   | 172 | Outbound Post Tail Pointer Register - OPTPR    | 321 |
|   | 173 | Index Address Register - IAR                   | 322 |
|   | 174 | MSI Capability Identifier Register - MSI_CAPID | 323 |
|   | 175 | MSI Next Item Pointer Register - MSI_NXTP      | 324 |
|   | 176 | MSI Message Control Register - MSI_MCR         | 325 |
|   | 177 | MSI Message Address Register - MSI_MAR         | 326 |
|   | 178 | MSI Message Upper Address Register - MSI_MUAR  | 327 |
|   | 179 | MSI Message Data Register - MSI_MDR            | 328 |
|   | 180 | Contiguous Byte Enable Encodings               | 334 |
|   | 181 | Internal Bus Command Summary                   | 335 |
|   |     | Bus Interface Unit Register Tables             |     |
|   | 183 | BIU Status Register - BIUSR                    | 342 |
|   | 184 | BIU Error Address Register - BEAR              | 344 |
|   | 185 | BIU Control Register - BIUCR                   | 345 |
|   | 186 | DMA Registers                                  | 350 |
|   | 187 | DMA Interrupt Summary                          | 367 |
|   | 188 | DMA Controller Unit Registers                  | 370 |
|   | 189 | Channel Control Register x - CCRx              | 371 |
|   | 190 | Channel Status Register x - CSRx               | 372 |
| • | 191 | Descriptor Address Register x - DARx           | 373 |
|   | 192 | Next Descriptor Address Register x - NDARs     | 374 |
|   |     | PCI Address Register x - PADRx                 |     |
|   |     | PCI Upper Address Register x - PU ADRx         |     |
|   |     | Local Address Register x - LADRx               |     |
| • | 196 | Byte Count Register x - BCRx                   | 378 |
| • | 197 | Descriptor Control Register x - DCRx           | 379 |
| • | 198 |                                                | 380 |
|   | 199 | Register Description                           | 383 |



| 200 | AA Interrupts                                                              | 412        |  |
|-----|----------------------------------------------------------------------------|------------|--|
| 201 | Application Accelerator Unit Registers                                     |            |  |
| 202 | Accelerator Control Register - ACR                                         |            |  |
| 203 | Accelerator Status Register - ASR                                          |            |  |
| 204 | Accelerator Descriptor Address Register - ADAR                             |            |  |
|     | Accelerator Next Descriptor Address Register - ANDAR                       |            |  |
|     | Data / Source Address Register - SAR1                                      |            |  |
|     | Source Address Register232 - SAR232                                        |            |  |
|     | Destination Address Register - DAR                                         |            |  |
|     | Accelerator Byte Count Register - ABCR                                     |            |  |
|     | Accelerator Descriptor Control Register - ADCR                             |            |  |
|     | Extended Descriptor Control Register 0 - EDCR0                             |            |  |
|     | Extended Descriptor Control Register 1 - EDCR1                             |            |  |
|     | Extended Descriptor Control Register 2 - EDCR2                             |            |  |
|     | Commonly Used Terms                                                        |            |  |
|     | DDR SDRAM Memory Configuration Options                                     |            |  |
|     | DDR SDRAM Interface Signals                                                |            |  |
|     | DDR-II SDRAM Interface Signals                                             |            |  |
|     | Supported DDR SDRAM Bank and Page Sizes                                    |            |  |
|     | Bank Address Decode                                                        |            |  |
|     | DDR SDRAM Address Decode Summary                                           |            |  |
|     | DDR SDRAM Address Decode Summary                                           |            |  |
|     | DDR SDRAM Address Decode #1                                                |            |  |
|     | DDR SDRAM Address Decode #2                                                |            |  |
|     | DDR SDRAM Address Decode #3                                                |            |  |
|     | Address Decoding for DDR SDRAM Memory Banks                                |            |  |
|     | Programming Codes for the DDR SDRAM Bank Size                              |            |  |
|     | Programming Values for the DDR SDRAM 32-bit Size Register (S32SR[29:20])45 |            |  |
|     | DDR SDRAM Commands                                                         |            |  |
|     | SDCR[1:0] Timing Parameters Summary                                        |            |  |
|     | Typical Refresh Frequency Register Values                                  |            |  |
|     | Syndrome Decoding                                                          |            |  |
|     | Overlapping Address Priorities                                             |            |  |
|     | MCU Error Response                                                         |            |  |
|     | Memory Controller Register                                                 |            |  |
|     | DDR SDRAM Initialization Register - SDIR                                   |            |  |
|     | DDR SDRAM Control Register 0 - SDCR0                                       |            |  |
|     | DDR SDRAM Control Register 1 - SDCR1                                       |            |  |
|     | SDRAM Base Register - SDBR                                                 |            |  |
|     | SDRAM Boundary Register 0 - SBR0                                           |            |  |
|     | SDRAM Boundary Register - SBR1                                             |            |  |
|     | DDR SDRAM 32-bit Region Size Register - S32SR                              |            |  |
|     | ECC Control Register - ECCR                                                |            |  |
| 242 | ECC Log Registers - ELOG0, ELOG1                                           | 506        |  |
| 243 | ECC Address Registers - ECAR0, ECAR1                                       | 507        |  |
| 244 | ECC Test Register - ECTST                                                  | 507<br>500 |  |
| 240 | Memory Controller Interrupt Status Register - MCISR                        | 500<br>600 |  |
|     | MCU Port Transaction Count Register - MPTCR                                |            |  |
|     | MCU Preemption Control Register - MPCR                                     |            |  |
|     | Refresh Frequency Register - RFR                                           |            |  |
| ∠+3 | Treffesti Frequency Tregister - IVLIV                                      | J 1 Z      |  |



|     | DCAL Control and Status Register - DCALCSR                           |     |  |
|-----|----------------------------------------------------------------------|-----|--|
| 251 | DCAL Address Register - DCALADDR                                     | 515 |  |
| 252 | 2 DCAL Data Registers 17-0 - DCALDATA[17:0]                          |     |  |
|     | 3 OCD Adjust Field Encoding                                          |     |  |
| 254 | 4 OCD Definition of DCALDATA[17:0] Registers                         |     |  |
|     | 55 Receive Enable Calibration of DCALDATA[9] Register                |     |  |
|     | 56 Receive Enable Calibration Definition of DCALDATA[17:0] Registers |     |  |
|     | 57 DQS Calibration Field Encodings for DCALDATA[17:0] Registers      |     |  |
|     | DQS Definition of DCALDATA[17:0] Registers                           |     |  |
|     | Receive Enabled Delay Register - RCVDLY                              |     |  |
|     | Slave Low Mix 0 - SLVLMIX0                                           |     |  |
|     | Slave Low Mix 1 - SLVLMIX1                                           |     |  |
|     | Slave High Mix 0 - SLVHMIX0                                          |     |  |
|     | Slave High Mix 1 - SLVHMIX1                                          |     |  |
|     | Slave Length - SLVLEN                                                |     |  |
|     |                                                                      |     |  |
|     | 65 Master Mix - MASTMIX56 Master Length- MASTLEN55                   |     |  |
|     | DDR Drive Strength Status Register - DDRDSSR                         |     |  |
|     | DDR Drive Strength Control Register - DDRDSCR                        |     |  |
|     | DDR Miscellaneous Pad Control Register - DDRMPCR                     |     |  |
|     | Bus Signal Descriptions                                              |     |  |
|     |                                                                      |     |  |
|     | Flash Wait State Profile Programming                                 |     |  |
|     | Peripheral Bus Interface Register                                    |     |  |
|     | PBI Control Register - PBCR                                          |     |  |
|     | Memory Block Size Limit Register Value                               |     |  |
|     | PBI Base Address Register 0 - PBBAR0                                 |     |  |
|     | PBI Limit Register 0 - PBLR0                                         |     |  |
|     | PBI Base Address Register 1- PBBAR1                                  |     |  |
|     | PBI Limit Register 1 - PBLR1                                         |     |  |
|     | PBI Memory-less Boot Registers 2:0 - PMBR[2:0]                       |     |  |
|     | PBI Drive Strength Control Register - PBDSCR                         |     |  |
|     | I2C Interface Pins                                                   |     |  |
|     | I <sup>2</sup> C Bus Definitions                                     |     |  |
|     | Modes of Operation                                                   |     |  |
|     | START and STOP Bit Definitions                                       |     |  |
|     | Master Transactions                                                  |     |  |
|     | Slave Transactions                                                   |     |  |
|     | General Call Address Second Byte Definitions                         |     |  |
| 288 | I <sup>2</sup> C Register Summary                                    | 575 |  |
| 289 | I <sup>2</sup> C Control Register x - ICRx                           | 576 |  |
| 290 | I <sup>2</sup> C Status Register x - ISRx                            | 578 |  |
| 291 | I <sup>2</sup> C Slave Address Register x - ISARx                    | 580 |  |
| 292 | I <sup>2</sup> C Data Buffer Register x - IDBRx                      | 581 |  |
|     | I <sup>2</sup> C Bus Monitor Register x - IBMRx                      |     |  |
| 294 | UART Signal Descriptions                                             | 585 |  |
| 295 | Divisor Values for Typical Baud Rates                                | 590 |  |
|     | UART Register Addresses as Offsets of a Base                         |     |  |
| 297 | UART Unit Registers                                                  | 592 |  |
| 298 | UART Register MMR Addresses                                          | 593 |  |
|     | UART x Receive Buffer Register - (UxRBR)                             |     |  |



| 300 | UART x Transmit Holding Register - (UxTHR)          | 595 |  |  |
|-----|-----------------------------------------------------|-----|--|--|
| 301 | UART x Interrupt Enable Register - (UxIER)          |     |  |  |
| 302 | UART x Interrupt Identification Register - (UxIIR)5 |     |  |  |
| 303 | Interrupt Identification Register Decode5           |     |  |  |
| 304 | UART x FIFO Control Register - (UxFCR)5             |     |  |  |
| 305 | 5 UART x Line Control Register - (UxLCR)            |     |  |  |
| 306 | S UART x Modem Control Register - (UxMCR)6          |     |  |  |
| 307 | UART x Line Status Register - (UxLSR)6              |     |  |  |
| 308 | UART x Modern Status Register - (UxMSR)             |     |  |  |
| 309 | UART x Scratchpad Register - (UxSCR)                | 609 |  |  |
| 310 | UART x Divisor Latch Low Register - (UxDLL)         | 610 |  |  |
| 311 | UART x Divisor Latch High Register - (UxDLH)        | 610 |  |  |
|     | UART x FIFO Occupancy Register - (UxFOR)            |     |  |  |
| 313 | UART x Auto-Baud Control Register - (UxABR)         | 612 |  |  |
| 314 | UART x Auto-Baud Count Register - (UxACR)           |     |  |  |
|     | Priority Programming Example                        |     |  |  |
|     | Bus Arbitration Example – Three Bus Initiators      |     |  |  |
|     | Bus Arbitration Example – Six Bus Initiators        |     |  |  |
|     | 3 Arbitration Flow                                  |     |  |  |
|     | Arbitration Reset                                   |     |  |  |
|     | O Arbiter Register                                  |     |  |  |
|     | Internal Arbitration Control Register - IACR        |     |  |  |
|     | Programmed Priority Control                         |     |  |  |
|     | 3 Multi-Transaction Timer Register - MTTR1          |     |  |  |
|     | Multi-Transaction Timer Register - MTTR2            |     |  |  |
|     | CP14 Registers                                      |     |  |  |
| 326 | Accessing the Performance Monitoring Registers      |     |  |  |
|     | Clock Count Register CCNT                           |     |  |  |
|     | Clock Count Register CCNT                           |     |  |  |
| 329 | Accessing the Debug Registers                       |     |  |  |
|     | CP15 Registers                                      |     |  |  |
|     | ID Register                                         |     |  |  |
| 332 | Cache Type Register                                 | 635 |  |  |
|     | ARM* Control Register                               |     |  |  |
| 334 | Auxiliary Control Register                          | 637 |  |  |
|     | Translation Table Base Register                     |     |  |  |
|     | Domain Access Control Register                      |     |  |  |
|     | Fault Status Register                               |     |  |  |
| 338 | Fault Address Register                              | 639 |  |  |
|     | Cache Functions                                     |     |  |  |
| 340 | TLB Functions                                       | 642 |  |  |
|     | Cache Lockdown Functions                            |     |  |  |
|     | Data Cache Lock Register                            |     |  |  |
|     | TLB Lockdown Functions                              |     |  |  |
|     | Accessing Process ID                                |     |  |  |
|     | Process ID Register                                 |     |  |  |
|     | Accessing the Debug Registers                       |     |  |  |
|     | Coprocessor Access Register                         |     |  |  |
|     | Performance Monitoring Events                       |     |  |  |
|     | Some Common Uses of the CPMON                       |     |  |  |



|    | 0 CPMON Registers                                                                                                                            |      |
|----|----------------------------------------------------------------------------------------------------------------------------------------------|------|
|    | 1 Clock Count Register CCNT                                                                                                                  |      |
| 35 | 2 Performance Count Register PMNx                                                                                                            | 654  |
| 35 | 3 Performance Monitor Control Register PMNC                                                                                                  | 655  |
|    | 4 Timer Performance Ranges                                                                                                                   |      |
| 35 | 5 Timer Mode Register Control Bit Summary                                                                                                    | 661  |
|    | 6 Timer Responses to Register Bit Settings                                                                                                   |      |
|    | 7 Timer Registers                                                                                                                            |      |
|    | 8 Timer Powerup Mode Settings                                                                                                                |      |
|    | i9 Timer Mode Register – TMRx                                                                                                                |      |
| 36 | io Timer Input Clock (TCLOCK) Frequency Selection                                                                                            | 669  |
|    | 1 Timer Count Register – TCRx                                                                                                                |      |
|    | 32 Timer Reload Register – TRRx                                                                                                              |      |
|    | 3 Timer Interrupt Status Register – TISR                                                                                                     |      |
| 36 | 34 Watch Dog Timer Control Register WDTCR                                                                                                    | 673  |
|    | 5 Uncommon TMRx Control Bit Settings                                                                                                         |      |
|    | 66 Exception Priorities And Vectors                                                                                                          |      |
|    | 7 Interrupt Input Pin Descriptions                                                                                                           |      |
|    | 8 Interrupt Output Pin Descriptions                                                                                                          |      |
|    | 9 Interrupt Routing Summary                                                                                                                  |      |
|    | O Normal Interrupt Sources                                                                                                                   |      |
|    | 1 Error Interrupt Sources                                                                                                                    |      |
|    | 2 Default Interrupt Routing and Status Values                                                                                                |      |
|    | '3 Interrupt Controller Register Addresses                                                                                                   |      |
|    | '4 Interrupt Control Register 0 - INTCTL0                                                                                                    |      |
|    | '5 Interrupt Control Register 1 - INTCTL1                                                                                                    |      |
|    | 6 Interrupt Steering Register 0 - INTSTR0                                                                                                    |      |
|    | 7 Interrupt Steering Register 1 - INTSTR1                                                                                                    |      |
|    | 8 IRQ Interrupt Source Register 0 - IINTSRC0                                                                                                 |      |
|    | '9 IRQ Interrupt Source Register 1 - IINTSRC1                                                                                                |      |
|    | 60 FIQ Interrupt Source Register 0 - FINTSRC0                                                                                                |      |
| 38 | 11 FIQ Interrupt Source Register 1 - FINTSRC1                                                                                                | 707  |
|    | 2 Interrupt Priority Register 0 - IPR0                                                                                                       |      |
|    | 3 Interrupt Priority Register 180331 - IPR1                                                                                                  |      |
|    | 4 Interrupt Priority Register 2 - IPR2                                                                                                       |      |
|    | 5 Interrupt Priority Register 3 - IPR3                                                                                                       |      |
|    | 6 Interrupt Base Register - INTBASE                                                                                                          |      |
|    | 7 Interrupt Size Register - INTSIZE                                                                                                          |      |
|    | 8 IRQ Interrupt Vector Register- IINTVEC                                                                                                     |      |
|    | 9 FIQ Interrupt Vector Register- FINTVEC                                                                                                     |      |
|    | 0 PCI Interrupt Routing Select Register- PIRSR                                                                                               |      |
|    | 1 GPIO Pin Multiplexing                                                                                                                      |      |
|    | 12 General Purpose I/O Registers Addresses                                                                                                   |      |
|    | 3 GPIO Output Enable Register - GPOE                                                                                                         |      |
|    | 94 GPIO Unput Data Register - GPID                                                                                                           |      |
|    | 15 Output Data Register - GPOD                                                                                                               |      |
| 20 | 16 Intel® 80331 I/O Processor PCI Programming Model                                                                                          | 72e  |
|    | 7 PCI Configuration Register Locations                                                                                                       |      |
| 20 | 77 PCI Configuration Register Locations<br>18 Intel <sup>®</sup> XScale <sup>™</sup> Core Local Addresses Assigned to Integrated Peripherals | 724  |
|    | 9 Peripheral Memory-Mapped Register Locations                                                                                                |      |
| િ  | ד בווטוובומו ועובוווטו y-ועומטטבע הבעוטנבו בטטמנוטווט                                                                                        | / 32 |

# Intel<sup>®</sup> 80331 I/O Processor Developer's Manual Contents



| 400 | Intel <sup>®</sup> XScale <sup>™</sup> Core Coprocessor Registers Assigned to Integrated Peripherals | 745 |  |
|-----|------------------------------------------------------------------------------------------------------|-----|--|
| 401 | Coprocessor Register Locations                                                                       |     |  |
| 402 | Output Clocks Loading Summary                                                                        | 752 |  |
|     | Clock Pin Summary                                                                                    |     |  |
| 404 | Intel® 80331 I/O Processor Clock Region Summary                                                      | 754 |  |
| 405 | Internal Bus Reset Summary                                                                           | 759 |  |
| 406 | Reset Summary                                                                                        | 761 |  |
| 407 | Reset Strap Signals                                                                                  | 763 |  |
|     | Test Control/Observe Pins                                                                            |     |  |
| 409 | TLU TAP Controller Instruction Set                                                                   | 776 |  |
| 410 | Intel® XScale <sup>™</sup> Core TAP Controller Instruction Set                                       | 777 |  |
| 411 | Device ID Register Field Definitions                                                                 | 779 |  |
| 412 | Intel <sup>®</sup> XScale <sup>™</sup> Core Device ID Register Settings                              | 779 |  |
|     | TLU Device ID Register Settings                                                                      | 779 |  |



#### **Revision History**

| Date           | Revision | Description          |
|----------------|----------|----------------------|
| October 2003   | 002      | Revised MCU Chapter. |
| September 2003 | 001      | Initial Release.     |



# This Page Intentionally Left Blank



## Introduction

1

#### 1.1 About This Document

This document is the authoritative and definitive reference for the external architecture of the Intel<sup>®</sup> 80331 I/O processor (80331).

Intel Corporation assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice. In particular, descriptions of features, timings, packaging, and pin-outs does not imply a commitment to implement them. In fact, this specification does not imply a commitment by Intel to design, manufacture, or sell the product described herein.

#### 1.1.1 How To Read This Document

This document describes the product-specific features of the 80331. Each chapter describes a different feature and starts with an overview followed by the theory of operation.

The reader should have a working understanding of the PCI Local Bus Specification, Revision 2.3.

#### 1.1.2 Other Relevant Documents

- 1. Intel<sup>®</sup> 80200 Processor based on Intel<sup>®</sup> XScale<sup>™</sup> Microarchitecture Developer's Manual (Order Number: 273411), Intel Corporation
- 2. Intel<sup>®</sup> XScale<sup>™</sup> Microarchitecture Programmer's Reference Manual (Order Number: 273436), Intel Corporation
- 3. ARM Architecture Reference Manual ARM Limited. Order number: ARM DDI 0100E.
- 4. Intel® 80321 I/O Processor Developer's Manual (Order Number: 273517), Intel Corporation
- 5. PCI Local Bus Specification, Revision 2.3 PCI Special Interest Group
- 6. PCI-to-PCI Bridge Architecture Specification, Revision 1.1 PCI Special Interest Group
- 7. PCI Bus Power Management Interface Specification, Revision 1.1 PCI Special Interest Group
- 8. PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a PCI Special Interest Group
- 9. IEEE Standard Test Access Port and Boundary Scan Architecture 1149.1a IEEE



#### 1.2 About the Intel<sup>®</sup> 80331 I/O Processor

The 80331 is a multi- function device that integrates the Intel<sup>®</sup> XScale<sup>™</sup> core (ARM\* architecture compliant) with intelligent peripherals and PCI-to-PCI Bridge. The 80331 consolidates, into a single system:

- Intel<sup>®</sup> XScale<sup>TM</sup> core.
- PCI-to-PCI Bridge supporting PCI-X interfaces on the Primary and Secondary bus.
- Address Translation Unit (PCI-to-Internal Bus Application Bridge) interfaced to the Secondary Bus.
- High-Performance Memory Controller.
- Interrupt Controller with 13 external interrupt inputs.
- Two Direct Memory Access (DMA) Controller.
- Application Accelerator.
- · Messaging Unit.
- Peripheral Bus Interface Unit.
- Performance Monitor.
- Two I<sup>2</sup>C Bus Interface Units.
- Two 16550 compatible UARTs with flow control (4 pins).
- Eight General Purpose Input Output (GPIO) ports.

It is an integrated processor that addresses the needs of intelligent I/O applications and helps reduce intelligent I/O system costs.

36 October, 2003 **Document Number: 273942-002** 



The 80331 integrates a PCI-to-PCI Bridge with the ATU as an integrated secondary PCI device. The Primary Address Translation Unit is compliant with the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a definitions of an 'application bridge'.

Figure 1 is a block diagram of the 80331.

Figure 1. Intel<sup>®</sup> 80331 I/O Processor Functional Block Diagram





#### 1.3 Features

The 80331 combines the Intel<sup>®</sup> XScale<sup>™</sup> core with powerful new features to create an intelligent I/O processor. This multi-device I/O Processor is fully compliant with the *PCI Local Bus Specification*, Revision 2.3 and the *PCI-to-PCI Bridge Architecture Specification*, Revision 1.1. 80331-specific features include:

- Intel® XScale<sup>TM</sup> Core
- Primary PCI-X 133MHz Bus Interface
- Application Accelerator Unit
- Address Translation Units
- Memory Controller
- Peripheral Bus Interface

- Two I<sup>2</sup>C Bus Interface Units
- Two DMA Controllers
- Messaging Unit
- · Internal Bus
- Two UARTs
- Interrupt Controller and GPIOs

• PCI-to-PCI Bridge to secondary PCI-X 133MHz Bus interface

The subsections that follow briefly overview each feature. Refer to the appropriate chapter for full technical descriptions.

# 1.3.1 Intel<sup>®</sup> XScale<sup>™</sup> Core

The 80331 core processor is based upon the Intel<sup>®</sup> XScale<sup>™</sup> core. The core processor operates at a maximum frequency of 800 MHz. The instruction cache is 32 Kbytes in size and is 32-way set associative. Also, the core processor includes a data cache that is 32 Kbytes and is 32-way set associative and a mini data cache that is 2 Kbytes and is 2-way set associative.

# 1.3.2 PCI-to-PCI Bridge Unit

80331 provides a PCI-to-PCI Bridge unit. The bridge Primary and Secondary PCI-X support 64-bit 133MHz interfaces compliant to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

38 October, 2003 **Document Number: 273942-002** 



#### 1.3.3 Address Translation Units

An Address Translation Unit (ATU) allows PCI transactions direct access to the 80331 local memory. The Address Translation Unit supports transactions between PCI address space and 80331 address space. Address translation for the ATU is controlled through programmable registers accessible from both the PCI interface and the Intel<sup>®</sup> XScale <sup>TM</sup> core. The PCI interface of the ATU is connected to the 80331 Secondary PCI interface of the bridge. Upstream access to the Primary PCI interface is controlled by inverse decode with the address windows of the bridge. Dual access to registers allows flexibility in mapping the two address spaces. The ATU also supports the power management extended capability configuration header that as defined by the *PCI Bus Power Management Interface Specification*, Revision 1.1.

# 1.3.4 Memory Controller

The Memory Controller allows direct control of a DDR SDRAM memory subsystem. It features programmable chip selects and support for error correction codes (ECC). The memory controller can be configured for DDR SDRAM at 333 MHz and DDR-II at 400 MHz. The memory controller is dual-ported, with a dedicated interface for the Intel<sup>®</sup> XScale<sup>™</sup> core Bus Interface Unit and a second interface to the Internal Bus. The memory controller supports pipelined access and arbitration control to maximize performance. The memory controller interface configuration support includes Unbuffered DIMMs, Registered DIMMs, and discrete DDR SDRAM devices.

External memory can be configured as host addressable memory or private 80331 memory utilizing the Address Translation Unit and Bridge.

# 1.3.5 Application Accelerator Unit

The Application Accelerator Unit (AA) provides low-latency, high-throughput data transfer capability between the AA unit, the 80331 local memory and the Primary PCI bus. It executes data transfers from and to the 80331 local memory, from the Primary PCI bus to the 80331 local memory, or from the 80331 local memory to the Primary PCI bus. The AA unit performs XOR operations, computes parity, generates and verifies an eight byte Data Integrity field which includes a 16-/32- bit Data Guard, performs memory block fills, and provides the necessary programming interface.

# 1.3.6 Peripheral Bus Interface

The Peripheral Bus Interface Unit is a data communication path to the flash memory components or other peripherals of a 80331 hardware system. The PBI includes support for either 8-/16-bit devices. To perform these tasks at high bandwidth, the bus features a burst transfer capability which allows successive 8-/16-bit data transfers.

### 1.3.7 DMA Controller

The DMA Controller allows low-latency, high-throughput data transfers between PCI bus agents and the local memory. Two separate DMA channels accommodate data transfers to the PCI bus. Both channels include a local memory to local memory transfer mode. The DMA Controller supports chaining and unaligned data transfers. It is programmable through the Intel<sup>®</sup> XScale TM core only.



# 1.3.8 I<sup>2</sup>C Bus Interface Unit

The  $I^2C$  (Inter-Integrated Circuit) Bus Interface Unit allows the Intel<sup>®</sup> XScale<sup>TM</sup> core to serve as a master and slave device residing on the  $I^2C$  bus. The  $I^2C$  unit uses a serial bus developed by Philips Semiconductor consisting of a two-pin interface. The bus allows the 80331 to interface to other  $I^2C$  peripherals and microcontrollers for system management functions. It requires a minimum of hardware for an economical system to relay status and reliability information on the I/O subsystem to an external device. Also refer to  $I^2C$  *Peripherals for Microcontrollers* (Philips Semiconductor).

The 80331 includes two I<sup>2</sup>C bus interface units.

# 1.3.9 Messaging Unit

The Messaging Unit (MU) provides data transfer between the 80331 and PCI system. It uses interrupts to notify each system when new data arrives. The MU has four messaging mechanisms: Message Registers, Doorbell Registers, Circular Queues and Index Registers. Each allows a host processor or external PCI device and the 80331 to communicate through message passing and interrupt generation.

#### 1.3.10 Internal Bus

The Internal Bus is a high-speed interconnect between internal units and  $Intel^{\textcircled{m}}$  XScale  $^{\texttt{TM}}$  core processor. The Internal Bus operates at 266 MHz and is 64 bits wide.

#### 1.3.11 **UART Unit**

The 80331 includes two UART units. The UART Unit allows the Intel<sup>®</sup> XScale<sup>™</sup> core to serve as a master and slave device residing on the UART bus. The UART unit uses a serial bus consisting of a two-pin interface. The bus allows the 80331 to interface to other peripherals and microcontrollers. Also refer to 16550 Device Specification (National Semiconductor\*).

# 1.3.12 Interrupt Controller Unit

The Interrupt Controller Unit (ICU) aggregates interrupt sources both external and internal of 80331 to the Intel<sup>®</sup> XScale core processor. The ICU supports high performance interrupt processing with direct interrupt service routine vector generation on a per source basis. Each source has programmability for masking, core processor interrupt input, and priority.

#### 1.3.13 GPIO

The 80331 includes 8 General Purpose I/O (GPIO) pins.



# 1.4 Terminology and Conventions

# 1.4.1 Representing Numbers

All numbers in this document can be assumed to be Base10 unless designated otherwise. In text, numbers in Base16 are represented as "nnnH", where the "H" signifies hexadecimal. In pseudo code descriptions, hexadecimal numbers are represented in the form 0x1234ABCD. Binary numbers are not explicitly identified but are assumed when bit operations or bit ranges are used.

#### 1.4.2 **Fields**

A *reserved* field is a read-only field that may be used by a future implementation. Software should not modify or depend on any values in reserved fields.

A *preserved* field is a read-write field that may be used by a future implementation. Software should not modify or depend on any values in preserved fields.

A *read/write* field can written to a new value following initialization. This field can always be read to return the current value.

A *read only* field can be read to return the current value. Writes to *read only* fields are treated as no-op operations and does not change the current value nor result in an error condition.

A *read/clear* field can also be read to return the current value. A write to a *read/clear* field with the data value of 0 causes no change to the field. A write to a *read/clear* field with a data value of 1 causes the field to be cleared (reset to the value of 0). For example, when a *read/clear* field has a value of F0H, and a data value of 55H is written, the resultant field is A0H.

A *read/set* field can also be read to return the current value. A write to a *read/set* field with the data value of 0 causes no change to the field. A write to a *read/set* field with a data value of 1 causes the field to be set (set to the value of 1). For example, when a *read/set* field has a value of F0H, and a data value of 55H is written, the resultant field is F5H.

A *writeonce/readonly* field can be written to a new value **once** following initialization. After the this write has occurred, the *writeonce/readonly* field treats all subsequent writes as no-op operations and does not change the current value or result in an error condition. The field can always be read to return the current value.

# 1.4.3 Specifying Bit and Signal Values

The terms *set* and *clear* in this specification refer to bit values in register and data structures. When a bit is set, its value is 1; when the bit is clear, its value is 0. Likewise, *setting* a bit means giving it a value of 1 and *clearing* a bit means giving it a value of 0.

The terms *assert* and *deassert* refer to the logically active or inactive value of a signal or bit, respectively.



# 1.4.4 Signal Name Conventions

All signal names use the signal name convention of using the "#" symbol at the end of a signal name to indicate that the signal's active state occurs when it is at a low voltage. The absence of the "#" symbol indicates that the signal's active state occurs when it is at a high voltage.

# 1.4.5 Terminology

To aid the discussion of the 80331 architecture, the following terminology is used:

#### Table 1. Terminology

| Term            | Description                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Core processor  | Intel <sup>®</sup> XScale <sup>™</sup> core within the 80331.                                                     |
| Downstream      | At or toward the Secondary PCI interface from the Primary PCI interface.                                          |
| DWORD           | 32-bit data quantity                                                                                              |
| Host processor  | Processor located upstream from the 80331.                                                                        |
| Inbound         | At or toward the Internal Bus of the 80331 from the PCI interface of the ATU.                                     |
| Local bus       | 80331 Internal Bus.                                                                                               |
| Local memory    | Memory subsystem on the Intel <sup>®</sup> XScale <sup>™</sup> core DDR SDRAM or Peripheral Bus Interface busses. |
| Local processor | Intel <sup>®</sup> XScale <sup>™</sup> core within the 80331.                                                     |
| Outbound        | At or toward the PCI interface of the 80331 ATU from the Internal Bus.                                            |
| QWORD           | 64-bit data quantity.                                                                                             |
| Short           | 16-bit quantity.                                                                                                  |
| Upstream        | At or toward the Primary PCI interface from the Secondary PCI interface.                                          |
| word            | 16-bit quantity.                                                                                                  |



# PCI-to-PCI Bridge

2

#### 2.1 Introduction

#### 2.1.1 Product Overview

The Intel<sup>®</sup> 80331 I/O processor (80331) PCI-to-PCI bridge (PCIB) functions as a highly concurrent, low latency transparent bridge between two PCI busses. The bridge is capable of operating as a PCI-to-PCI bridge in the following configurations:

#### Table 2. PCI-to-PCI Bridge Configurations

| Primary Bus Interface                                               | Secondary Bus Interface                                             |
|---------------------------------------------------------------------|---------------------------------------------------------------------|
| PCI Local Bus Specification, Revision 2.3                           | PCI Local Bus Specification, Revision 2.3                           |
| PCI Local Bus Specification, Revision 2.3                           | PCI-X Addendum to the PCI Local Bus Specification,<br>Revision 1.0a |
| PCI-X Addendum to the PCI Local Bus Specification,<br>Revision 1.0a | PCI Local Bus Specification, Revision 2.3                           |
| PCI-X Addendum to the PCI Local Bus Specification,<br>Revision 1.0a | PCI-X Addendum to the PCI Local Bus Specification,<br>Revision 1.0a |

The bridge is used on motherboards as a means to provide additional I/O expansion slots. It is also used on PCI add-in cards as a means of mitigating the restrictive electrical loading constraints imposed on an expansion slot, enabling multiple Conventional PCI or multiple PCI-X devices to reside on a single PCI I/O adapter.

80331 supports any combination of 32- and 64-bit data transfers on its primary and secondary bus interfaces. The bridge is 33/66 MHz capable in Conventional PCI mode, and can run at 66 MHz, 100 MHz, or 133 MHz when operating in PCI-X mode depending upon its surrounding environment.

**Document Number: 273942-002** October, 2003 43



#### 2.1.2 Features List

#### Table 3. Features List

44

- PCI Bus Interfaces (2)
  - PCI Local Bus Specification, Revision 2.3 compliant
  - PCI-to-PCI Bridge Architecture Specification, Revision 1.1 compliant
  - PCI Bus Power Management Interface Specification, Revision 1.1 compliant
  - PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a compliant
  - Message Signal Interrupt (MSI)
     Support64-bit Initiator/Target Capable
  - 64-bit addressing

- Secondary Bus Arbitration
  - Secondary Bus Arbiter Supports six agents in addition to bridge
  - Optimized for PCI-X mode
  - Bus parking on bridge or last master
- Improved Buffer Architecture
  - 8 K Bytes Data Buffers in each direction
  - Improved level of Concurrency
     Up to nine outstanding transactions on each bus simultaneously
- Scalability/ Flexibility
  - PCI-Rev 2.3 32/64-bit 33/66 MHz, 3.3 V
  - PCI-X 32/64-bit 66/100/133 MHz, 3.3 V

# 2.1.3 Related External Specifications

- PCI Local Bus Specification, Revision 2.3
- PCI-to-PCI Bridge Architecture Specification, Revision 1.1
- PCI Bus Power Management Interface Specification, Revision 1.1
- PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a



# 2.2 Bus Operation

This section details the operation of the Bus interfaces. Topics described in this section include:

- RESET
- Pre-Boot Component Initialization
- Clock Domains
- Bus Transactions
- a. PCI Local Bus Specification, Revision 2.3
- Data Flow
- PCI operation<sup>a</sup>
- · PCI-X operation

#### 2.2.1 **RESET**

The bridge receives a primary bus reset input, **P\_RST#**, and generates a secondary reset output, S\_RST#. The bridge also supports a software controlled secondary bus reset mechanism defined by the PCI standard Secondary Bus Reset bit (Bridge Control Register, offset 3Eh).

The bridge internal state is completely initialized to its default state whenever **P\_RST**# is asserted. The bridge primary PCI bus data and control signals are tri-stated as long as **P\_RST**# is asserted.

The bridge secondary bus reset output, S\_RST#, is asserted and remains asserted whenever any of the following conditions are true:

- P\_RST# is asserted.
- A configuration write sets the Secondary Reset bit to a 1b.

Assertion of S\_RST# by setting the Bridge Control Register Secondary Reset Bit (BCR.6) does not cause all of bridge internal state logic to be reset. However, all of bridge data queues, request queues, and associated control logic are re-initialized to their default state. The primary bus interface and all configuration space registers are not affected by setting this bit.

*Note:* A second configuration write is required to clear the Secondary Reset bit.

Table 4 outlines bridge reset mechanisms along with corresponding impact of each on bridge. S\_RST# is asserted for both reset mechanisms, but factors governing de-assertion of S\_RST# and whether bridge experiences an internal state reset, (and to what extent), varies between mechanisms.

#### Table 4. Reset Behavior Summary

| Reset<br>Mechanism               | Full Component Reset?                                                                       | Deassertion of S_RST#                                                                                  |
|----------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| P_RST#                           | Yes                                                                                         | Following P_RST# deassertion.                                                                          |
| Secondary Reset<br>Bit set to 1b | No. Reset the secondary bus interface, data/request queues and associated state logic only. | On clearing of Secondary Reset bit via configuration write cycle to the bridge control register bit(6) |

Note: A bridge transition from the D3 hot state to the D0 device PM state could be viewed as an internal reset however, since when in D3 hot the main power rails have never been switched off, there is NO internal re-initialization of any kind performed, and S\_RST# is not asserted to the secondary bus.

**Document Number: 273942-002** October, 2003 45



# 2.2.2 Pre-Boot Component Initialization

Through the use of pin strappings several of bridge features can be configured prior to host software initialization of the bridge. Key bridge secondary bus attributes that are configured prior to host involvement include:

- Maximum Allowable Secondary Bus Operating Frequency
- · Private Device
- Private Memory Address Space

# 2.2.3 Pin Strap Configuration

The bridge provides a number of inputs that must be strapped either high or low to configure the above features prior to host initialization of the bridge. All strapping options are sampled on the low-to-high, trailing edge of **P\_RST#**.

#### 2.2.3.1 Secondary Bus Maximum Allowable Frequency

The bridge supports secondary bus operation in either Conventional PCI or PCI-X modes. As per the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a the secondary bus must be configured for mode as well as for operating frequency when coming out of S\_RST#. The bridge supports the strapping of a pin (S\_133EN) as a means of enabling designer input of additional information relating to the system; information necessary in addition to reported device capabilities in order to choose the correct operating speed for the bus.

Refer to Section 2.2.4.2, "Secondary Bus Mode and Frequency Initialization" on page 47 for additional detail.

#### 2.2.3.2 Bridge Disable

The bridge can be disabled to configure 80331 as a single PCI interface I/O processor. When **BRG\_EN** is pulled low, the bridge is disabled, the primary PCI interface pins are pulled high, and the secondary PCI interface operates as the primary PCI interface for 80331 operating in this 'no bridge' mode. With the bridge disabled, the internal PCI bus arbiter can be enabled or disabled through the **ARB\_EN** reset strap.

#### 2.2.3.3 Arbiter and Central Resource

When operating with the bridge disabled (BRG\_EN low), the ARB\_EN reset strap can be pulled low to disable the integrated arbiter and central resource function. By default, ARB\_EN is high, enabling the integrated arbiter and central resource function for embedded applications. When ARB\_EN is pulled low, and the secondary PCI interface can be used as a primary PCI interface in an adapter card solution, or embedded solution with an external arbiter.

# 2.2.4 Bus Mode and Frequency Initialization

Both of bridge bus interfaces are capable of operating at a variety of frequencies, and in either Conventional PCI mode, or in PCI-X mode. The buses mode and frequency are established when coming out of their corresponding bus segment reset sequences. The resultant mode and frequency is dependent upon the device capabilities reported as well as any system specific loading information.



#### 2.2.4.1 Primary Bus Mode and Frequency Initialization

The bridge reports its primary bus operating capabilities to the primary bus segments originating device (typically the host bridge). The bridge indicates to the primary bus segments originating device that its primary interface is PCI-X capable at frequencies of up to 133 MHz inclusive. It also indicates that bridge is capable of running at 66 MHz when operating in Conventional PCI mode.

#### 2.2.4.2 Secondary Bus Mode and Frequency Initialization

The bridge is the originating device for its secondary bus, and as such sets the bus mode and frequency when exiting out of the secondary bus reset sequence. The two key components that factor into the resultant secondary bus mode and frequency are the PCI-X standard sampling of downstream device capabilities, and the system specific physical bus loading characteristics for which the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a does not provide any standard means of reporting.

Downstream device capabilities are indicated by the values of **S\_M66EN**, and **S\_PCIXCAP** during **S\_RST#** assertion.

#### Table 5. Device Mode/Frequency Capability Reporting

| M66EN         | PCIXCAP       | Conventional PCI<br>Device Frequency<br>Capability | PCI-X Device Frequency<br>Capability |
|---------------|---------------|----------------------------------------------------|--------------------------------------|
| Ground        | Ground        | 33 MHz                                             | Not capable                          |
| Not connected | Ground        | 66 MHz                                             | Not capable                          |
| Ground        | Pull-down     | 33 MHz                                             | PCI-X 66 MHz                         |
| Not connected | Pull-down     | 66 MHz                                             | PCI-X 66 MHz                         |
| Ground        | Not connected | 33 MHz                                             | PCI-X 133 MHz                        |
| Not connected | Not connected | 66 MHz                                             | PCI-X 133 MHz                        |

Note:

Knowledge of the device capabilities alone is insufficient information to robustly select the bus frequency. In order to be sure of what the bus operating frequency should be set to, knowledge of the bus layout (e.g., number of slots), is necessary.

When, for example, a 133 MHz PCI-X capable adapter was the sole occupant of a two slot segment, then it would be necessary to slow the bus to 100 MHz, even though the card reported it could operate at 133 MHz due to the additional electrical loading imposed by the two slot board and connector layout.

The bridge provides a strapping approach for reporting system specific secondary bus loading information that is used in determining the maximum operating frequency of the secondary bus. The bridge considers this strap along with the device capabilities reported during S\_RST# to determine the secondary bus's mode and frequency when emerging from S\_RST#.

This strap, entitled Secondary PCI-X Bus 133 MHz Enable, is sampled on S\_133EN, indicating to bridge what to set the bus frequency to, given any of the possible device capabilities that it samples. The value of this field is determined by the system designer, after having assessed the characteristics of the secondary bus system/adapter implementation.



Table 6 details the secondary bus frequency initialization as a function of the Secondary Bus S\_133EN reset strap, and the sampled secondary device capabilities when operating in PCI-X mode.

#### Table 6. Secondary Bus Frequency Initialization

| M133EN <sup>a</sup> | M66EN         | PCIXCAP       | PCI Bus Mode     | PCI Frequency |
|---------------------|---------------|---------------|------------------|---------------|
| N/A                 | Ground        | Ground        | PCI Conventional | 33 MHz        |
| N/A                 | Not Connected | Ground        | PCI Conventional | 66 MHz        |
| N/A                 | N/A           | Pull-down     | PCI-X            | 66 MHz        |
| Ground              | N/A           | Not Connected | PCI-X            | 100 MHz       |
| Not Connected       | N/A           | Not Connected | PCI-X            | 133 MHz       |

a. This pin is used by the motherboard designer to run the PCI-X bus at 100 MHz even when all the PCI-X cards on the bus are 133MHz capable, so as to accommodate the board routing limitation on frequency. Note that to accommodate running a PCI-X bus at 66MHz, when all cards are capable of 133 MHz, the motherboard has to drive the PCIXCAP pin to VCC/2.

**Note:** The Secondary Bus PCI-X 133 MHz Enable strapping feature enables implementations to force the Secondary bus of 80331 to operate at 100 MHz even with no standard provisions in the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a for reporting device capability of 100 MHz operation.

When a card is plugged into a four slot secondary bus, a **S\_PCIXCAP** pull-down strapping ensures that the bus runs at no greater than 66 MHz in PCI-X mode, and grounding **S\_M66EN** ensures that the bus runs at no greater than 33 MHz in PCI, regardless of the reported downstream device capabilities.

When a card is plugged into a two slot secondary bus, the S\_133EN pull-down strapping ensures that the bus runs at no greater than 100 MHz in PCI-X mode regardless of the reported downstream device capabilities.

Finally, when a card is plugged into a single slot secondary (i.e., a segment that should be able to run at 133 MHz), by strapping the S\_133EN to 0b (as though it were a two slot configuration), the bus operates at 100 MHz maximum<sup>T</sup>.

Table 7 describes the bus mode and frequency initialization pattern that bridge signals on its secondary bus when coming out of S\_RST#, after having evaluated the above information.

#### Table 7. PCI-X Initialization Pattern

| DEVSEL# STOP# | STOP#      | TRDY#      | /# Mode | Clock Period (Ns) |         | Clock Frequency (MHz) |         |
|---------------|------------|------------|---------|-------------------|---------|-----------------------|---------|
| DEVSEL#       | 310F#      | IKDI#      | Wode    | Maximum           | Minimum | Minimum               | Maximum |
| Deasserted    | Deasserted | Deasserted | PCI 33  | 60                | 30      | 16                    | 33      |
| Deasserted    | Deasserted | Deasserted | PCI 66  | 30                | 15      | 33                    | 66      |
| Deasserted    | Deasserted | Asserted   | PCI-X   | 20                | 15      | 50                    | 66      |
| Deasserted    | Asserted   | Deasserted | PCI-X   | 15                | 10      | 66                    | 100     |
| Deasserted    | Asserted   | Asserted   | PCI-X   | 10                | 7.5     | 100                   | 133     |
| Asserted      | Deasserted | Deasserted | PCI-X   | Reserved          |         |                       |         |
| Asserted      | Deasserted | Asserted   | PCI-X   |                   |         |                       |         |
| Asserted      | Asserted   | Deasserted | PCI-X   |                   |         |                       |         |
| Asserted      | Asserted   | Asserted   | PCI-X   |                   |         |                       |         |

<sup>1.</sup> Adapters that report 133MHz PCI-X device capability with this MaxFreq setting is limited to 100MHz operation.



# 2.2.5 Private Devices on the Secondary Interface

Private devices are hidden from PCI configuration software but are accessible from the Address Translation Unit. Private devices are configured through the 80331 ATU. The control mechanism for enabling a private device and private memory address range for the private devices resides in the PCI-to-PCI bridge.

#### 2.2.5.1 Private Type 0 Commands on Secondary Interface

Type 0 configuration reads and write commands can be generated by the Address Translation Unit of the 80331. These Type 0 configuration commands are required to configure private PCI devices on the Secondary bus which are in private PCI address space. These commands are initiated by the Address Translation Unit and not by Type 1 commands on the Primary bus. Any device mapped into this private address space *is not* part of the standard Secondary PCI address space and therefore is not configured by the system host processor. These devices are hidden from PCI configuration software but are accessible from the Address Translation Unit. See Chapter 3, "Address Translation Unit" for a complete description of the private PCI address space implementation.

In Type 0 commands on the Secondary interface, **S\_AD[31:11]** are used to select the **IDSEL** input of the target device. In Type 1 to Type 0 conversions, **P\_AD[15:11]** are decoded to assert a unique address line from **S\_AD[31:16]** on the Secondary interface.

The Secondary IDSEL Select Register (SISR) can be programmed to block 10 address lines during Type 1 to Type 0 conversions from the Primary interface. Secondary address bits **S\_AD[25:16]** are the address lines that can be masked by the SISR register. By setting bits 0 through 9 (corresponding to **S\_AD[16] - S\_AD[25]**) in the SISR, the associated address line can be forced to remain deasserted for the **P\_AD[15:11]** encodings of  $00000_2$  -  $01001_2$  and therefore are free to be used as an **IDSEL** select line for private Secondary PCI devices. Table 8 shows the possible configurations of **S\_AD[31:11]** for public/private Type 0 commands on the Secondary interface. For example, when SISR Bit 0 is set, **S\_AD[16]** is not asserted during a Type 1 to Type 0 conversion from the Primary PCI bus. It can only be asserted by the Address Translation Unit.

When Primary interface receives a Type 1 command that intends to use one of the **S\_AD** address lines reserved for private PCI devices, the bridge performs the Type 1 to Type 0 conversion but not assert the reserved **S\_AD** address line. The Type 0 command is then ignored on the Secondary PCI bus.

By using the SISR register, a total of 10 **IDSEL** signals are available for private PCI devices. The remaining **S\_AD** lines (**S\_AD[31:26]**) are used for devices that are always public and accessible by Type 1 commands on the Primary bus. The ATU IDSEL input is internally wired to **S\_AD30** and therefore, **S\_AD30** is not to be used for external PCI device IDSEL input.

Table 8. Public/Private PCI Memory IDSEL Select Configurations

| Primary Address<br>P_AD[15:11] | Secondary Addresses S_AD[31:11]<br>with All SISR Bits = 0 | Secondary IDSEL Select<br>Register Bits 9-0 | Secondary Addresses S_AD[31:11] with SISR Bits Programmed |
|--------------------------------|-----------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------|
| 000002                         | 0000 0000 0000 0001 0000 0 <sub>2</sub>                   | XXXXXXXXX1 <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 000012                         | 0000 0000 0000 0010 0000 0 <sub>2</sub>                   | XXXXXXXXX1X <sub>2</sub>                    | 0000 0000 0000 0000 0000 0 <sub>2</sub>                   |
| 000102                         | 0000 0000 0000 0100 0000 0 <sub>2</sub>                   | XXXXXXX1XX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 000112                         | 0000 0000 0000 1000 0000 0 <sub>2</sub>                   | XXXXXX1XXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 001002                         | 0000 0000 0001 0000 0000 0 <sub>2</sub>                   | XXXXX1XXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 001012                         | 0000 0000 0010 0000 0000 0 <sub>2</sub>                   | XXXX1XXXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 001102                         | 0000 0000 0100 0000 0000 0 <sub>2</sub>                   | XXX1XXXXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 001112                         | 0000 0000 1000 0000 0000 0 <sub>2</sub>                   | XX1XXXXXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 010002                         | 0000 0001 0000 0000 0000 0 <sub>2</sub>                   | X1XXXXXXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |
| 010012                         | 0000 0010 0000 0000 0000 0 <sub>2</sub>                   | 1XXXXXXXXX <sub>2</sub>                     | 0000 0000 0000 0000 0000 02                               |

X = Don't Care



Figure 2 shows an example of connecting **S\_AD** lines to **IDSEL** inputs of PCI devices and private PCI devices. The default value for all the SISR bits is controlled by the **PRIVDEV** reset strap, which enables private devices at reset.

Figure 2. Secondary IDSEL Example



#### 2.2.5.2 Private Memory Space

When Private Memory Space Enable (bit 2) in the SDER (see Section 2.5.2.10, "Secondary Decode Enable Register - SDER" on page 116) is set, bridge overrides its secondary inverse decode logic and not forward upstream any secondary bus initiated DAC Memory transactions with address in the upper half of 64-bit address space (i.e. AD(63)=1b). This establishes a private memory space for secondary bus usage, independent of bridge downstream forwarding configuration. This private memory space can be used for private devices on the secondary bus addressing a private memory space of 80331 through the Address Translation Unit. The default value for the Private Memory Space Enable bit is controlled by the **PRIVMEM** reset strap.



# 2.2.6 Device Select Timing

Targets are required to claim transactions by asserting DEVSEL# as shown in Table 9. The bridge responds as a type A target (PCI-X), or Medium (Conventional PCI).

#### Table 9. DEVSEL# Timing

| Decode Speed                    | Conventional PCI | PCI-X         |
|---------------------------------|------------------|---------------|
| 1 clock after address phase(s)  | Fast             | Not Supported |
| 2 clocks after address phase(s) | Medium           | Decode A      |
| 3 clocks after address phase(s) | Slow             | Decode B      |
| 4 clocks after address phase(s) | Subtractive      | Decode C      |
| 5 clocks after address phase(s) | N/A              | N/A           |
| 6 clocks after address phase(s) | N/A              | Subtractive   |

# 2.2.7 64-Bit Operation

The bridge is 64-bit capable on both of its bus interfaces. Primary and secondary bus interfaces can operate in any combination of 32- or 64-bit operation at any given time.

As an initiator bridge always asserts **REQ64**# with the following exceptions:

- A Memory Read that has been reissued because the byte count has not been satisfied and whose starting address falls within four QWORDs of an ADB.
- Any DWORD transaction.
- When starting address is not QWORD aligned (operating in Conventional PCI mode only).
- When the total transaction length is less than four QWORDs.

As a target, bridge asserts **ACK64**# in response to the initiators assertion of **REQ64**# with the following exceptions:

- Upstream Memory Read (i.e., the originating bus is the secondary bus).
- Downstream MRL, MRM, or Memory Read to a non-prefetchable address space. (When the CLS is cleared to zero, or a non-supported value any read transaction is treated as non-prefetchable)
- Memory Read (MR, MRL, MRM) reconnection (because delayed read) which executed as a DWORD transaction on the destination bus.
- Any DWORD transaction.
- When the bus is configured to 32-bit mode during reset.
- When responding with a Split Response.

# 2.2.8 PCI Power Management Support

The bridge is compliant with *PCI Bus Power Management Interface Specification*, Revision 1.1. Following are some bridge PCI-PM specifics:

- PMCSR[1:0] PowerState field value dictates bridge ability to respond to and initiate transactions: 00 (D0 state) bridge responds to, and initiates transactions normally.
  - 01, 10, 11 bridge responds ONLY to type 0 configuration accesses. Does not master any transactions.
- When the PMCSR[1:0] is written to 00 from 11, an internal reset is performed transitioning bridge to the D0uninitialized state.



#### 2.2.9 Overview of Bus Transactions

The following sub-sections details bridge behavior when operating in Conventional PCI/X modes.

For purposes of the following discussion the terms in define the buses being described. Split Completions are the only transactions that arbitrate for and start on the Destination Bus.

#### Table 10. Bus Terms Description

| Term            | Description                                                                                                                                                                          |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Origination Bus | The bus which initiates a request. Bus closest to the Requester.                                                                                                                     |
| Destination Bus | The bus where a request is completed. Bus closest to the Completer. All Split Completion originate from this bus in response to a request that had been made on the Origination Bus. |
| PMW             | Posted Memory Write                                                                                                                                                                  |
| NPMW            | NOT (PMW)                                                                                                                                                                            |

Transaction crossing bridge assume one of the following configurations:

- PCI to PCI
- PCI-X to PCI
- PCI to PCI-X
- · PCI-X to PCI-X

Operational type is dependent on the operating mode of each bus. PCI-X uses block transfers based on ADQ and ADB concepts. While Conventional PCI interfaces do not have the concept of ADQ and ADB, they observe the ADQ and ADB structures.

Each interface operates and places data into the queues and then dispatches the request to the other interface. A "valid" indication is used to determine when a request has been enqueued and is ready to be scheduled for being played out on the destination bus.

Other than for PCI Configuration space transactions the two buses are symmetrical. Each operates independently of the other bus, sending or receiving data from the queues.

#### 2.2.9.1 **PCI-to-PCI**

52

PCI to PCI transactions use the ADQ Queue for all block transactions. Transactions can start and stop anywhere within an ADQ.

Delayed transactions are supported using the same data and request queue structures that are used when operating in PCI-X mode. PCI to PCI-X.



#### 2.2.9.2 **PCI to PCI-X**

When going from PCI to PCI-X, a transaction bases the setting of valid for a given transaction on crossing at least one ADB, or upon transaction completion by the requestor on the initiating bus. Multiple ADB crossings would allow for larger transfers that have lower overhead on both buses.

Transactions originating from a Conventional PCI initiator do not contain any of the PCI-X additional attributes such as byte count, and so therefore bridge creates the attributes for the Conventional PCI master before presenting the transaction onto the PCI-X bus. Write byte count, for example, is created based on what has been received by the bridge, and conversely, read byte counts are created based on prefetchable, and non prefetchable read policies implemented by bridge.

#### 2.2.9.3 **PCI-X** to **PCI**

Transactions to PCI can start as soon as the transaction is enqueued.

#### 2.2.9.4 **PCI-X** to **PCI-X**

For the PCI-X to PCI-X case all transactions with the exception of immediate transactions play as unidirectional transactions. Each transaction plays until it is completed in one direction. No link is present to any transaction going in the opposite direction. Requests may result in multiple responses which each become an independent transaction.



#### 2.2.10 Bus Interface Data Flow

Each bus interface of the bridge operates in one of four modes for a transaction in which it is involved. The following subsections describe the operation of each of the modes of operation.

• PCI as a target

PCI-X as a target

• PCI as a master

• PCI-X as a master

#### 2.2.10.1 Target Operation

The bridge checks each operation to determine whether or not to assert DEVSEL# thereby claiming the transaction. The bridge supports the standard set of bridge forwarding registers. When a transaction on the Origination Bus is within the standard set of forwarding ranges defined it is then forwarded to the Destination Bus.

Primary bus to Secondary bus "Base and Limit registers" define the ranges for transactions that are claimed and subsequently forwarded to the secondary bus interface. The bridge, being a transparent bridge, utilizes inverse decoding for the purpose of claiming and forwarding transactions that are to be forwarded from the secondary bus to the primary bus.

#### 2.2.10.1.1 As the PCI Target

As a PCI target, bridge enqueues requests and responds with a Retry while tracking a delayed transaction. After a request is enqueued it is ready to be forwarded to the Destination Bus (in accordance with ordering rules). A link between initial request and data operation is used to track data returning from Destination Bus.

Transactions start from Origination Bus and play on Destination Bus. After a transaction is done on Destination Bus, operation completes when initial master comes back one more time for the response.

The bridge supports linear increment address mode only (AD[1:0]=00b), and disconnects Conventional PCI memory transactions whose least significant two address bits are not 00b after a single DWORD.

For PMW operations, data is received before transaction is enqueued. At that point the byte count is known and the transaction can start on the Destination Bus. Using standard PCI protocol, data is received by bridge without insertion of wait states. The bridge disconnects a transaction whenever Queue space is not available.

For operations with a delayed response, data is transferred on the Destination Bus and held until the transaction is successfully completed by the Originating Bus Master. Data is sent to the Originating Master then using standard PCI protocol.

Delayed read completion transactions that are disconnected by the Master while prefetch data is still available are cleared from bridge queues.

#### 2.2.10.1.2 As the PCI-X Target

All transactions might have a Retry response when space is not available for either the data or the request itself. .

#### 2.2.10.1.3 PCI-X Receiving Data

54

The bridge receives data whenever it is the target of a Split Read Completion, PMW or, in the case of an immediate read data transfer on the bus, when bridge is the Master.



#### 2.2.10.2 Master Operation

#### 2.2.10.2.1 As the PCI Master

As PCI Master, bridge issues requests to a target, but does not insert wait states on PCI interface.

For PMW transactions, data is sent on Destination Bus until either byte count is satisfied, MLT expires, or Target disconnects.

For Prefetch operations, data is received until the transaction disconnects. Prefetch Disconnects from target are not retried. On Originating Bus, bridge returns only amount of data transferred before the Disconnect occurred. When the Originating Bus is operating in PCI-X mode, bridge fetches to the extent defined by the original requested byte count, and creates a single split completion sequence.

All other delayed transactions Retry until they complete, or a time-out error occurs. Status from the Destination bus operation is sent back to the Origination Bus.

Before a delayed transaction requests bus, space must be available for a Split Completion entry going from Destination to Origination Bus. When transaction is a read, bridge checks for available ADQ of space in D2O (Destination to Origination) queue.

#### 2.2.10.2.2 As the PCI-X Master

The bridge tracks requests that is has issued as a PCI-X master until the full byte count of the transaction has been completed. This is done whether the operation has an immediate response or a Split Response.

Transactions do not request the Destination Bus until a space is available in the D2O request queue. This space is required to accommodate an immediate response. Additionally, Block Read requests must have data space for at least two D2O ADQ blocks.

Master operation might be repeated multiple times for a single Origination Bus request. Each time a disconnect occurs, or partial immediate response is received from Destination Bus target, address and byte count are updated. A new request is then generated based on the updated address and byte count.

This repeats until the full byte count has been transferred.

Transmittal of PMW data, Split Requests, and Split Completion data/status is performed by the master portion of the bus interface.



#### 2.2.11 Exclusive Access

Lock is defeatured in 80331.

#### 2.2.12 Conventional PCI Mode

The central resource for a given PCI bus segment broadcasts that the operating mode for that bus is Conventional PCI mode following reset when any device on the bus reports that it is incapable of running in PCI-X mode. On the bridge Primary Bus, whenever the bus mode is indicated to be Conventional PCI by the upstream bridge, bridge enters Conventional PCI mode. On the Secondary Bus bridge enters Conventional PCI mode following secondary reset when it has determined that at least one agent on the secondary bus reports that it is incapable of operating in PCI-X mode.

#### 2.2.12.1 Posted Memory Write Transactions

The bridge posts all Memory Write and Memory Write and Invalidate (MWI) transactions that are to be forwarded from one interface to the other. The bridge accepts write data into its buffers without wait states. A posted memory write transaction is terminated when any of the following occur:

- the originator ends the transaction.
- insufficient buffer space exists to buffer another ADQ.

In the second case, target disconnect is returned to the originator.

The bridge does not initiate a memory write transaction on the Destination bus until two ADQs of data have been captured during the transaction, or until the transaction is terminated by the originator. The bridge does not insert master wait states when it acts as a bus master for the playing out of posted memory writes.

The bridge ends the transaction when all of the posted data for this queue entry has been played out and accepted by the target on the Destination Bus.

When bridge receives  $2^{24}$  consecutive target retries from the target when attempting to deliver posted write data, it discards the posted write transaction and conditionally asserts **P\_SERR**# (See Section 2.4, "Error Detection and Reporting" on page 73). This retry counter may be disabled by setting the Watchdog Timer Disable bit in the Bridge Control Register 1 - BCR1. The bridge also conditionally asserts **P\_SERR**# when a target abort or master abort is detected on the target bus in response to the posted write.

#### 2.2.12.2 Fast Back-to-Back Transactions

The bridge accepts fast back-to-back transactions as a target, but does not generate them as an initiator.

#### 2.2.12.3 Write Flow-Through

Write flow-through is supported opportunistically.



#### 2.2.12.4 Delayed Write Transactions

The bridge executes delayed transactions when forwarding I/O and configuration writes from the Conventional PCI interface to the other bus.

When an I/O or Configuration write transaction targeting the other PCI bus is first initiated, bridge returns a target retry. The bridge latches the transaction information, including address, bus command, write data, byte enables, **PAR** and **REQ64#**, and enqueues a delayed write request (DWR) when all of the following conditions are true at that time:

- space is available in the request queue structure
- a transaction having the same address, bus command, write data, and byte enables does not already exist in the request queue structure.

The bridge requests the destination bus and, once bus ownership is obtained, initiates the corresponding delayed write transaction in accordance with PCI ordering rules.

The bridge always executes delayed write transactions as single data phase DWORD writes. Once bridge completes the destination bus delayed write transaction it adds the transaction completion status to origination side request queue status structure. Completion status returns termination mode (TRDY#, target abort, master abort) and whether PERR# assertion was detected during delayed write transaction. This phase of delayed transaction is called delayed write completion (DWC).

When originator repeats transaction using same transaction information, bridge either retries the originator indicating that the delayed write transaction has not yet completed, or target disconnects the transaction with either TRDY# (normal completion) or Target Abort (error indication).

# 2.2.12.4.1 Delayed Write Transaction Time-out Errors on the Destination Bus

The bridge may be configured to discard delayed write requests when  $2^{24}$  consecutive target retries occur on the Destination Bus to the same transaction. The Watchdog Timers Disable bit in the Bridge Control Register 1 - BCR1 enables the discard.

The bridge may also be configured to assert **P\_SERR#** (**SERR#** on the primary bus) when the discard timer expires. This is done by setting the Delayed Write Watchdog Timer Expired bit of the **P\_SERR#** Assertion Control - **SERR\_CTL**.

When the timer expires bridge sends status back to the Origination Bus interface to indicate that the timer expired. When the Originating Master again tries to write this location a target abort response is given instead of a Retry. When the target abort occurs the transaction is deleted from the request queuing structure and **SERR**# is asserted when it is enabled.

# 2.2.12.4.2 Delayed Write Transaction Time-out Errors on the Origination Bus

When bridge has delayed write transaction completion status for an originator and the originator does not repeat the initial transaction before the Discard Timer for that interface expires, (see Section 2.5.1.20, "Bridge Control Register - BCR" on page 98 and Section 2.5.2.3, "Bridge Control Register 1 - BCR1" on page 104), bridge discards the delayed transaction freeing up both request and completion queue space for re-allocation to a future delayed transaction. When configured to do so via the Discard Timer SERR# Enable bit of the Bridge Control Register, bridge also asserts **SERR**# on its primary bus in the event that the delayed transaction had timed out and had been discarded by bridge.

The timer starts when Completion Status is available. The Discard Timer is reset when the transaction which started the timer completes.



#### 2.2.12.5 Read Transactions

#### 2.2.12.5.1 Delayed Read Transactions

Delayed read transaction protocol is similar to that of delayed write transactions, with the exception that transfers longer than a DWORD may also utilize delayed read transactions, specifically delayed memory read transactions. When a read to I/O, configuration, or memory intended for the other PCI bus is first initiated, bridge returns a target retry. The bridge enqueues the transaction information, including address, bus command, byte enables for non-prefetchable reads, and **REO64#** when all of the following conditions are true:

- space is available in the request queue structure.
- a delayed request having the same address, bus width, and bus command does not already exist in the request queue structure.

This phase of the delayed transaction is called a delayed read request (DRR).

The bridge then requests the destination bus and, once it obtains bus ownership, initiates the delayed read request (read transaction) in accordance with PCI ordering rules. When the transaction is a non-prefetchable read, then bridge requests only a single DWORD of data. When the transaction is a memory read to a pre-fetchable memory space, then the pre-fetchs a programmable amount of data. Refer to Section 2.2.12.5.4, "Prefetching" on page 60 for details.

The bridge completes the transaction on the destination bus<sup>1</sup>, and stores response to the appropriate queues. This phase of the delayed transaction is called the delayed read completion (DRC).

• Delayed Read Transaction Time-out Errors on the Destination Bus.

When on destination bus, bridge attempts to execute the delayed read transaction are met with  $2^{24}$  consecutive target retries, then bridge has a configuration option that enables it to discard the delayed read request and to conditionally assert **P\_SERR**#. The Watchdog Timers Disable bit is enabled/disabled in BCR1, and optional **P\_SERR**# assertion. When a read transaction on the Origination Bus matches a delayed read transaction having a DRC, bridge returns the read data, data parity bit(s), and appropriate target termination in accordance with PCI ordering rules. For all prefetchable memory read transactions, bridge aliases the memory read, memory read line, and memory read multiple commands when comparing a transaction in the delayed transaction queue to one initiated on the Origination PCI bus. Therefore, regardless of exact command used, when the address matches, and both commands are any type of memory read, bridge considers it a match. When there is no match or, the ordering rules prevent returning the completion data at that point, bridge returns target retry. The target terminations returned are as follows:

#### **Table 11.** Target Termination Returns

| <b>Destination Bus Target Response to Bridge</b> | Bridge response to Originator                                     |  |
|--------------------------------------------------|-------------------------------------------------------------------|--|
| TRDY#                                            | TRDY# (with STOP# when returning last data phase)                 |  |
| Target Abort                                     | Target Abort                                                      |  |
| Master Abort                                     | • TRDY# and FFFF FFFFh (when Master Abort Mode bit = 0)-          |  |
| Waster Abort                                     | <ul> <li>Target Abort (when Master Abort Mode bit = 1)</li> </ul> |  |

• Delayed Read Transaction Time-out Errors on the Origination Bus.
When the bridge has read completion data for an originator and originator does not repeat initial transaction before the Discard Timer interface expires (when enabled), (Section 2.5.1.20, "Bridge Control Register - BCR" on page 98 and Section 2.5.2.3, "Bridge Control Register 1 - BCR1" on page 104), bridge discards the delayed transaction. When configured to do so via the Discard Timer SERR# Enable bit of the BCR, bridge also asserts SERR# on its primary bus in the event that the delayed transaction had timed out and been discarded.

<sup>1.</sup> Which might execute as another delayed read transaction, ase when target is another bridge device also executing a delayed read transaction.



#### 2.2.12.5.2 Non-prefetchable Reads

The following transactions are considered by bridge to be non-prefetchable:

- I/O transactions.
- configuration transactions.
- transactions using the Memory Read, Memory Read Line, or Memory Read Multiple commands that address the non-prefetchable memory range.
- Single DWORD Memory Read, Memory Read Line, or Memory Read Multiple transactions.

When originating a non-prefetchable read, bridge requests only a single DWORD of read data from the target. The bridge uses the same byte enables driven by the originator of the transaction<sup>1</sup>.

When bridge returns the read data to the originator, it asserts STOP# with TRDY# to enforce a single DWORD transaction.

#### 2.2.12.5.3 Read Flow Through

Read Flow Through can be either fine grained or large grained. For the fine grained case data is tracked on each cache line boundary using an additional tracking mechanism. Large grained tracking is done at the ADB level passing data between the interfaces when a full ADQ is available for the transaction.

Flow-through is achieved when data is transferring on both the Origination Bus and Destination Bus at the same time. The bridge stops issuing Retry when a valid DRC from the Destination Bus is indicated to the Origination Bus.

- Fine Grained Tracking.
  - Fine grained tracking provides the greatest flexibility. Fine grain data tracking occurs at the cache line level allowing each interface to use either a 32- or 64-bit width for a transfer. Using a fine grain tracking mechanism is particularly useful for PCI-to-PCI tracking, allowing each data transfer to proceed across the bridge as soon as it becomes available and allowing wait state insertion on a data phase basis. Fine grain tracking is employed whenever forwarding data to a bus of less than or equal bandwidth.
- The insertion of wait states on each data phase is attractive because of the eight clock rule on PCI for consecutive data phases. Large grain tracking has the sum of the delays of all the data phases in an ADQ. Large grain tracking must wait longer to start transferring, and is more likely to disconnect due to eight or more clocks of accumulated delay. Large Grained Tracking. Large grained tracking is done at the ADQ level. Each time a transfer on the Destination Bus crosses an ADB, that ADQ may be transferred onto the Origination Bus. This is the policy that is executed whenever the transaction is a PMW or the Originating Bus is operating in PCI-X mode.

**Document Number: 273942-002** October, 2003 59

<sup>1.</sup> This is the case where FRAME# is de-asserted for the first data phase, and REQ64# was never asserted.



#### 2.2.12.5.4 Prefetching

The bridge supports a staged pre-fetch mechanism that enables fine tuning of how much data to pre-fetch. The feature remembers, from past experience, whether or not the needs of the initiator were sufficiently met, or whether even more data should be pre-fetched for a given transaction.

Prefetching is performed for memory read transactions when targeting prefetchable memory. The amount of data prefetched by bridge is programmable. When the prefetch size from one of the following tables is greater than 128 bytes, bridge disconnects at the last ADB it crosses.

Prefetch management uses a multiplication factor to determine the amount of data to be prefetched. Two sets of Prefetch factors are used, one for the Primary Bus and another for the Secondary Bus. The Secondary Bus has four control bits that select when a prefetch factor is applied to operations based on the **REQ**#/GNT# pairs. The first three **REQ**#/GNT#[2:0] pairs have individual enables for the prefetch factor, while the remaining **REQ**#/GNT# pairs [5:3] are controlled by a single control bit.

Disabling the prefetch factor results in the use of a prefetch factor equal to zero during all prefetch operations.

The bridge uses the 64-bit extension signals to initiate and complete prefetchable read transactions as a master. As a target bridge asserts **ACK64#** in response to an originator's assertion of **REQ64#** for read transactions to prefetchable memory<sup>1</sup>.

Prefetch factors are divided into two types, FirstRead and ReRead Factors. These factors are stored in the PF\_POLICY register; (see Section 2.5.2.7, "Read Prefetch Policy Register - RPPR" on page 110), and are used to compute the amount of data prefetched as shown in Table 12. The "(Factor+1)" value of the same table adds 1 to either the FirstRead or ReRead factors, depending upon whether the request is the first, or a continuing sequence.

The bridge determines whether a transaction might continue by looking for the following combination of events when the Master completes a prefetched transaction on the Origination Bus.

- bridge disconnects the transaction because data is exhausted.
- The Master still has FRAME# asserted at the disconnect.

This results in bridge storing the beginning address of cacheline. Up to eight beginning addresses are stored by bridge for prefetch ReRead transactions.

Every MR, MRL, and MRM transaction is compared to these stored values. When a match is detected the byte count is set based on the ReRead value. When a match does not occur the FirstRead value determines the byte count.

Prefetchable amounts are not guaranteed; when the queue fills before the full amount is prefetched then bridge disconnects the target and only returns the amount of data buffered. Prefetching is limited to not cross a 4KB boundary and only data up to the 4KB boundary is returned to the initiator.

#### Table 12. Prefetch Data Length

| Memory Operation | Alignment    | Read Size                  |
|------------------|--------------|----------------------------|
| Read             | 4 * DWORD    | (Factor +1) * 4 * DWORD    |
| Read Line        | cacheline    | (Factor +1) * cacheline    |
| Read Multiple    | 2 cachelines | (Factor +1) *2* cachelines |

<sup>1.</sup> Refer to Section 2.2.7, "64-Bit Operation" on page 51.



Prefetch size, in bytes, for Read, ReadLine Read Multiple transactions are shown in Table 13 through, Table 15 respectively<sup>1</sup>.

#### Table 13. Read Command Prefetch Size

| Factor | Bytes |
|--------|-------|
| 0      | 16    |
| 1      | 32    |
| 2      | 48    |
| 3      | 64    |
| 4      | 80    |
| 5      | 96    |
| 6      | 112   |
| 7      | 128   |

#### Table 14. Read Line Command Prefetch Size

| Factor | Cache Line Size |     |  |
|--------|-----------------|-----|--|
|        | 32              | 64  |  |
| 0      | 32              | 64  |  |
| 1      | 64              | 128 |  |
| 2      | 96              | 192 |  |
| 3      | 128             | 256 |  |
| 4      | 160             | 320 |  |
| 5      | 192             | 384 |  |
| 6      | 224             | 448 |  |
| 7      | 256             | 512 |  |

#### Table 15. Read Multiple Prefetch Size

| Factor | Cache Line Size |      |  |
|--------|-----------------|------|--|
|        | 32              | 64   |  |
| 0      | 64              | 128  |  |
| 1      | 128             | 256  |  |
| 2      | 192             | 384  |  |
| 3      | 256             | 512  |  |
| 4      | 320             | 640  |  |
| 5      | 384             | 768  |  |
| 6      | 448             | 896  |  |
| 7      | 512             | 1024 |  |

#### • FirstRead

The FirstRead value determines how much data is read on the FirstRead transaction for a given originator. Each type of read command (e.g., MEM\_Rd MRM, MRL) prefetches the amount of data specified in the three preceding Tables.

Requests not starting on cache line boundary are aligned to cache line at end of FirstRead transaction.

• ReRead (repeated until time-out)

The ReRead value determines how much data is read on the ReRead transaction for a given originator. Each type of read command (e.g., MEM\_Rd MRM, MRL) prefetches the amount of data specified in Table 13 through, Table 15.

**Document Number: 273942-002** October, 2003 61

<sup>1.</sup> The cache line size is a power of two. Masters should only start on a cache line boundary.



# 2.2.12.6 Transaction Ordering

Transaction ordering for all data traveling in the same direction across the bridge adheres to the Conventional PCI set of ordering rules. Note that all "Don't Care" (i.e., yes/no) entries are implemented as "yes" providing the maximum opportunity for making forward progress. There are no ordering requirements for transactions traveling in opposite directions.

Table 16. Conventional PCI Ordering Rules

| Row Pass Column? | PMW (Column 2) | DRR (Column 3) | DWR (Column 4) | DRC (Column 5) | DWC (Column 6) |
|------------------|----------------|----------------|----------------|----------------|----------------|
| PMW (Row 1)      | No             | Yes            | Yes            | Yes            | Yes            |
| DRR (Row 2)      | No             | Yes            | Yes            | Yes            | Yes            |
| DWR (Row 3)      | No             | Yes            | Yes            | Yes            | Yes            |
| DRC (Row 4)      | No             | Yes            | Yes            | Yes            | Yes            |
| DWC (Row 5)      | Yes            | Yes            | Yes            | Yes            | Yes            |



#### 2.2.13 PCI-X Bus Mode

This portion of the *Intel*<sup>®</sup> 80331 I/O Processor Component Specification describes bridge behavior when operating in PCI-X mode. The bridge behavior when dealing with areas of PCI-X operation that are open to interpretation is also highlighted. Please see the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a for all details related to PCI-X operation.

Unless otherwise noted in this section, bridge follows all rules of the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

#### 2.2.13.1 Attributes

Table 17 describes how bridge handles a few of the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a less crisply defined attribute fields.

#### Table 17. Bridge Implementation of Requester Attribute Fields

| Attribute             | Function                                                                                                                                                                                                                                                                                                                               |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| No Snoop (NS)         | As a target, this bit is forwarded with the transaction to allow a north bridge to not snoop the transaction. The bridge takes no action on this bit.                                                                                                                                                                                  |  |
| Relaxed Ordering (RO) | This bit allows relaxed ordering of transactions, which bridge does not permit. This bit is simply forwarded by bridge, and is never initially set by bridge.                                                                                                                                                                          |  |
| Tag                   | The bridge stores and forwards tag information presented to it by the original requester. The only exception to this behavior is when bridge must forward a request on behalf of a Conventional PCI requester. In this case there is not any tag (or other Sequence ID attributes) available, and bridge creates one for the sequence. |  |

#### 2.2.13.2 Special Notes for Burst Transactions

The PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a allows burst transactions to cross the minimum memory map boundary (in bridge case, this is 1 M) and 4 GB address boundaries. The bridge never does this as an originator or as a target. It always ends the transaction at a 1M boundary with an exception for Block Read Transactions which are handled as per the PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a. As a target, it disconnects transactions on these boundaries.

The bridge never issues an immediate response as a target for a burst read command, but it must be ready with 256 bytes of data space (two ADQs) when originating one. When it does not have this space available, it does not issue the transaction and wait for the internal congestion to resolve naturally.



#### 2.2.13.3 Split Transactions

#### 2.2.13.3.1 Completer Attributes

Completer attributes are normally passed through bridge without modification. However, certain error or other conditions may cause bridge to modify these bits.

Additionally, whenever an immediate response is received bridge becomes the completer and must report any error conditions it encounters in handling the transaction.

#### Table 18. Bridge Implementation Completer Attribute Fields

| Attribute                         | Function                                                                                                                                                                                         |  |  |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Byte Count Modified (BCM)         | This bit is used for diagnostic purposes. The bridge forwards this bit, but might also generate it as specified by the <i>PCI-X Addendum to the PCI Local Bus Specification</i> , Revision 1.0a. |  |  |
| Split Completion Error (SCE)      | The bridge sets this bit in accordance with the PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a.                                                                                |  |  |
| Split Completion<br>Message (SCM) | The bridge returns an SCM in the event that an error, corresponding to the current sequence has been detected. The bridge also returns an SCM whenever completing a split write transaction.     |  |  |

#### 2.2.13.3.2 Requirements for Accepting Split Completions

The bridge accepts (i.e., assert DEVSEL#) Split Completions targeting resources on its other side provided the following conditions are met:

- At least two ADQ of buffer space is available (otherwise the Split Completion is retried).
- The Sequence ID matches an outstanding Split Request that had been issued by bridge.
- There are less than two Split Completions of the same sequence ID currently staged within bridge internal buffers<sup>1</sup>.

#### 2.2.13.3.3 Split Completion Messages

64

Split Completion messages provide a means of reporting, to the requestor, status information relating to the current completion transaction. An SCM received by bridge is passed to the other bus unaltered.

The bridge generates a Split Completion Message (SCM) when it has encountered an error with a transaction on the Destination Bus. SCMs are issued for error conditions including Master, or Target Abort encountered on the Destination Bus, as well as for error conditions relating to corrupted completion transactions. In such cases bridge forwards an SCM reporting the error condition to the original requestor.

Additionally bridge generates an SCM for split write transactions that are completed on the destination bus as an immediate transaction.

Refer to Section 2.4, "Error Detection and Reporting" on page 73 for a complete, detailed description of error handling.

The bridge allows up to two SCs of the same sequence ID on the bridge at any given time. When a third Split Completion of the same sequence ID targets bridge, it is Retried.



#### 2.2.13.4 Transaction Ordering

Transaction ordering for all data traveling in the same direction across the bridge adheres to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a ordering rules for bridges. Note that all "Don't Care" choices (i.e., yes/no entries) have been chosen to align completely with the ordering policy for PCI Conventional Mode. By making the same policy decisions regarding the ordering of transactions flowing out of the bridge, the logic for controlling transaction queuing is greatly simplified. There are no ordering requirements for transactions traveling in opposite directions.

Table 19. PCI-X Ordering Rules

| Row Pass Column?                     | Memory Write<br>(Column 2) | Split Read Request<br>(Column 3) | Split Write Request<br>(Column 4) | Split Read<br>Completion<br>(Column 5) | Split Write<br>Completion<br>(Column 6) |
|--------------------------------------|----------------------------|----------------------------------|-----------------------------------|----------------------------------------|-----------------------------------------|
| Memory Write<br>(Row A)              | No <sup>a</sup>            | Yes                              | Yes                               | Yes                                    | Yes                                     |
| Split Read Request<br>(Row B)        | No                         | Yes                              | Yes                               | Yes                                    | Yes                                     |
| Split Write Request (Row C)          | No                         | Yes                              | Yes                               | Yes                                    | Yes                                     |
| Split Read<br>Completion<br>(Row D)  | No <sup>b</sup>            | Yes                              | Yes                               | Yes <sup>c</sup>                       | Yes                                     |
| Split Write<br>Completion<br>(Row E) | Yes                        | Yes                              | Yes                               | Yes                                    | Yes                                     |

a. The bridge ignores the Relaxed Ordering bit, and so therefore does not allow a PMW to pass a previously posted PMW.

b. The bridge ignores the Relaxed Ordering bit, and so therefore does not allow a Split Read Completion to pass a previously posted PMW.

c. The bridge allows Split Completions possessing different Sequence IDs to pass each other. Split Completions possessing the same Sequence ID must play out in the order that they were received. The bridge accepts two such Split Completions on chip at any given time.



#### 2.2.13.5 Transaction Termination as a PCI-X Target

#### 2.2.13.5.1 Retry

The bridge retries a transaction when any of the following conditions is true.

- Target queue (Request queue) is full.
- When receiving a third Split Completion of the same sequence (bridge allows a maximum of two on chip at any time).

The bridge stores no state from a transaction that it has target terminated with retry.

Retries due to buffer full conditions should be infrequent as bridge supports a deep request queue for pending operations. Additionally, a Split Queue keeps transactions that are in process, between a Split Response and the final Split Completion for that sequence.

#### 2.2.13.5.2 Split Response

The bridge responds to all "splitable" transactions with a Split Response, when not retried due to insufficient buffer availability. One exception to this is for PCI Configuration read cycles targeting bridge internal configuration registers.

#### 2.2.13.5.3 Split Completion Errors

During the address phase bridge looks for an exact Sequence ID match between a split completion transaction on the bus with any pending completion enqueued within its corresponding Split Queue. Unless there is an exact match, a split completion transaction that would appear to be targeting an agent on the opposite side of bridge is ignored, causing the Completer to Master Abort.

When a problem with the byte count is detected within the completion attribute phase, bridge target aborts the completer.

Refer to Section 2.4, "Error Detection and Reporting" on page 73 for a complete, detailed description of error handling.

#### 2.2.13.6 Bridge Buffer Requirements

The bridge always has at least 256 bytes (2 ADQ) in use by a PMW or reserved for incoming PMW transactions. The bridge does not implement the split completion buffer pre-allocation algorithm as proposed by the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

All transactions except for Split Completion, Memory Write, and Memory Write Block transactions which are immediate transactions, and so cannot be converted to split transactions.



### 2.3 Arbitration

The bridge provides an integrated secondary bus arbiter.

The internal arbiter is able to make more intelligent arbitration decisions based on information available to it internally; information not typically available external to the bridge.

#### 2.3.1 Arbitration Events

An arbitration event is defined as the act of evaluating all bus requests, applying arbitration policy algorithms, and assigning a new bus grant. Within a busy environment PCI arbitration events occur in a "hidden" fashion, where the next bus owner is chosen during the current bus transaction thereby minimizing bus latency in turning the bus over to its new owner.

Aside from performing arbitration events within an active environment, two other cases exist:

- Idle bus with no pending requests (bus parking).
- Granted agent is non-responsive (Grant Time-out situation).

#### 2.3.1.1 Arbitrating in Traffic

The bridge secondary bus arbiter always performs arbitration events for an active secondary bus during execution of the current transaction, effectively "hiding" any additional latencies when turning the bus over to it's next owner. Independent of the secondary bus mode of operation (Conventional PCI or PCI-X), bridge always performs an arbitration event as follows:

- 1. De-assert the current GNT# as soon as bridge has observed that the new bus owner has begun the next bus transaction (i.e., FRAME# assertion sampled).
- 2. Within the current transaction bridge evaluates all outstanding bus requests and determines which agent is granted the bus next.
- 3. GNT# is asserted to the next bus owner while the current transaction is executing.

#### Figure 3. Arbitration Events





#### 2.3.1.2 Bus Parking

When the secondary bus is idle with no pending bus requests, the bridge arbiter parks bus ownership with either the last granted agent or itself depending on the programming of the Secondary Bus Arbiter Control register.

When emerging from S\_RST# the secondary bus is always internally parked at bridge.

Refer to Section 2.5.2.1, "Secondary Arbiter Control/Status Register - SACSR" on page 102 for details on the SACSR device specific register (offset 41h).

#### 2.3.1.3 Grant Time-Out

Once a grant has been asserted on the bus, and the bus has gone idle, the granted agent is required to begin its initial transaction, indicated by the assertion of FRAME# within a maximum number of clocks. When the bridge secondary bus is operating in PCI Conventional mode the maximum permissible delay is 16 clocks. When the bridge secondary bus is operating in PCI-X mode the maximum permissible delay is 6 clocks. This requirement intends to ensure that PCI agents do not request the bus unless they are prepared to use it.

The bridge employs a Grant Time-out counter mechanism that begins counting from the time the bus goes to the idle state with a bus grant asserted. When FRAME# is not sampled in the asserted state by the granted agent before the time-out counter expires, the agent's grant is de-asserted, and a new arbitration event occurs.

**Note:** In an idle, bus parked situation, the Grant Time-out counter does not apply.

Agents that are slow to assert FRAME# may, when operating on a busy bus, be starved as a result of their PCI non-compliant behavior.

For diagnostic purposes, status information detailing the detection of a Grant Time-out along with information as to which secondary agent was in violation of the *PCI Local Bus Specification*, Revision 2.3, is available in the SACSR register.

Refer to Section 2.5.2.1, "Secondary Arbiter Control/Status Register - SACSR" on page 102 for details on the SACSR device specific register (offset 41h).



# 2.3.2 Multi-Transaction Timer (MTT)

The bridge incorporates a multi-transaction timer that, in conjunction with the granted agent MLT and the Grant Time-out mechanism, enables the grantee to perform multiple transactions within a single arbitration cycle. Whereas an agent MLT governs the maximum duration of a single PCI transaction, the MTT residing in the secondary arbiter block, enables multiple PCI transactions to proceed by effectively establishing a minimum grant time period.

One MTT counter/value supports all secondary bus agents. Mask bits individually enable, or disable the MTT for each agent on the secondary bus.

#### Figure 4. Multi-Transaction Timer Operation



For MTT programming model details refer to Section 2.5.2.6, "Bridge Multi-Transaction Timer Register - BMTTR" on page 109.



#### 2.3.2.1 MTT Rules

- The MTT counter is loaded with its programmed value each time, as a result of an arbitration event, a GNT# is asserted to an agent other than the last bus owner with an exception case for a bus parked situation. When the bus is in an idle, parked GNT# situation the MTT programmed value is re-loaded each time the park agent's GNT# is re-asserted.
- The MTT countdown begins when the granted agent's initial assertion of FRAME# is sampled by bridge on the bus.
- An agent wishing to utilize the MTT is required to continually assert its REQ# signal
  throughout the current transaction in its entirety. When at any time during the current
  transaction the agent de-asserts it's REQ# signal, MTT usage is terminated for the remainder
  of the current arbitration cycle.
- No greater than 4 transactions is re-granted by bridge during any single arbitration cycle, regardless of whether or not the MTT had expired.

When the following three conditions are satisfied at the next arbitration event then the bridge arbiter re-asserts the current owner's GNT# enabling a new transaction to begin from the same secondary bus agent.

- The current bus owner **REQ**# is sampled asserted, having never been de-asserted throughout the current transaction.
- The MTT count has not yet expired.
- The number of consecutive transactions already executed by this same bus agent is three or less.

For each subsequent transaction within the same arbitration cycle the grantee's MLT is re-initialized to its programmed value, while the MTT continues to count down. When during a transaction the grantee's MLT expires, the grantee should self evict, and de-assert its **REQ**# thereby ending its current ownership of the bus.



#### 2.3.3 PCI Conventional Mode Arbitration

When operating in PCI Conventional mode the bridge conducts arbitration using a two tiered "round robin" rotating scheme (Figure 5).

When bridge owns the bus it plays out any newly enqueued delayed transaction requests, or PMW data in accordance with PCI ordering rules.

Bus agents can be programmed to reside in the high (top), or lower priority ring of arbitration. Refer to the SACSR register (offset 41h).

Figure 5. Two-Tiered Round Robin Rotating Scheme



Refer to Section 2.5.2.1, "Secondary Arbiter Control/Status Register - SACSR" on page 102 for detailed programming interface information.



#### 2.3.4 PCI-X Arbitration

The bridge secondary arbitration scheme for PCI-X mode is nearly identical to that of its PCI Conventional arbitration scheme. The only real difference is that when the secondary bus is running in PCI-X mode bridge requests the bus for playing out split completions, as well as for playing out new split requests and PMW immediate data.

#### 2.3.4.1 Fair Internal Arbitration

Split Completions, new internal requests, and posted Memory Write data are rotated fairly when determining the next transaction to be played out of bridge on its next bus ownership. Due to the effect of the MLT, bridge interleaves other valid split completions in an attempt to promote more uniform forward progress for all agents through the bridge.

Figure 6 below illustrates the PCI-X arbitration scheme.

Figure 6. PCI-X Priority Rings



#### 2.3.4.2 Retry or Disconnected Request

72

When bridge mastered transaction receives either a Target Retry or other Target Disconnect response, bridge internal transaction flow arbiter<sup>1</sup> ensures that this particular internal request is masked until all other currently outstanding requests have been honored. In a sense this could be viewed as a third level lower arbitration ring for bridge that is underneath the "New Internal Requests" ring.

Request masking is only done for internal requests that have been target terminated. The bridge does not block grants to external agents based on Retry or a Disconnect. External agents may have multiple functions with request streams active that are not related to the request that was retried. External agents simply wait for their next slot in the normal arbitration queue.

<sup>1.</sup> Arbiter/control logic that determines which of the valid internal transactions plays out next. Not to be confused with the PCI bus arbiter.



## 2.4 Error Detection and Reporting

Error detection and reporting are separate items within bridge. Error detection is a continuous on going operation. Every detected error is logged in the status bits for reporting errors at all times.

When error reporting is enabled for an interface; PER set in the Command and Bridge Control registers for the primary and secondary busses respectively allows bridge to respond to error detection. Further, errors can be reported to the system by the assertion of **P\_SERR**#, which is enable by the SERR# Enable bit in the Command register.

During normal operation all transactions are passed from one interface to the other without modification, unless they require special action by bridge. All phases of a transaction are passed from one bus to the other without modification including address and attributes.

## 2.4.1 Normal Operation

Address, attributes and data are accepted on the Origination Bus and passed without modification for most types of transactions. Parity for each phase of a transaction is also passed though the bridge without modification. Parity is generated by bridge for the following types of transactions:

- Type 1 configuration to Special cycle conversion.
- Type 1 configuration to Type 0 conversion.
- The bridge generated Split Completions.

Detection of errors always results in the error detection state being set. This is true for all types of errors detected by bridge.



## 2.4.2 Response Enabled

Each bus has a separate PER control bit to enable bridge responding to errors. When the PER bit is set bridge takes action on each transaction depending on the type of error. Types of errors on which action is taken are:

 Table 20.
 Detected Error Types and Action Taken

| Error Type                                | Action Taken                                                                                                                                                                                                                   |  |  |  |  |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| address or attribute parity               | For all transactions in error it sets the Detected Parity Error bit in the associated buses Status register. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> . |  |  |  |  |
|                                           | Split Completion: The bridge target aborts (when requestor ID matches) or master abort. There is no SCM error message generated.                                                                                               |  |  |  |  |
|                                           | Other transaction: Generates a SCM response to all transactions needing a Split Completion response. Discards transaction and associated data.                                                                                 |  |  |  |  |
| data parity                               | Sets Detected Parity Error bit in the Status register. Asserts x_PERR# on the associated bus.                                                                                                                                  |  |  |  |  |
|                                           | PCI-X transaction: Store and forward all data including parity bit.                                                                                                                                                            |  |  |  |  |
|                                           | Delayed transaction: Discard transaction and purge data from buffers.                                                                                                                                                          |  |  |  |  |
|                                           | Type 0 Configuration Write Transaction (Conventional Mode or PCI-X Mode) Bridge configuration register is written with data.                                                                                                   |  |  |  |  |
| x_PERR#<br>assertion by<br>external agent | Set Master Data Parity Error bit in the Status register for the associated bus                                                                                                                                                 |  |  |  |  |
| Master Abort                              | Set Received Master Abort bit in the associated Status register. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> .                                             |  |  |  |  |
|                                           | PCI and read: Send FFFF FFFFh as read data on the Origination bus.                                                                                                                                                             |  |  |  |  |
|                                           | PCI-X: Generate a SCM message to all transactions that received a split response.                                                                                                                                              |  |  |  |  |
|                                           | Set Received Target Abort bit in the associated Status register.                                                                                                                                                               |  |  |  |  |
| Target Abort                              | PMW: Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> .                                                                                                         |  |  |  |  |
| S_SERR#                                   | Set the Received System Error bit in the Secondary Status Register. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>P_SERR#</b> .                                        |  |  |  |  |
| Discard Timer                             | Set the Discard Timer bit in the associated Status register. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> .                                                 |  |  |  |  |
| Retry Timer                               | After 2 <sup>24</sup> retries on the destination bus discard the transaction. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> .                                |  |  |  |  |
| Unexpected<br>Split Completion            | When a Split Completion does not match byte count, or address field is incorrect. Conditionally sets Signaled System Error bit in the Status register when it causes an assertion of <b>SERR#</b> .                            |  |  |  |  |

## 2.4.3 P\_SERR# Assertion

Asserted when an error capable of **SERR**# assertion occurs, the SERR# enable bit in the Command register is set, and that particular error condition has been enabled to assert **P\_SERR**# in the P\_ERR# Assertion Control Register. In all cases the assertion of **SERR**# results in setting of the Signaled System Error bit in the Status register.



# 2.5 Programming Interface

The bridge programming interface is provided only in the configuration register address space, which is accessible from the primary bus interface. The bridge registers are not accessible by the Intel<sup>®</sup> XScale core. The space is divided into four groups with the ranges indicated in Table 21.

#### Table 21. Configuration Register Address Space Groupings and Ranges

| Register Group             | Configuration Offset |
|----------------------------|----------------------|
| Standard PCI Configuration | 00-3Fh               |
| Device Specific Registers  | 40-A7h               |
| Reserved                   | A8-CBh               |
| Enhanced Capability List   | CC-FFh               |

Details of three of these four groups are given in the following subsections. The Reserved section needs no further explanation.

The following sections define bridge programming interface. In addition to the minimum standard set of PCI-to-PCI bridge features, bridge also supports several device specific features as well as other PCI standard enhanced capabilities. The PCI enhanced capabilities supported consist of:

#### Table 22. PCI Enhanced Capabilities Supported

| Enhanced Capability                                              | Configuration Offset |
|------------------------------------------------------------------|----------------------|
| PCI Bus Power Management Interface Specification, Revision 1.1   | DCh                  |
| PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a | F0h                  |

PCI enhanced capabilities are enumerated, and managed via the PCI standard Capabilities linked list infrastructure. System software discovers the existence of enhanced capabilities by sampling the state of the PCI Status Register (Offset 06h). Bit(4) of the PCI Status Register sampled as a 1b indicates that a capabilities linked list for at least one enhanced capability exits, beginning at the address offset contained in the Capabilities Pointer register, located at offset 34h.

Table 23, "Standard PCI Type 1 Configuration Space Address Map" on page 76, Table 44, "Bridge Device-Specific Configuration Address Map" on page 101 and Table 56, "Enhanced Capabilities Register File" on page 119provide an overview of bridge Configuration Space Registers. Detailed register definitions follow each table.

**Note:** Some register bits have defined behavior that differs depending upon the mode of the subject interface. (i.e., Conventional PCI or PCI-X). In such cases the behavior is explicitly spelled out for each mode. In all other cases the stated definition applies to both modes of operation.



# 2.5.1 Standard PCI Configuration Header Registers (Offset 00H-3FH)

#### Table 23. Standard PCI Type 1 Configuration Space Address Map

| Byte 3                                    | Byte 2                    | Byte 1                               | Byte 0             | Configu-<br>ration Byte<br>Offset |  |
|-------------------------------------------|---------------------------|--------------------------------------|--------------------|-----------------------------------|--|
| Devid                                     | ce ID                     | Vendor ID                            |                    | 00h                               |  |
| Primary                                   | / Status                  | Primary Command                      |                    | 04h                               |  |
|                                           | Class Code                |                                      | RevID              | 08h                               |  |
| (reserved)                                | Header Type               | Primary MLT                          | Primary CLS        | 0Ch                               |  |
|                                           | Reserved                  |                                      |                    |                                   |  |
|                                           | 14h                       |                                      |                    |                                   |  |
| Secondary MLT                             | Subordinate Bus<br>Number | Secondary Bus<br>Number              | Primary Bus Number | 18h                               |  |
| Seconda                                   | ry Status                 | I/O Limit                            | I/O Base           | 1Ch                               |  |
| Non-prefetchable Me                       | emory Limit Address       | Non-prefetchable Memory Base Address |                    | 20h                               |  |
| Prefetchable Mem                          | ory Limit Address         | Prefetchable Memory Base Address     |                    | 24h                               |  |
| Р                                         | 28h                       |                                      |                    |                                   |  |
| Р                                         | 2Ch                       |                                      |                    |                                   |  |
| I/O Limit Upper 16 Bits I/O Base Upper 16 |                           |                                      |                    | 30h                               |  |
|                                           | 34h                       |                                      |                    |                                   |  |
|                                           | 38h                       |                                      |                    |                                   |  |
| Bridge                                    | 3Ch                       |                                      |                    |                                   |  |

The following subsections detail the bit assignments, and corresponding definitions for each of the bridge standard PCI configuration Type 1 header registers.

Register bits of the type "RC" bits are readable, and writable only to the extent that they are cleared by writing a 1b to them. Writing 0b to a RC bit has no affect on the current state of the bit.

Register bits of the type "Reserved" must always return 0b when read, and writes to them must have no affect.

Default power on reset states are provided for all but those fields that are device dependent. Device specific defaults are labeled "DS".



## 2.5.1.1 Identifiers - ID

Contains the vendor and device identifiers.

#### Table 24. Identifiers - ID





#### 2.5.1.2 Primary Command Register - PCR

Controls how bridge behaves on its primary interface, and is the same as all other devices, with the exception of the VGA Palette Snoop bit. As this component is a bridge, additional command information is located in a separate register called "Bridge Control" located at offset 3Eh.

#### Table 25. Primary Command Register - PCR (Sheet 1 of 2)





#### Table 25. Primary Command Register - PCR (Sheet 2 of 2)





#### 2.5.1.3 Primary Status Register - PSR

Bits in this register are either Read Only (RO) or Read Clear (RC).

#### Table 26. Primary Status Register - PSR (Sheet 1 of 2)



80



#### Table 26. Primary Status Register - PSR (Sheet 2 of 2)





## 2.5.1.4 Revision ID Register - RID

Revision ID Register.

#### Table 27. Revision ID Register - RID





## 2.5.1.5 Class Code Register - CCR

This contains the class code, sub class code, and programming interface for the device.

#### Table 28. Class Code Register - CCR





## 2.5.1.6 Cacheline Size Register - CLSR

This indicates the cache line size of the host system.

#### Table 29. Cacheline Size Register - CLSR

84



October, 2003 Document Number: 273942-002



#### 2.5.1.7 Primary Latency Timer Register - PLTR

Primary bus MLT.

#### Table 30. Primary Latency Timer Register - PLTR





## 2.5.1.8 Header Type Register - HTR

This register indicates bridge PCI Configuration Header Type. The bridge reports that it is a single function (i.e., not a multi-function device), and that its PCI header type conforms to the PCI standard Type 1 header layout.

#### Table 31. Header Type Register - HTR





#### 2.5.1.9 Bus Number Register - BNR

This register is used to configure bridge primary, secondary, and maximum subordinate bus numbers.

#### Table 32. Bus Number Register - BNR





#### 2.5.1.10 Secondary Latency Timer Register - SLTR

Secondary MLT.

#### Table 33. Secondary Latency Timer Register - SLTR





## 2.5.1.11 I/O Base and Limit Register - IOBL

This register defines, by way of base and limit fields, a 4K Byte aligned address range. I/O transactions originating on bridge primary bus that address an I/O location falling within the range specified in this register are subsequently forwarded to bridge secondary PCI bus<sup>1</sup>.

I/O transactions on the primary bus that address an I/O location that is outside of the range specified by the contents of this register is not forwarded by bridge<sup>2</sup>.

#### Table 34. I/O Base and Limit Register - IOBL



**Document Number: 273942-002** October, 2003 89

<sup>1.</sup> Provided that the I/O Space Enable bit of the PCI Command register is set.

<sup>2.</sup> With the exception of legacy I/O transactions when enabled (e.g., VGA palette snoops).



#### 2.5.1.12 Secondary Status Register - SSR

#### Table 35. Secondary Status Register - SSR

90





#### 2.5.1.13 Memory Base and Limit Register - MBL

This register defines, by way of base and limit fields, a 1M Byte aligned address range.

A memory transaction, whose address is within the address range specified by this register is treated as a non-prefetchable transaction. The non-prefetchable memory address window is typically used for accessing memory mapped I/O locations where read side-affects may occur.

#### Table 36. Memory Base and Limit Register - MBL





## 2.5.1.14 Prefetchable Memory Base and Limit Register - PMBL

This register defines, by way of base and limit fields, a 1M Byte aligned address range. Memory transactions originating on the bridge primary bus that address a memory location falling within the range specified by this register are subsequently forwarded to bridge secondary PCI bus<sup>1</sup>.

A memory transaction, whose address is within the address range specified by this register is treated as a prefetchable transaction. The prefetchable memory address window must only be used for accessing memory locations where there are no read side-affects.

The guarantee of no read side affects enables bridge to speculatively prefetch additional read data in anticipation of its being requested shortly thereafter.

#### Table 37. Prefetchable Memory Base and Limit Register - PMBL



<sup>1. .</sup> Provided that the Memory Space Enable bit of the PCI Command register is set.



## 2.5.1.15 Prefetchable Memory Base Upper 32 Bits - PMBU32

This defines the upper 32 bits of the prefetchable address base register.

#### Table 38. Prefetchable Memory Base Upper 32 Bits - PMBU32





## 2.5.1.16 Prefetchable Memory Limit Upper 32 Bits - PMLU32

This defines the upper 32 bits of the prefetchable address base register.

#### Table 39. Prefetchable Memory Limit Upper 32 Bits - PMLU32



94 October, 2003 **Document Number: 273942-002** 



## 2.5.1.17 I/O Base and Limit Upper 16 Bits - IOBLU16

## Table 40. I/O Base and Limit Upper 16 Bits - IOBLU16





## 2.5.1.18 Capabilities Pointer Register - Cap\_Ptr

Contains the pointer to the first entry in the capabilities list.

## Table 41. Capabilities Pointer Register - Cap\_Ptr





## 2.5.1.19 Interrupt Information - INTR

This register contains information on interrupts and while required is not utilized by PCI-to-PCI bridges.

#### Table 42. Interrupt Information - INTR





#### 2.5.1.20 **Bridge Control Register - BCR**

This register provides extensions to the Command register that are specific to a PCI-to-PCI bridge. The Bridge Control register provides many of the same controls for the secondary interface that are provided by the Command register for the primary interface.

Some bits affect operation of both interfaces of the bridge.

#### Table 43. **Bridge Control Register - BCR (Sheet 1 of 3)**





#### Table 43. Bridge Control Register - BCR (Sheet 2 of 3)



99



#### Table 43. Bridge Control Register - BCR (Sheet 3 of 3)





## 2.5.2 Device Specific Registers

The following sections detail the programming interface for bridge device specific registers. These registers reside in bridge PCI configuration address space with an offset range of 40h - CBh.

## Table 44. Bridge Device-Specific Configuration Address Map

| Byte 3                   | Byte 2     | Byte 1                    | Byte 0   | Configuration<br>Byte Offset |
|--------------------------|------------|---------------------------|----------|------------------------------|
| Bridge Control 0         | Arbiter Co | ntrol/Status              | Reserved | 40h                          |
| Bridge (                 | Control 2  | Bridge Control 1          |          | 44h                          |
| Rese                     | erved      | Bridge Status             |          | 48h                          |
|                          | 4Ch        |                           |          |                              |
| Prefetc                  | h Policy   | Multi-Transaction Timer   |          | 50h                          |
| Reserved Pre-boot Status |            | P_SERR# Assertion Control |          | 54h                          |
| Reserved Reserved        |            | Secondary Decode Enable   |          | 58h                          |
| Rese                     | 5Ch        |                           |          |                              |
|                          | 5Ch        |                           |          |                              |
|                          | 68h:CBh    |                           |          |                              |



#### 2.5.2.1 Secondary Arbiter Control/Status Register - SACSR

#### Table 45. Secondary Arbiter Control/Status Register - SACSR





#### 2.5.2.2 Bridge Control Register 0 - BCR0

#### Table 46. Bridge Control Register 0 - BCR0





## 2.5.2.3 Bridge Control Register 1 - BCR1

#### Table 47. Bridge Control Register 1 - BCR1 (Sheet 1 of 2)





#### Table 47. Bridge Control Register 1 - BCR1 (Sheet 2 of 2)





## 2.5.2.4 Bridge Control Register 2 - BCR2

#### Table 48. Bridge Control Register 2 - BCR2





#### 2.5.2.5 Bridge Status Register - BSR

#### Table 49. Bridge Status Register - BSR (Sheet 1 of 2)





#### Table 49. Bridge Status Register - BSR (Sheet 2 of 2)





# 2.5.2.6 Bridge Multi-Transaction Timer Register - BMTTR

The bridge Multi-Transaction Timer mechanism (MTT) provides the bridge itself, and any secondary bus master a configurable extended grant duration when desired. The contents of this register have no affect on the operation of the bridge when the internal secondary arbiter is disabled.

The MTT register specifies a common value that establishes a total grant time that applies for all secondary masters. The default value for MTT is 64 PCI clocks.

Refer to Section 2.3.1, "Arbitration Events" on page 67, and Section 2.3.2, "Multi-Transaction Timer (MTT)" on page 69 for detailed information regarding the operation of, and rules governing, the Multi-Transaction Timer.

### Table 50. Bridge Multi-Transaction Timer Register - BMTTR





# 2.5.2.7 Read Prefetch Policy Register - RPPR

The Prefetch Policy register is used when the initiating bus is operating in Conventional PCI mode to determine bridge read prefetch parameters.

The amount of data that is to be prefetched is based on the type of read command, i.e., MRL, MRM or a Memory Read targeting pre-fetchable memory space, coupled with the read data demand demonstrated by the PCI initiator.

This register configures a pre-fetchable read byte count based on a "FIRSTREAD" parameter, and a subsequent, larger read byte count based on the "REREAD" parameter that takes affect for a given initiator when its initial demands are not satisfied by the initial pre-fetch amount. (i.e., bridge, not the delayed read transaction initiator, is forced to disconnect the initial read transaction on the originating bus, leaving the initiator waiting for additional read data.)

This "smart" pre-fetch policy may be disabled, in which case imposes a fixed pre-fetch policy, also based on read command type. The first three secondary **REQ**#/GNT# pairs have individual enable/disable bits. A single enable/disable bit governs smart pre-fetch operation for the remainder of the secondary **REQ**#/GNT# pairs.

The primary bus interface does not require an enable bit. The affect of leaving the Primary bus FirstRead, and ReRead parameters in their power on default states establishes the equivalent behavior.

The bridge supports separate smart pre-fetch parameters for the Primary and secondary bus interfaces.

Refer to Section 2.2.12.5.4, "Prefetching" on page 60 for detailed information regarding the operation of the Prefetch feature.

#### Table 51. Read Prefetch Policy Register - RPPR (Sheet 1 of 2)





Table 51. Read Prefetch Policy Register - RPPR (Sheet 2 of 2)





# 2.5.2.8 P\_SERR# Assertion Control - SERR\_CTL

This register specifies which events, when detected, cause bridge to assert **SERR**# on its primary bus. This register does not affect the behavior of the bridge unless the SERR# Enable bit (PCI command register) is set which enables, subject to the further conditions specified herein, the assertion of **SERR**# on the primary bus.

#### Table 52. P\_SERR# Assertion Control - SERR\_CTL (Sheet 1 of 3)





# Table 52. P\_SERR# Assertion Control - SERR\_CTL (Sheet 2 of 3)





#### Table 52. P\_SERR# Assertion Control - SERR\_CTL (Sheet 3 of 3)



114 October, 2003 **Document Number: 273942-002** 



# 2.5.2.9 Pre-Boot Status Register - PBSR

This register provides status for each of the strapable configuration settings. Status is updated, and is available immediately following power on reset.

# Table 53. Pre-Boot Status Register - PBSR





# 2.5.2.10 Secondary Decode Enable Register - SDER

The Secondary Decode Enable Register controls the address decode functions on the Secondary PCI interface of the bridge unit.

The Private Memory Space Enable bit allows a private memory space to be created on the Secondary PCI bus. When this bit is set, bridge overrides its secondary inverse decode logic and not forward upstream any secondary bus initiated DAC Memory transactions with AD(63)=1b.

Table 54. Secondary Decode Enable Register - SDER





# 2.5.2.11 Secondary IDSEL Select Register - SISR

The Secondary IDSEL Select Register controls the usage of **S\_AD[25:16]** in Type 1 to Type 0 conversions from the Primary to Secondary interface. In default operation, a unique encoding on Primary addresses **P\_AD[15:11]** results in the assertion of one bit on the Secondary address bus **S\_AD[31:16]** during a Type 1 to Type 0 conversion (See Section 2.2.5.1.). This is used for the assertion of **IDSEL** on the device being targeted by the Type 0 configuration command. This register allows Secondary address bits **S\_AD[25:16]** to be used to configure private PCI devices by forcing Secondary address bits **S\_AD[25:16]** to all zeros during Type 1 to Type 0 conversions, regardless of the state of Primary addresses **P\_AD[15:11]** (device number in Type 1 configuration command).

When any address bit within **S\_AD[25:16]** is to be used for private Secondary PCI devices, the user must guarantee that the corresponding bit in the SISR register is set before the host tries to configure the hierarchical PCI buses.

Private devices can be initially configured in 80331 through the PRIVMEM reset strap. Pulling this input high during reset causes the SISR bits to default to one, resulting in Device Numbers zero through nine (devices with **IDSEL** tied to **S\_AD[25:16]**) to be hidden from the Primary PCI interface.

Table 55. Secondary IDSEL Select Register - SISR (Sheet 1 of 2)





Table 55. Secondary IDSEL Select Register - SISR (Sheet 2 of 2)





# 2.5.3 PCI Extended Capabilities List

The following sections detail the programming interface for the bridge Capabilities List. This standard link list infrastructure lays out the programming model for the following extended capabilities:

- PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a compliant.
- PCI Bus Power Management Interface Specification, Revision 1.1 compliant.

Table 56 outlines the address map for the extended capabilities, followed by the individual sub sections where full interface details are provided.

#### Table 56. Enhanced Capabilities Register File

| Byte 3        | Byte 2                                     | Byte 1        | Byte 0        | Configuration<br>Byte Offset |  |  |
|---------------|--------------------------------------------|---------------|---------------|------------------------------|--|--|
| Power Manager | nent Capabilities                          | Next Item Ptr | Capability ID | DCh                          |  |  |
| PM Data       | PPB Support<br>Extensions                  | Power Mana    | E0h           |                              |  |  |
| Rese          | erved                                      | Reserved      | Reserved      | E4h                          |  |  |
|               | E8h                                        |               |               |                              |  |  |
| Reserved      | Reserved                                   | Reserved      | Reserved      | ECh                          |  |  |
| PCI-X Seco    | ndary Status                               | Next Item Ptr | Capability ID | F0h                          |  |  |
|               | PCI-X Bridge Status                        |               |               |                              |  |  |
|               | PCI-X Upstream Split Transaction Control   |               |               |                              |  |  |
|               | PCI-X Downstream Split Transaction Control |               |               |                              |  |  |



# 2.5.3.1 PCI Bus Power Management

# 2.5.3.1.1 Power Management Capabilities Identifier - PM\_CAPID

Read by system software as 01h to indicate that this is the PCI Power Management data structure.

#### Table 57. Power Management Capabilities Identifier - PM\_CAPID





# 2.5.3.1.2 Next Item Pointer - PM\_NXTP

This points to the next item in the function's capability list.

# Table 58. Next Item Pointer - PM\_NXTP





#### 2.5.3.1.3 Power Management Capabilities Register - PMCR

This register reports bridge power management capabilities.

#### Table 59. Power Management Capabilities Register - PMCR





#### 2.5.3.1.4 Power Management Control / Status Register - PMCSR

This register is used to manage the bridge power management state as well as to enable/monitor PMEs.

#### Table 60. Power Management Control / Status - Register - PMCSR





# 2.5.3.1.5 Power Management Control / Status PCI-to-PCI Bridge Support - PMCSR BSE

Indicates support for PCI bridge specific functionality.

# Table 61. Power Management Control / Status PCI to PCI Bridge Support - PMCSR\_BSE



124 October, 2003 **Document Number: 273942-002** 



# 2.5.3.1.6 Power Management Data Register - PMDR

The data register is not supported.

# Table 62. Power Management Data Register - PMDR





# 2.5.3.2 PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a

# 2.5.3.2.1 PCI-X Capabilities Identifier - PX\_CAPID

Identifies this item in the Capabilities list as a PCI-X register set. It returns 07h when read.

#### Table 63. PCI-X Capabilities Identifier - PX\_CAPID





#### 2.5.3.2.2 Next Item Pointer - PX\_NXTP

Indicates where the next item in the capabilities list resides. The PCI-X capability register block is normally the end of the bridge Capabilities List, so "00h" is the power on reset default state.

# Table 64. Next Item Pointer - PX\_NXTP





#### 2.5.3.2.3 PCI-X Secondary Status - PX\_SSTS

# Table 65. PCI-X Secondary Status - PX\_SSTS





#### 2.5.3.2.4 PCI-X Bridge Status - PX\_BSTS

Identifies PCI-X capabilities and current operating mode of the bridge.

# Table 66. PCI-X Bridge Status - PX\_BSTS





#### 2.5.3.2.5 PCI-X Upstream Split Transaction Control - PX\_USTC

This register identifies controls behavior of bridge buffers for forwarding Split Transactions from the secondary bus to primary.

#### Table 67. PCI-X Upstream Split Transaction Control - PX\_USTC





#### 2.5.3.2.6 PCI-X Downstream Split Transaction Control - PX\_DSTC

This register controls behavior of bridge buffers for forwarding Split Transactions from primary to the secondary bus.

#### Table 68. PCI-X Downstream Split Transaction Control - PX\_DSTC





# This Page Intentionally Left Blank



# Address Translation Unit

3

This chapter describes the operation modes, setup, and implementation of the module which interfaces between the PCI bus and the Intel® 80331 I/O processor (80331) internal bus.

# 3.1 Overview

As indicated in Figure 7, the Address Translation Unit (ATU) — the interface between the PCI bus and the on-chip internal bus — consists of the Address Translation Unit (ATU), the Expansion ROM Unit and the Messaging Unit (MU) described in Chapter 4, "Messaging Unit"

The ATU supports both inbound and outbound address translation. The ATU provides access between the PCI bus and the 80331 internal bus. The ATU and the MU share PCI address space.

Transactions initiated on the PCI bus and targeted at the 80331 internal bus are referred to as *inbound transactions* (PCI to internal bus). Transactions initiated on the 80331 internal bus and targeted at the PCI bus are referred to as *outbound transactions* (internal bus to PCI). The ATU accepts multiple inbound or outbound transactions and processes them simultaneously.

During inbound transactions, the ATU converts PCI addresses (initiated by a PCI bus master) to internal bus addresses and initiates the data transfer on the 80331 internal bus. During outbound transactions, the ATU converts internal bus addresses to PCI addresses and initiates the data transfer on the PCI bus.

The Messaging Unit provides a mechanism for the system processor and the 80331 to transfer control information. The Messaging Unit occupies the first 4 Kbytes in Memory Window 0 of the ATU address space. PCI masters on the PCI interface of the 80331 access the MU by addressing the ATU anywhere in the first 4 KB offset from the ATU Base Address Register 0.

The Expansion ROM provides the PCI mechanism for downloading device/board driver code during system boot sequence. It consists of a separate inbound address range which accesses a Flash EPROM device connected through the 80331 memory controller. Refer to the *PCI Local Bus Specification*, Revision 2.3 for details of Expansion ROM usage.

The Address Translation Unit, the Expansion ROM Translation Unit, and the Messaging Unit appear as a single PCI device on the PCI bus. That is, the 80331 is a single-function device.

The ATU supports the PCI 64-bit and 66 MHz extensions providing up to 532 Mbytes/sec of PCI bandwidth as well as the PCI-X 64-bit and 133 MHz extensions providing up to 1064 Mbytes/sec of PCI bandwidth. On the internal interface, the ATU implements the 80331 internal bus protocol which provides for a maximum of 1600 Mbytes/sec using 64-bit/200 MHz signaling.

The ATU includes three extended capability headers that implement Power Management capability as defined by the *PCI Bus Power Management Interface Specification*, Revision 1.1, MSI capability as defined by *PCI Local Bus Specification*, Revision 2.3, and PCI-X capability as defined by *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

The functionality of the ATU is described in the following sections. The ATU and the MU have a memory-mapped register interface that is visible from either the PCI interface, the internal bus interface, or both.



Figure 7. ATU Block Diagram







Figure 8. ATU Queue Architecture Block Diagram



# 3.2 ATU Address Translation

The ATU allows PCI masters on the PCI bus to initiate transactions to the 80331 internal bus and allows the Intel<sup>®</sup> XScale  $^{\text{TM}}$  core (ARM\* architecture compliant) to initiate transactions to the PCI bus.

The ATU implements an address windowing scheme to determine which addresses to claim and translate to the destination bus.

- The address windowing mechanism for inbound translation is described in Section 3.2.1.1, "Inbound Address Translation" on page 139
- The address windowing mechanism for outbound translation is described in Section 3.2.2,
   "Outbound Transactions- Single Address Cycle (SAC) Internal Bus Transactions" on page 149 and Section 3.2.3, "Outbound Write Transaction" on page 157

The ATU has the ability to accept up to eight inbound PCI read transactions and four inbound PCI write transactions simultaneously. Also, the ATU has the ability to accept up to eight outbound internal bus read transactions and four outbound internal bus write transactions simultaneously. Refer to Figure 8 and Section 3.5 for details of the ATU queue architecture.

The ATU unit allows for recognition and generation of multiple PCI cycle types. Table 69 shows the PCI and PCI-X commands supported for both inbound and outbound ATU transactions. The type of operation seen by the ATU on inbound transactions is determined by the PCI master who initiates the transaction. Claiming an inbound transaction depends on the address range programmed within the inbound translation window. The type of transaction used by the ATU on outbound transactions generated by the core processor is determined by the internal bus address and the fixed outbound windowing scheme.

ATU supports the 64-bit addressing specified by the *PCI Local Bus Specification*, Revision 2.3. This 64-bit addressing extension is supported for both inbound and outbound data transactions. This is in addition to the 64-bit data extensions supported by the 80331.

ATU does not support exclusive access using the PCI LOCK# signal. Also, the ATU does not guarantee atomicity for outbound transactions.



# Table 69. ATU Command Support

| PCI Command<br>Encoding | PCI Command<br>Type         | PCI-X<br>Command<br>Type       | Claimed on<br>Inbound<br>Transactions<br>on PCI Bus | Generated by<br>Outbound<br>Transactions<br>on PCI Bus | Valid Internal<br>Bus Command  |
|-------------------------|-----------------------------|--------------------------------|-----------------------------------------------------|--------------------------------------------------------|--------------------------------|
| 0000                    | Interrupt<br>Acknowledge    | Interrupt<br>Acknowledge       | No                                                  | No                                                     | Interrupt<br>Acknowledge       |
| 0001                    | Special Cycle               | Special Cycle                  | No                                                  | No                                                     | Special Cycle                  |
| 0010                    | I/O Read                    | I/O Read                       | No                                                  | Yes                                                    | I/O Read                       |
| 0011                    | I/O Write                   | I/O Write                      | No                                                  | Yes                                                    | I/O Write                      |
| 0100                    | reserved                    | reserved                       | No                                                  | No                                                     | reserved                       |
| 0101                    | reserved                    | reserved                       | No                                                  | No                                                     | reserved                       |
| 0110                    | Memory Read                 | Memory Read<br>DWORD           | Yes                                                 | Yes                                                    | Memory Read<br>DWORD           |
| 0111                    | Memory Write                | Memory Write                   | Yes                                                 | Yes                                                    | Memory Write                   |
| 1000                    | reserved                    | Alias to Memory<br>Read Block  | Yes                                                 | No                                                     | Alias to Memory<br>Read Block  |
| 1001                    | reserved                    | Alias to Memory<br>Write Block | Yes                                                 | No                                                     | Alias to Memory<br>Write Block |
| 1010                    | Configuration<br>Read       | Configuration<br>Read          | Yes                                                 | Yes                                                    | Configuration<br>Read          |
| 1011                    | Configuration<br>Write      | Configuration<br>Write         | Yes                                                 | Yes                                                    | Configuration<br>Write         |
| 1100                    | Memory Read<br>Multiple     | Split Completion               | Yes                                                 | Yes                                                    | Split Completion               |
| 1101                    | Dual Address<br>Cycle       | Dual Address<br>Cycle          | Yes                                                 | Yes                                                    | Dual Address<br>Cycle          |
| 1110                    | Memory Read<br>Line         | Memory Read<br>Block           | Yes                                                 | Yes <sup>a</sup>                                       | Memory Read<br>Block           |
| 1111                    | Memory Write and Invalidate | Memory Write<br>Block          | Yes                                                 | Yes                                                    | Memory Write<br>Block          |

a. PCI-X mode only.

Inbound and outbound ATU transactions are best described by the data flows used on the PCI bus and the 80331 internal bus during read and write operations. The following sections describe read and write operations for inbound ATU transactions (PCI to internal bus) and outbound transactions (internal bus to PCI).



# 3.2.1 Inbound Transactions

Inbound transactions which target the ATU are translated and executed on the 80331 internal bus. As a PCI target, the ATU is capable of accepting all PCI memory read and write operations as either a 32-bit or a 64-bit PCI target. In the conventional PCI mode *Memory Write* and *Memory Write* and *Invalidate* operations are performed as posted operations and all memory read operations are performed as delayed reads. In the PCI-X mode *Memory Write*, *Memory Write Block*, and *Alias to Memory Write Block* operations are performed as posted operations and *Memory Read DWORD*, *Memory Read Block*, and *Alias to Memory Read Block* operations are executed as split transactions. The ATU is capable of accepting configuration read and write cycles. In the conventional PCI mode, *Configuration Writes* are performed as delayed memory write operations and *Configuration Reads* are performed as delayed read operations. In the PCI-X mode, both *Configuration Writes* and *Configuration Reads* are performed as split transactions.

Inbound memory write transactions have their addresses entered into the inbound write address queue (IWADQ) and data entered into the inbound write data queue (IWQ). The IWQ/IWADQ pair are capable of holding up to 4 write operations up to the size of the data queue. Inbound configuration writes use the inbound delayed write queue (IDWQ) for address and data. Refer to Section 3.5 for details of queue operation. Inbound read operations (memory and configuration) have their address entered into the inbound transaction queue (ITQ) and the data is returned to the PCI master in the inbound read queue (IRQ). The ITQ is capable of holding up to 8 delayed read requests (split read requests when operating in the PCI-X mode).

In the conventional PCI mode, for inbound transactions, the ATU is a slave on the PCI bus and is a requester on the internal bus. PCI slave operation is defined in the *PCI Local Bus Specification*, Revision 2.3. In the PCI-X mode, for inbound transactions, the ATU initially is a target on the PCI bus and becomes an initiator when performing split completion transactions, and is an initiator on the internal bus.



#### 3.2.1.1 Inbound Address Translation

The ATU allows external PCI bus initiators to directly access the internal bus. These PCI bus initiators can read or write 80331 memory-mapped registers or 80331 local memory space. The process of inbound address translation involves two steps:

- 1. Address Detection.
  - Determine when the 32-bit PCI address (64-bit PCI address during DACs) is within the address windows defined for the inbound ATU.
  - Claim the PCI transaction with medium DEVSEL# timing in the conventional PCI mode and with Decode A DEVSEL# timing in the PCI-X mode.
- 2. Address Translation.
  - Translate the 32-bit PCI address (lower 32-bit PCI address during DACs) to a 32-bit 80331 internal bus address.

The ATU uses the following registers in inbound address window 0 translation:

- Inbound ATU Base Address Register 0
- Inbound ATU Limit Register 0
- Inbound ATU Translate Value Register 0

The ATU uses the following registers in inbound address window 2 translation:

- Inbound ATU Base Address Register 2
- Inbound ATU Limit Register 2
- Inbound ATU Translate Value Register 2

The ATU uses the following registers in inbound address window 3 translation:

- Inbound ATU Base Address Register 3
- Inbound ATU Limit Register 3
- Inbound ATU Translate Value Register 3

Inbound Address window 1 is not a translate window. Instead, window 1 may be used to allocate host memory for Private Devices. Inbound Address window 3 does not reside in the standard section of the configuration header (offsets 00H - 3CH), thus the host BIOS does not configure window 3. Window 3 is intended to be used as a special window into local memory for private PCI agents controlled by the 80331 in conjunction with the Private Memory Space of the bridge. PCI-to-PCI Bridge in 80331 or

Inbound address detection is determined from the 32-bit PCI address, (64-bit PCI address during DACs) the base address register and the limit register. In the case of DACs none of the upper 32-bits of the address is masked during address comparison. The algorithm for detection is:

#### **Equation 1. Inbound Address Detection**

When PCI\_Address [31:0] and Limit\_Register[31:0] == Base\_Register[31:0] and PCI\_Address [63:32] == Base\_Register[63:32] (for DACs only) the PCI Address is claimed by the Inbound ATU.



Figure 9 shows an example of inbound address detection.

#### Figure 9. Inbound Address Detection



The incoming 32-bit PCI address (lower 32-bits of the address in case of DACs) is bitwise ANDed with the associated inbound limit register. When the result matches the base register (and upper base address matches upper PCI address in case of DACs), the inbound PCI address is detected as being within the inbound translation window and is claimed by the ATU.

**Note:** The first 4 Kbytes of the ATU inbound address translation window 0 are reserved for the Messaging Unit. See Section 3.3, "Messaging Unit" on page 161.

Once the transaction is claimed, the address must be translated from a PCI address to a 32-bit internal bus address. In case of DACs upper 32-bits of the address is simply discarded and only the lower 32-bits are used during address translation. The algorithm is:

#### **Equation 2.** Inbound Translation

Intel® I/O processor Internal Bus Address = (PCI\_Address[31:0] and ~Limit\_Register[31:0]) | ATU\_Translate\_Value\_Register[31:0].

The incoming 32-bit PCI address (lower 32-bits in case of DACs) is first bitwise ANDed with the bitwise inverse of the limit register. This result is bitwise ORed with the ATU Translate Value and the result is the internal bus address. This translation mechanism is used for all inbound memory read and write commands excluding inbound configuration read and writes. Inbound configuration cycle translation is described in Section 3.2.1.4, "Inbound Configuration Cycle Translation" on page 147.

In the PCI mode for inbound memory transactions, the only burst order supported is Linear Incrementing. For any other burst order, the ATU signals a Disconnect after the first data phase. The PCI-X supports linear incrementing only, and hence above situation is not encountered in the PCI-X mode.



Figure 10 shows an inbound translation example for 32-bit addressing. This example would hold true for an inbound transaction from PCI bus.

Figure 10. Inbound Translation Example





#### 3.2.1.2 Inbound Write Transaction

An inbound write transaction is initiated by a PCI master and is targeted at either 80331 local memory or a 80331 memory-mapped register.

Data flow for an inbound write transaction on the PCI bus is summarized as:

- The ATU claims the PCI write transaction when the PCI address is within the inbound translation window defined by the ATU Inbound Base Address Register (and Inbound Upper Base Address Register during DACs) and Inbound Limit Register.
- When the IWADQ has at least one address entry available and the IWQ has at least one buffer available, the address is captured and the first data phase is accepted.
- The PCI interface continues to accept write data until one of the following is true:
  - The initiator performs a disconnect.
  - The transaction crosses a buffer boundary.
- When an address parity error is detected during the address phase of the transaction, the address parity error mechanisms are used. Refer to Section 3.7.1 for details of the address parity error response.
- When operating in the PCI-X mode when an attribute parity error is detected, the attribute parity error mechanism described in Section 3.7.1 is used.
- When a data parity error is detected while accepting data, the slave interface sets the
  appropriate bits based on PCI specifications. No other action is taken. Refer to Section 3.7.2.6
  for details of the inbound write data parity error response.

Once the PCI interface places a PCI address in the IWADQ, when IWQ has received data sufficient to cross a buffer boundary or the master disconnects on the PCI bus, the ATUs internal bus interface becomes aware of the inbound write. When there are additional write transactions ahead in the IWQ/IWADQ, the current transaction remains posted until ordering and priority have been satisfied (Refer to Section 3.5.3) and the transaction is attempted on the internal bus by the ATU internal master interface. The ATU does not insert target wait states nor do data merging on the PCI interface, when operating in the PCI mode.

In the PCI-X mode memory writes are always executed as immediate transactions, while configuration write transactions are processed as split transactions. The ATU generates a Split Completion Message, (with Message class = 0h - Write Completion Class and Message index = 00h - Write Completion Message) once a configuration write is successfully executed.

Also, when operating in the PCI-X mode a write sequence may contain multiple write transactions. The ATU handles such transactions as independent transactions.



Data flow for the inbound write transaction on the internal bus is summarized as:

- The ATU internal bus master requests the internal bus when IWADQ has at least one entry with associated data in the IWQ.
- When the internal bus is granted, the internal bus master interface initiates the write transaction by driving the translated address onto the internal bus. For details on inbound address translation, see Section 3.2, "ATU Address Translation" on page 136.
- When IB\_DEVSEL# is not returned, a master abort condition is signaled on the internal bus.
  The current transaction is flushed from the queue and SERR# may be asserted on the PCI interface.
- The ATU initiator interface asserts **IB\_REQ64#** to attempt a 64-bit transfer. When **IB\_ACK64#** is not returned, a 32-bit transfer is used. Transfers of less than 64-bits use the **IB\_C/BE[7:0]#** to mask the bytes not written in the 64-bit data phase. Write data is transferred from the IWQ to the internal bus when data is available and the internal bus interface retains internal bus ownership.
- The internal bus interface stops transferring data from the current transaction to the internal bus when one of the following conditions becomes true:
  - The internal bus initiator interface loses bus ownership. The ATU internal initiator terminates the transfer (initiator disconnection) at the next ADB (for the internal bus ADB is defined as a naturally aligned 128-byte boundary) and attempt to reacquire the bus to complete the delivery of remaining data using the same sequence ID but with the modified starting address and byte count.
  - A Disconnect at Next ADB is signaled on the internal bus from the internal target. When the transaction in the IWQ completes at that ADB, the initiator returns to idle. When the transaction in the IWQ is not complete, the initiator attempts to reacquire the bus to complete the delivery of remaining data using the same sequence ID but with the modified starting address and byte count.
  - A Single Data Phase Disconnect is signaled on the internal bus from the internal target. When the transaction in the IWQ needs only a single data phase, the master returns to idle. When the transaction in the IWQ is not complete, the initiator attempts to reacquire the bus to complete the delivery of remaining data using the same sequence ID but with the modified starting address and byte count.
  - The data from the current transaction has completed (satisfaction of byte count). An initiator termination is performed and the bus returns to idle.
  - A Master Abort is signaled on the internal bus. SERR# may be asserted on the PCI bus.
     Data is flushed from the IWQ.



#### 3.2.1.3 Inbound Read Transaction

An inbound read transaction is initiated by a PCI initiator and is targeted at either 80331 local memory or a 80331 memory-mapped register space. The read transaction is propagated through the inbound transaction queue (ITQ) and read data is returned through the inbound read queue (IRQ).

When operating in the conventional PCI mode, all inbound read transactions are processed as delayed read transactions. When operating in the PCI-X mode, all inbound read transactions are processed as split transactions. The ATUs PCI interface claims the read transaction and forwards the read request through to the internal bus and returns the read data to the PCI bus. Data flow for an inbound read transaction on the PCI bus is summarized in the following statements:

- The ATU claims the PCI read transaction when the PCI address is within the inbound translation window defined by ATU Inbound Base Address Register (and Inbound Upper Base Address Register during DACs) and Inbound Limit Register.
- When operating in the conventional PCI mode, when the ITQ is currently holding transaction information from a previous delayed read, the current transaction information is compared to the previous transaction information (based on the setting of the DRC Alias bit in Section 3.10.39, "ATU Configuration Register ATUCR" on page 252). When there is a match and the data is in the IRQ, return the data to the master on the PCI bus. When there is a match and the data is not available, a Retry is signaled with no other action taken. When there is not a match and when the ITQ has less than eight entries, capture the transaction information, signal a Retry and initiate a delayed transaction. When there is not a match and when the ITQ is full, then signal a Retry with no other action taken.
  - When an address parity error is detected, the address parity response defined in Section 3.7 is used.
- When operating in the conventional PCI mode, once read data is driven onto the PCI bus from the IRQ, it continues until one of the following is true:
  - The initiator completes the PCI transaction. When there is data left unread in the IRQ, the data is flushed.
  - An internal bus Target Abort was detected. In this case, the QWORD associated with the Target Abort is never entered into the IRQ, and therefore is never returned.
  - Target Abort or a Disconnect with Data is returned in response to the Internal Bus Error.
  - The IRQ becomes empty. In this case, the PCI interface signals a Disconnect with data to the initiator on the last data word available.
- When operating in the PCI-X mode, when ITQ is not full, the PCI address, attribute and command are latched into the available ITQ and a Split Response Termination is signalled to the initiator.
- When operating in the PCI-X mode, when the transaction does not cross a 1024 byte aligned boundary, then the ATU waits until it receives the full byte count from the internal bus target before returning read data by generating the split completion transaction on the PCI-X bus. When the read requested crosses at least one 1024 byte boundary, then ATU completes the transfer by returning data in 1024 byte aligned chunks.



- When operating in the PCI-X mode, once a split completion transaction has started, it continues until one of the following is true:
  - The requester (now the target) generates a Retry Termination, or a Disconnection at Next ADB (when the requester is a bridge)
  - The byte count is satisfied.
  - An internal bus Target Abort was detected. The ATU generates a Split Completion
     Message (message class=2h completer error, and message index=81h target abort) to
     inform the requester about the abnormal condition. The ITQ for this transaction is flushed.
     Refer to Section 3.7.1.
  - An internal bus Master Abort was detected. The ATU generates a Split Completion
     Message (message class=2h completer error, and message index=80h Master abort) to
     inform the requester about the abnormal condition. The ITQ for this transaction is flushed.
     Refer to Section 3.7.1
- When operating in the conventional PCI mode, when the master inserts wait states on the PCI bus, the ATU PCI slave interface waits with no premature disconnects.
- When a data parity error occurs signified by **PERR**# asserted from the initiator, no action is taken by the target interface. Refer to Section 3.7.2.5.
- When operating in the conventional PCI mode, when the read on the internal bus is
  target-aborted, either a target-abort or a disconnect with data is signaled to the initiator. This is
  based on the ATU ECC Target Abort Enable bit (bit 0 of the ATUIMR for ATU). When set, a
  target abort is used, when clear, a disconnect is used.
- When operating in the PCI-X mode (with the exception of the MU queue ports at offsets 40h and 44h), when the transaction on the internal bus resulted in a target abort, the ATU generates a Split Completion Message (message class=2h completer error, and message index=81h internal bus target abort) to inform the requester about the abnormal condition. For the MU queue ports, the ATU returns either a target abort or a single data phase disconnect depending on the ATU ECC Target Abort Enable bit (bit 0 of the ATUIMR for ATU). The ITQ for this transaction is flushed. Refer to Section 3.7.1.
- When operating in the conventional PCI mode, when the transaction on the internal bus resulted in a master abort, the ATU returns a target abort to inform the requester about the abnormal condition. The ITQ for this transaction is flushed. Refer to Section 3.7.1
- When operating in the PCI-X mode, when the transaction on the internal bus resulted in a master abort, the ATU generates a Split Completion Message (message class=2h completer error, and message index=80h internal bus master abort) to inform the requester about the abnormal condition. The ITQ for this transaction is flushed. Refer to Section 3.7.1.
- When operating in the PCI-X mode, when the Split Completion transaction completes with
  either Master-Abort or Target-Abort, the requester is indicating a failure condition that
  prevents it from accepting the completion it requested. In this case, since the Split Request
  addresses a location that has no read side effects, the completer must discard the Split
  Completion and take no further action.

#### Address Translation Unit



The data flow for an inbound read transaction on the internal bus is summarized in the following statements:

- The ATU internal bus master interface requests the internal bus when a PCI address appears in an ITQ and transaction ordering has been satisfied. When operating in the PCI-X mode the ATU does not use the information provided by the Relax Ordering Attribute bit. That is, ATU always uses conventional PCI ordering rules.
- Once the internal bus is granted, the internal bus master interface drives the translated address
  onto the bus and wait for IB\_DEVSEL#. When a Retry is signaled, the request is repeated.
  When a master abort occurs, the transaction is considered complete and a target abort is loaded
  into the associated IRQ for return to the PCI initiator (transaction is flushed once the PCI
  master has been delivered the target abort).
- Once the translated address is on the bus and the transaction has been accepted, the internal
  bus target starts returning data with the assertion of IB\_TRDY#. Read data is continuously
  received by the IRQ until one of the following is true:
  - The full byte count requested by the ATU read request is received. The ATU internal bus initiator interface performs a initiator completion in this case.
  - When operating in the conventional PCI mode, a Target Abort is received on the internal bus from the internal bus target. In this case, the transaction is aborted and the PCI side is informed.
  - When operating in the PCI-X mode, a Target Abort is received on the internal bus from the internal bus target. In this case, the transaction is aborted. The ATU generates a Split Completion Message (message class=2h completer error, and message index=81h target abort) on the PCI bus to inform the requester about the abnormal condition. The ITO for this transaction is flushed.
  - When operating in the conventional PCI mode, a single data phase disconnection is received from the internal bus target. When the data has not been received up to the next QWORD boundary, the ATU internal bus master interface attempts to reacquire the bus. When not, the bus returns to idle.
  - When operating in the PCI-X mode, a single data phase disconnection is received from the internal bus target. The ATU IB initiator interface attempts to reacquire the bus to obtain remaining data.
  - When operating in the conventional PCI mode, a disconnection at Next ADB is received from the internal bus target. The bus returns to idle.
  - When operating in the PCI-X mode, a disconnection at Next ADB is received from the internal bus target. The ATU IB initiator interface attempts to reacquire the bus to obtain remaining data.

To support *PCI Local Bus Specification*, Revision 2.0 devices, the ATU can be programmed to ignore the memory read command (Memory Read, Memory Read Line, and Memory Read Multiple) when trying to match the current inbound read transaction with data in a DRC queue which was read previously (DRC on target bus). When the Read Command Alias Bit in the ATUCR register is set, the ATU does not distinguish the read commands on transactions. For example, the ATU enqueues a DRR with a Memory Read Multiple command and performs the read on the internal bus. Some time later, a PCI master attempts a Memory Read with the same address as the previous Memory Read Multiple. When the Read Command Bit is set, the ATU would return the read data from the DRC queue and consider the Delayed Read transaction complete. When the Read Command bit in the ATUCR was clear, the ATU would not return data since the PCI read commands did not match, only the address.



## 3.2.1.4 Inbound Configuration Cycle Translation

The ATU only accepts Type 0 configuration cycles with a function number of zero.

The ATU is configured through the PCI bus. When operating in the conventional PCI mode, all inbound configuration cycles are processed as delayed transactions. When operating in the PCI-X mode, all inbound configuration cycles are processed as split transactions. The translation mechanism for inbound configuration cycles is defined by the *PCI Local Bus Specification*, Revision 2.3.

The ATU configuration space is selected by a PCI configuration command and claims the access (by asserting DEVSEL#) when the IDSEL pin is asserted, the PCI command indicates a configuration read or write, and address bits **AD[1:0]** are  $00_2$  all during the address phase. The ATU interface ignores any configuration command (IDSEL active) where **AD[1:0]** are not  $00_2$  (e.g. Type 1 commands). During the configuration access address phase, the PCI address is divided into a number of fields to determine the actual configuration register access. These fields, in combination with the byte enables during the data phase create the unique encoding necessary to access the individual registers of the configuration address space:

- AD[7:2] Register Number. Selects one of 64 DWORD registers in the ATU PCI configuration address space.
- **C/BE[3:0]#** Used during the data phase. Selects which actual configuration register is used within the DWORD address. Creates byte addressability of the register space.
- AD[10:8] Function Number. Used to select which function of a multi-function device is being accessed. The ATU is function 0 and therefore it only responds to 000<sub>2</sub> in this bit field and ignore all other bit combinations.

The ATU configuration address space starts at internal address FFFF.E100H. Therefore  $\mathbf{AD[7:2]}$  equal to  $000000_2$  equates to address FFFF.E100H and  $\mathbf{AD[7:2]}$  equal to  $000001_2$  results in address FFFF.E104H and so on.

For inbound configuration reads, the IRQ and ITQ are used in the same manner as inbound memory read operations. The internal bus cycle that results is a 32-bit transaction where **I\_REQ64#** is not asserted.

For inbound configuration writes, the ATU adds a delayed write data queue, IDWQ, which holds data in the same manner as the IWQ. The transaction information from the configuration write operation on the PCI interface is captured into the IDWQ (when full, a Retry is signaled). The data from the delayed write (split write when operating in the PCI-X mode) request cycle is latched into the IDWQ and forwarded to the internal bus interface. Once transaction ordering and priority have been satisfied, the internal bus master interface requests the internal bus and deliver the write data to the target as defined in Section 3.2.1.2.

The status of the transaction on the internal bus is returned to the PCI initiator on the PCI bus. When operating in the conventional PCI mode, the retry cycle from the initiator is accepted once the write has been completed on the internal bus and the status has been captured for return to the PCI master. When operating in the PCI-X mode, a Split Completion Message (message class=0h and message index=00h) is generated on the PCI bus, once the write has been completed on the internal bus and the status has been latched for return to the PCI master. Since Master Aborts and Target Aborts cannot occur during configuration cycles on the internal bus, normal completion status is returned. The data from PCI completion transaction is discarded.



## 3.2.1.5 Discard Timers

The ATU implements discard timers for inbound delayed transactions. These timers prevent deadlocks when the initiator of a retried delayed transaction fails to complete the transaction within  $2^{10}$  or  $2^{15}$  PCI clock cycles on the initiating bus when operating in the conventional PCI mode. The timer starts counting when the delayed request becomes a delayed completion by completing on the internal bus and all passing rules are satisfied. When the originating master on the PCI bus has not retried the transaction before the timer expires, the completion transaction is discarded.

Discard timer values are controlled by the ATU Configuration Register's Discard Timer Value bit. The ATU queues covered by discard timers are the IRQ and the IDWQ. After discarding a transaction, the ATU must set the Discard Timer Status bit in the ATU Configuration Register. The ATU does *not* assert the **SERR**# signal after discarding a transaction.



# 3.2.2 Outbound Transactions- Single Address Cycle (SAC) Internal Bus Transactions

Outbound transactions initiated by the 80331 core processor are directed to the PCI interface through the ATU. The core processor always generates Single Address Cycles on the internal bus. As a PCI master, the ATU is capable of PCI I/O transactions, PCI memory reads (in case of conventional PCI), memory read DWORD (in case of PCI-X), PCI memory writes, configuration reads and writes, and DAC cycles. Outbound memory transactions are always attempted as 64-bit PCI transactions. Outbound memory write operations are performed as posted operations and outbound memory read operations are all performed as split read operations.

Outbound transactions use a separate set of queues from inbound transactions. Outbound write operations have their address entered into the outbound write address queue (OWADQ) and their data into the outbound write queue (OWQ). Outbound read transactions, performed as split transactions, use the Outbound Transaction Queue (OTQ) to store address, and get data returned into the outbound read queue (ORQ). Refer to Section 3.5.2 for details of outbound queue architecture. Outbound configuration transactions use a special outbound port structure. Refer to Section 3.2.3 for details.

For outbound write transactions, the ATU is a target on the internal bus and initiator on the PCI bus. For outbound read transactions, the ATU is a completer on the internal bus (initially accepts the split read as a target and then provides read data by initiating a split completion).

## 3.2.2.1 Outbound Address Translation - Single Address Cycle (SAC) Internal Bus Transactions

In addition to providing the mechanism for inbound translation, the ATU translates Intel<sup>®</sup> XScale<sup>™</sup> core-initiated cycles to the PCI bus. This is known as *outbound address translation*. Outbound transactions are processor or DMA transactions targeted at the PCI bus. The ATU internal bus target interface claims internal bus cycles and completes the cycle on the PCI bus on behalf of the Intel<sup>®</sup> XScale<sup>™</sup> core or DMAs. The ATU supports two different outbound windowing modes:

- Address Translation Windowing
- Direct Address Windowing (No translation)

Figure 11 shows a 80331 memory map with all reserved address locations highlighted. The two 64 MByte outbound translation memory windows exist from 8000.0000H to 83FF.FFFFH and 8400.0000H to 87FF.FFFFH. The direct addressing window is from 0000.0040H to 7FFF.FFFFH. The 64KByte outbound I/O window is from 9000.0000H to 90000.FFFFH.

The response of the ATU to Outbound Transactions is controlled by bits in the ATU Command Register and the ATU Configuration Register. The Outbound ATUs behavior for the different combinations of these control bits is described in Table 70.

#### Table 70. Outbound Address Translation Control

| Outbound Response  | Bus Master Enable (ATUCMD - bit2) | Outbound Enable (ATUCR - bit1) |
|--------------------|-----------------------------------|--------------------------------|
| Master-Abort       | 0                                 | 0                              |
| Retry              | 0                                 | 1                              |
| Master-Abort       | 1                                 | 0                              |
| Claim <sup>a</sup> | 1                                 | 1                              |

a. The ATU may respond with a Retry in this case when the Outbound Transaction Queues are full.



## 3.2.2.2 Outbound Address Translation Windows- Single Address Cycle (SAC) Internal Bus Transactions

Inbound translation involves a programmable inbound translation window consisting of a base and limit register and a translate value register for PCI to internal bus translation. The outbound address translation windows use a similar methodology except that the outbound translation window base addresses and limit sizes are fixed in 80331 internal bus local address space; this removes the need for separate base and limit registers.

Figure 12 on page 154 illustrates the outbound address translation windows. The ATU has three windows: two are 64 Mbyte and one is 64 Kbyte. The two outbound memory translation windows range from 8000.0000H to 87FF.FFFFH. After these two windows, the outbound I/O window range from 9000.0000H to 9000.FFFFH.

The two Memory windows are 64 Mbytes and I/O window is 64 Kbytes. An internal bus cycle with an address within one of the outbound windows initiates a read or write cycle on the PCI bus. The PCI cycle type depends on which translation window the local bus cycle "hits". The read or write decision is based on the internal bus cycle type.

ATU has a window dedicated to the following outbound PCI/PCI-X transaction types:

- Memory reads and Memory writes Memory Window
- I/O reads and writes I/O Window

## Table 71. Internal Bus-to-PCI Command Translation for Two Memory Windows/DMA Channels

| Internal Bus Command        | Conventional PCI Command                                 | PCI-X Command      |
|-----------------------------|----------------------------------------------------------|--------------------|
| Memory Write                | Memory Write                                             | Memory Write       |
| Memory Write Block          | Memory Write and Invalidate <sup>a</sup> or Memory Write | Memory Write Block |
| Memory Read Block           | Memory Read Multiple                                     | Memory Read Block  |
| Memory Read DWORD           | Memory Read                                              | Memory Read DWORD  |
| Alias to Memory Write Block | Memory Write and Invalidate or<br>Memory Write           | Memory Write Block |
| Alias to Memory Read Block  | Memory Read Multiple                                     | Memory Read Block  |

- a. The ATU converts (Alias to) Memory Write Block to Memory Write and Invalidate when the following four conditions are met, otherwise the Memory Write Block is converted to a Memory Write:
  - 1.) Memory Write and Invalidate transactions are enabled in the "ATU Command Register ATUCMD".
  - 2.) The Cache Line size is set to 8 or 16 DWORDS in the "ATU Cacheline Size Register ATUCLSR".
  - 3.) Starting address of the Outbound PCI bus request is aligned to the cache line size.
  - 4.) Byte count intended for the Outbound PCI bus request is a multiple of the cache line size.



#### Table 72. Internal Bus-to-PCI Command Translation for I/O Window

| Internal Bus Command <sup>a</sup> | Conventional PCI Command | PCI-X Command |
|-----------------------------------|--------------------------|---------------|
| Memory Write                      | I/O Write                | I/O Write     |
| Memory Write Block                | I/O Write                | I/O Write     |
| Memory Read Block                 | I/O Read                 | I/O Read      |
| Memory Read DWORD                 | I/O Read                 | I/O Read      |
| Alias to Memory Write Block       | I/O Write                | I/O Write     |
| Alias to Memory Read Block        | I/O Read                 | I/O Read      |

a. User should designate memory region containing I/O Window (9000.0000H to 90000.FFFFH) as non-cacheable and non-bufferable from Intel<sup>®</sup> XScale<sup>™</sup> core. This guarantees all load/stores to I/O Window are of DWORD quantities. In event the user inadvertently issues a read to the I/O Window that crosses a DWORD address boundary, the ATU target aborts transaction. All writes are terminated with a Single-Phase-Disconnect and only bytes 3:0 is relevant dependent on the Byte Enables.

## The windowing scheme refers to:

- An Internal Bus read cycle that addresses a Memory Window is translated to a Memory Read on the PCI bus
- An Internal Bus write cycle that addresses a Memory Window is translated to a Memory Write on the PCI bus
- An Internal Bus read cycle that addresses the I/O Window is an I/O Read on the PCI bus
- An Internal Bus write cycle that addresses the I/O Window is an I/O Write on the PCI bus



Figure 11. Internal Bus Memory Map





The translation portion of outbound ATU transactions is accomplished with a translate value register in the same manner as inbound translations. Each outbound memory window is associated with two translation registers which provide lower and upper translation addresses (OMWTVR0-1, OUMWTVR-1). When the corresponding OUMWTVRx register is all-zero a SAC transaction is generated on the PCI bus. Otherwise, a DAC is generated on the PCI bus. ATU uses the following registers during outbound address translation:

- Outbound Memory Window Translate Value Register 0 (OMWTVR0)
- Outbound Upper 32-bit Memory Window Translate Value Register 0 (OUMWTVR0)
- Outbound Memory Window Translate Value Register 1 (OMWTVR1)
- Outbound Upper 32-bit Memory Window Translate Value Register 1 (OUMWTVR1)
- Outbound I/O Window Translate Value Register (OIOWTVR)
- Outbound Configuration Cycle Address Register (OCCA)

See Section 3.8 for details on outbound translation register definition and programming constraints.

The translation algorithm used, as stated, is very similar to inbound translation. For memory transactions, the algorithm is:

#### **Equation 3. Outbound Address Translation**

PCI Address = (Internal Bus Address and 03FF.FFFFH) | Window Translate Value Register

For memory transactions, the internal bus address is bitwise ANDed with the inverse of 64 Mbytes which clears the upper 6 bits of address. The result is bitwise ORed with the outbound window translate value register to create the lower 32-bits of the PCI address.

For I/O transactions, the algorithm is:

## **Equation 4. I/O Transactions**

PCI Address = (Internal\_Bus\_Address and 0000.FFFFH) | Window\_Translate\_Value\_Register

For I/O transactions, the internal bus address is bitwise ANDed with the inverse of 64 Kbytes which clears the upper 16 bits of address. Address aliasing is prevented by the outbound window translate value registers which only allow values on boundaries equivalent to the window length. PCI I/O addresses are byte addresses and not word addresses. The PCI I/O address two least significant bits are determined by byte enables that the processor issues. For example, when the Intel<sup>®</sup> XScale core performs a 2-byte write and generates byte enables of 0011<sub>2</sub>, the ATU sets the two least significant bits of PCI I/O address to 10<sub>2</sub>.



Figure 12. Outbound Address Translation Windows





# 3.2.2.3 Direct Addressing Window - Single Address Cycle (SAC) Transactions

The second method used by outbound cycles from the Intel<sup>®</sup> XScale <sup>TM</sup> core to the PCI bus is the direct addressing window. This is a window of addresses in Intel<sup>®</sup> XScale <sup>TM</sup> core address space that act in the same manner as the outbound translation windows either without any translation or with the translation of address bit 31 only. This allows the Direct Addressing window to translate to different address ranges on the PCI bus (0000.0040H to 7FFF.FFFFH or 8000.0000H to FFFF.FFFFH). A Intel<sup>®</sup> XScale <sup>TM</sup> core read or write to an internal bus address within the direct addressing window initiates a read or write on the PCI bus with the same address (with the possible exception of address bit 31) as used on the internal bus. When the Outbound Upper 32-bit Direct Window Translate Value Register (OUDWTVR) is not all-zero, then a DAC transaction is generated on the PCI bus using the upper-32 bit address provided in OUDWTVR. Otherwise a SAC transaction is generated on the PCI bus. Figure 13 shows two examples of outbound writes that are through the direct addressing window.

Direct Addressing is limited to PCI memory read and write commands only. I/O cycles are not supported with direct addressing.

Figure 13. Direct Addressing Window



The internal bus side of the direct addressing window address range is fixed in the lower 2 Gbytes of the 80331 local address space (except for the first 32 Bytes which are reserved for the Reset and Exception vectors). Internal bus cycles with an address from 0000.0040H to 7FFF.FFFFH are forwarded to the PCI bus, when enabled. The following bits within the ATUCR affect direct addressing operation:

- ATUCR Direct Addressing Enable bit when set, enables the direct addressing window. When clear, addresses within the direct addressing window are not forwarded to the PCI bus.
- ATUCR Direct Addressing Upper 2G Translation Enable when set, the ATU forwards internal bus cycles with an address between 0000.0040H and 7FFF.FFFH to the PCI bus with bit 31 of the address set (8000.0000H FFFF.FFFFH). When clear, no translation occurs.



## 3.2.2.4 Outbound DMA Transactions

The ATU provides each DMA channel with its own dedicated decode window that claims all transactions generated by that channel that are destined for the PCI bus.

Depending on the contents of the PCI Upper Address field of a particular DMA descriptor, the ATU may initiate a SAC or a DAC transaction on the PCI bus in response to the DMA channel's request. As the DMA channel transfers data to the ATU, the lower 32-bits of the Internal Bus address are passed to the PCI bus unaltered (see Section 6.3.1, "Chain Descriptors" on page 351 for more details).



## 3.2.3 Outbound Write Transaction

An outbound write transaction is initiated by the Intel<sup>®</sup> XScale<sup>™</sup> core<sup>1</sup> or by one of the DMAs and is targeted at a PCI target on the PCI bus. The outbound write address and write data are propagated from the 80331 internal bus to a PCI bus through the OWADQ and OWQ, respectively.

The ATUs internal bus target interface claims the write transaction and forwards the write data through to the targeted PCI bus. The data flow for an outbound write transaction on the internal bus is summarized in the following statements:

- For Single Address Cycles (SACs), ATU internal bus target interface latches the address from the internal bus into the OWADQ when that address is inside one of the outbound translate windows (see Section 3.5) and the OWO is not full.
- For Dual Address Cycles (DACs), ATU internal bus target interface latches address from the internal bus into the OWADQ when the OWQ is not full and OWADQ is not full.
- Once outbound address is latched, internal bus target interface stores write data into the OWQ
  until the internal bus transaction completes or the reaches a buffer boundary. The initiator of the
  transaction is disconnected at an ADB when the transaction reaches a buffer boundary.
- When the OWADQ is full, the target interface signals a Retry on the internal bus to the outbound cycle initiator.
- When OWADQ latches the address and corresponding data is latched in a buffer in OWQ, the outbound cycle is enabled for transmission on the PCI Bus and PCI interface requests PCI bus.

The PCI interface is responsible for completing the outbound write transaction with the PCI address translated from the OWADQ and the data in the OWQ. The data flow for an outbound write transaction on the PCI bus is summarized in the following statements:

- ATU PCI interface requests PCI bus when completed internal bus transaction is in OWADQ and data associated with transfer in OWQ. Once bus is granted, PCI master interface writes PCI translated address from OWADQ to the PCI bus and wait for the transaction to be claimed.
- When Master Abort seen during address phase, transaction flushed and OWADQ/OWQ are cleared. Refer Section 3.7.3 for full details on PCI master abort conditions during outbound transactions.
- In the conventional PCI mode, once the PCI write transaction is claimed, the PCI interface transfers data from the OWO to the PCI bus until one of the following is true:
  - The PCI target signals a Retry or Disconnect. The ATU PCI master attempts to reacquire the PCI bus to complete the write transaction.
  - The **GNT**# signal is deasserted and the master latency timer has expired. In this case, the master interface attempts to reacquire the PCI bus and complete the write transaction.
  - The PCI target signals a Target-Abort. In this case, the OWQ and OTQ are cleared and the transaction is aborted. The appropriate error bits are set as defined in Section 3.7.4.
  - The transaction terminates normally by transferring all data (full byte count) associated with it. The write address is removed from the OWADQ and the interface returns to idle.

**Document Number: 273942-002** October, 2003 157

<sup>1.</sup> For best performance, the user should designate the two Outbound Memory Windows (8000.0000H to 83FF.FFFFH, 8400.0000H to 87FF.FFFFH) as non-cacheable and bufferable from the Intel<sup>®</sup> XScale<sup>™</sup> core. This assignment enables the Intel<sup>®</sup> XScale<sup>™</sup> core to issue multiple outstanding transactions to the Outbound Memory Windows, thereby, taking full advantage of the ATU outbound queue architecture. However, the user needs to be aware that the Outbound ATU queue architecture does not maintain strict ordering between read and write requests as described in Table 78, "ATU Outbound Data Flow Ordering Rules" on page 168. In the event that the user requires strict ordering to be maintained, the user can either change the designation of this region of memory to be non-cacheable and non-bufferable or enforce the requirement in software.

## Address Translation Unit



- In the PCI-X mode, once the PCI memory write transaction is claimed, the PCI interface transfers data from the OWQ to the PCI bus until one of the following is true:
  - The PCI target signals a Retry or Single Data Phase Disconnect. The ATU PCI initiator attempts to reacquire the PCI bus to complete the write transaction.
  - reacquire the PCI bus to complete the write transaction.
  - The **GNT**# signal is deasserted and the master latency timer has expired. In this case, the master interface attempts to reacquire the PCI bus and complete the write transaction.
  - The PCI target signals a Target-Abort. In this case, the OWQ and OWADQ are cleared and the transaction is aborted. The appropriate error bits are set as defined in Section 3.7.4.
  - The transaction terminates normally with Satisfaction of Byte Count. The write address is removed from the OWADQ and the interface returns to idle.
- In the PCI-X mode, once the PCI I/O write transaction is claimed, the PCI interface transfers data from the OWQ to the PCI bus until one of the following is true:
  - The PCI target signals a Retry. The ATU PCI initiator attempts to reacquire the PCI bus to complete the write transaction.
  - The transaction terminates normally with Satisfaction of Byte Count or with Single Data Phase Disconnect. The write address is removed from the OWADQ and the interface returns to idle.
  - The PCI target signals a Target-Abort. In this case, the OWQ and OWADQ are cleared and the transaction is aborted. The appropriate error bits are set as defined in Section 3.7.4.
  - The transaction terminates with Split Response Termination. The write address is removed from the OWADQ and the interface returns to idle only when it receives the corresponding Split Completion Message.

When a data parity error is encountered (**PERR**# detected), the master interface continues writing data to clear the queue.

In the conventional PCI mode when the PCI target deasserts TRDY#, no action is taken by the ATU master other than inserting wait states.



## 3.2.4 Outbound Read Transaction

An outbound read transaction is initiated by the Intel<sup>®</sup> XScale<sup>TM</sup> core<sup>1</sup> or one of the DMAs and is targeted at a PCI slave on the PCI bus. The read transaction is propagated through the outbound transaction queue (OTQ) and read data is returned through the outbound read queue (ORQ).

The ATUs internal bus target interface claims the Memory Read Dword and Memory Read Block and Alias to Memory Read Block transaction and forwards the read request through to the PCI bus and returns the read data to the internal bus.

Data flow for an outbound read transaction on the internal bus is summarized as follows:

- For Single Address Cycles (SACs), the ATU internal bus interface latches the internal bus address
  when the address is inside an outbound address translation window (or direct addressing window,
  when enabled) and the OTQ is not full. For Dual Address Cycles (DACs), ATU internal bus target
  interface latches the address from the internal bus into the OTQ irrespective of the address. All read
  transactions are handled as split transactions. When the OTQ is full (previous outbound
  transactions in progress), the internal bus interface signals a Retry to the transaction initiator.
- When during the completion cycle on the PCI interface, a master abort is encountered, a flag is
  set and the ATU notifies the internal bus requester about the aborted transaction by generating
  a Split Completion Error Message (with message class=1h PCI bus error and message
  index=00h master abort). The OTQ is cleared of the transaction.
- When during the completion cycle on the PCI interface, a target abort is encountered, a flag is
  set and the ATU notifies the internal bus requester about the aborted transaction by generating
  a Split Completion Error Message (with message class=1h PCI bus error and message
  index=01h target abort). The OTQ is cleared of the transaction.
- Once the transaction completes on the PCI bus, the ATU generates a split completion transaction to return data to the internal bus requester.
- When operating in the PCI-X mode, ATU may receive a split completion error message when
  attempting to read data on the PCI bus. In this case, ATU notifies the internal bus requester
  about the error by forwarding the Split Completion Error Message from the PCI bus back to
  the Internal Requester. The OTQ is cleared of the transaction.

Data flow for an outbound read transaction on the PCI bus is summarized as follows:

- The ATU PCI interface requests the PCI bus when the head of the OTQ has at least one entry and
  the ordering rules are satisfied. Once the bus is granted, the PCI interface transfers the PCI
  translated address from the OTQ to the PCI bus and wait for the transaction to be claimed.
- When no **DEVSEL**# is asserted, a master abort is signaled. This is passed through to the internal bus target interface.
- When a target abort is signaled from the PCI target, the target abort is returned to the internal bus and the PCI interface returns to idle.
- When operating in the PCI-X mode the read transaction may terminate as a split response termination. Then the ATU receives data during the corresponding split completion transaction. When an error occurs, the ATU may receive a split completion error message.

<sup>1.</sup> For best performance, the user should designate the two Outbound Memory Windows (8000.0000H to 87FF.FFFFH, 8400.0000H to 87FF.FFFFH) as non-cacheable and bufferable from the Intel<sup>®</sup> XScale<sup>™</sup> core. This assignment enables the Intel<sup>®</sup> XScale<sup>™</sup> core to issue multiple outstanding transactions to the Outbound Memory Windows, thereby, taking full advantage of the ATU outbound queue architecture. However, the user needs to be aware that the Outbound ATU queue architecture does not maintain strict ordering between read and write requests as described in Table 78, "ATU Outbound Data Flow Ordering Rules" on page 168. In the event that the user requires strict ordering to be maintained, the user can either change the designation of this region of memory to be non-cacheable and non-bufferable or enforce the requirement in software.



## 3.2.5 Outbound Configuration Cycle Translation

The outbound ATU provides a port programming model for outbound configuration cycles.

Performing an outbound configuration cycle to the PCI bus involves up to two internal bus cycles:

- 1. Writing Outbound Configuration Cycle Address Register (OCCAR) with PCI address used during configuration cycle. See the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a for information regarding configuration address cycle formats. This IB bus cycle enables the transaction.
- 2. Writing or reading the Outbound Configuration Cycle Data Register (OCCDR). A read causes a configuration cycle read to the PCI bus with the address in the outbound configuration cycle address register. Note that the Internal Bus read is executed as a split transaction. Similarly, a write initiates a configuration cycle write to PCI with the write data from the second processor cycle. Configuration cycles are non-burst and restricted to a single DWORD cycle. <sup>1</sup>

**Note:** Bits 15:11 of the configuration cycle address for Type 0 configuration cycles are defined differently for Conventional versus PCI-X modes. When 80331 software programs the OCCAR to initiate a Type 0 configuration cycle, the OCCAR should always be loaded based on the PCI-X definition for the Type 0 configuration cycle address. When operating in Conventional mode, the 80331 clears bits 15:11 of the OCCAR prior to initiating an outbound Type 0 configuration cycle.

**Note:** During the attribute phase of a Type 0 configuration transaction, the Secondary Bus Number field (bits 7:0) is set equal to the Requester Bus Number (bits 15:8 of the "PCI-X Status Register - PX\_SR" on page 279).

Master aborts during outbound configuration reads result in ATU generating a Split Completion Error Message (class=1h - bridge error and index=00h - master abort on PCI) on internal bus.

Target aborts during outbound configuration reads result in ATU generating a Split Completion Error Message (class=1h - bridge error and index=01h - target abort on PCI) on the internal bus.

Parity errors during outbound configuration reads result in ATU generating a Split Completion Error Message (class=2h - completer error and index=82h - parity error on PCI) on the internal bus.

Parity errors detected by target of an outbound configuration write may result in the ATU receiving either of the two Split Completion Write Data Parity Error Messages (with message class=2h -completer error and message index=01h - split write data parity error or with message class=1h - bridge error and message index=02h - write data parity error) on the PCI bus. When Parity Checking is enabled, the ATU sets error bits in the ATUSR and the PCIXSR. The Intel<sup>®</sup> XScale core is interrupted when the Split Completion Error and/or Master Data Parity interrupt(s) are unmasked.

When the Configuration Cycle Data Register is written, the data is latched and forwarded to the PCI bus with the internal target issuing a single data phase disconnect with data for 32-bits only. This cycle does not receive an **ACK64**# from the ATU and therefore is defined as 32-bit only.

Note that while the programming model uses the register interface for outbound configuration cycles, from a hardware standpoint, the address is entered into the OTQ (reads) or OWADQ (writes), configuration write data goes through the OWQ and configuration read data is returned in the ORQ.

**Note:** Outbound configuration cycle data registers are not physical registers. They are a 80331 memory mapped addresses used to initiate a transaction with the address in the associated address register.

The user should designate the memory region containing the OCCDR as non-cacheable and non-bufferable from the Intel<sup>®</sup> XScale<sup>™</sup> core.
 This guarantees that all load/stores to the OCCDR is only of DWORD quantities. In event the user inadvertently issues a read to the OCCDR that crosses a DWORD address boundary, the ATU target aborts the transaction. All writes is terminated with a Single-Phase-Disconnect and only bytes 3:0 is relevant.



## 3.3 Messaging Unit

The Messaging Unit (MU) transfers data between the PCI system and the 80331 and notifies the respective system when new data arrives. The MU is described in Chapter 4, "Messaging Unit".

The PCI window for messaging transactions is always the *first* 4 Kbytes of the inbound translation window defined by the Inbound ATU Base Address Register 0 (IABAR0) and the Inbound ATU Limit Register 0 (IALR0).

All of the Messaging Unit errors are reported in the same manner as ATU errors. Error conditions and status can be found in the ATUSR and the ATUISR, see Section 3.7, "ATU Error Conditions" on page 174.



## 3.4 Expansion ROM Translation Unit

The inbound ATU supports one address range (defined by a base/limit register pair) used for the Expansion ROM. Refer to the *PCI Local Bus Specification*, Revision 2.3 for details on Expansion ROM format and usage.

During a powerup sequence, initialization code from Expansion ROM is executed once by the host processor to initialize the associated device. The code can be discarded once executed. Expansion ROM registers are described in Section , and Section 3.10.29.

The inbound ATU supports an inbound Expansion ROM window which works like the inbound translation window. A read from the expansion ROM windows is forwarded to the internal bus. The address translation algorithm is the same as the inbound translation; see Section 3.2.1.1, "Inbound Address Translation" on page 139. As a PCI target, the Expansion ROM interface behaves as a standard ATU interface and is capable of returning a 64-bit access by the assertion of ACK64# in response to a 64-bit request.

The Expansion ROM unit uses the ATU inbound transaction queue and the inbound read data queue.

When operating in the conventional PCI mode, the address of the inbound delayed read cycle is entered into the ITQ queue and the delayed read completion data is returned in the IRQ. That is, inbound reads to the Expansion ROM window are handled as delayed transactions on the PCI bus.

When operating in the PCI-X mode, the address of the inbound read cycle is entered into the ITQ queue and the read completion data is returned in the IRQ. That is, inbound reads to the Expansion ROM window are handled as split transactions on the PCI bus. The internal bus initiator interface fills the IRQ read queue with the full byte count before generating the split completion transaction on the PCI bus. That is, the ATU generates a Memory Read Block transaction on the internal bus with byte count set to the byte count specified in the PCI read. The PBI (Flash Interface) terminates the read as a split read request and return data in

- either one or more 1024 byte split completion transactions when byte count is greater than or equal to 1024 bytes or
- one split completion with the full byte count when byte count is less than 1024 bytes.

Expansion ROM writes are not supported and result in a Target Abort.



## 3.5 ATU Queue Architecture

ATU operation and performance depends on the queueing mechanism implemented between the internal bus interface and PCI bus interface. As indicated in Figure 8, the ATU queue architecture consists of separate inbound and outbound queues. The function of each queue is described in the following sections.

## 3.5.1 Inbound Queues

The inbound data queues of the ATU support transactions initiated on a PCI bus and targeted at either 80331 local memory or a 80331 memory mapped register. Table 73 details the name and sizes of the ATU inbound data queues.

#### Table 73. Inbound Queues

| Queue Mnemonic | Queue Name                                  | Queue Size<br>(Bytes)   |
|----------------|---------------------------------------------|-------------------------|
| IWQ            | Inbound Write Data Queue                    | 4 KBytes (4*1KB)        |
| IWADQ          | Inbound Write Address Queue                 | 4 Transaction Addresses |
| IRQ            | Inbound Read Data Queue                     | 4 KBytes (4*1KB)        |
| IDWQ           | Inbound Delayed Write address/data<br>Queue | 1 Transaction           |
| ITQ            | Inbound Transaction Queue                   | 8 Addresses/Commands    |

#### 3.5.1.1 Inbound Write Queue Structure

The ATU Inbound Write Queues consist of the inbound write data queue and the inbound write address queue. The inbound write data queue holds the data for memory write transactions moving from a PCI Bus to the internal bus and the address queue holds the corresponding address of the transactions in the data queues. The inbound write queue, IWQ, has a queue depth of 4 KBytes and moves write transactions from the PCI bus to the internal bus. The corresponding address queue, IWADQ, is capable of holding 4 address entries. The queue pair is capable of holding up to 4 memory write (or MWI when operating in the conventional PCI mode) transactions.

The following rules apply to the PCI bus interface and govern the acceptance of data into IWQ and address into the tail of the IWADQ:

- A memory write operation claimed by the target PCI interface on the PCI bus is accepted into the address and data queues when the IWADQ has at least one address entry available.
- When operating in the conventional PCI mode, when the IWQ reaches a full state while filling, a disconnect with data is signaled to the master of the transaction.
- When operating in the PCI-X mode, when the IWQ reaches a full state while filling, a disconnect at next ADB is signaled to the master of that transaction.

Memory write transactions are drained from the head of the queue when the master interface has acquired bus ownership and transaction ordering and priority have been satisfied (see Section 3.5.3). A memory write transaction is considered drained from the queue when the entire amount of data entered on the PCI bus has been accepted by the internal bus target. Error conditions resulting in the cancellation of a write transaction only flush the transaction at the head of the data and address queue. All other transactions within the queues are considered still valid.



#### 3.5.1.2 Inbound Read Queue Structure

The inbound read queues are responsible for retrieving data from local memory and returning it to the PCI bus in response to a read transaction initiated from a PCI master. When operating in the conventional PCI mode, reads are handled as delayed transactions. When operating in the PCI-X mode reads are handled as split transactions. The address of the transactions are held in the ITQ. Up to 8 read requests can be stored in the ITQ. The read data is returned through IRQ.

When operating in the conventional PCI mode, the IRQ holds data from four PCI bus read transactions. The read request cycle on PCI latches the read command and the address into the ITQ when the cycle is first initiated by the PCI master. The ATU internal bus initiator interface takes the translated address and the command and performs a read on the internal bus. Reads can be any of the PCI memory read command types using the ATU inbound translation or an inbound configuration read using the specific configuration cycle translation. The data from the read on the internal bus is stored in the IRQ until the PCI master initiates a read cycle that matches the initial request cycle in both command and address. Any data left in an IRQ after the delivery of a completion cycle on PCI is flushed. This is possible since all internal bus memory is considered prefetchable with no read side effects.

When operating in the PCI-X mode, the IRQ may hold data from up to four PCI bus read transactions. The read request cycle on PCI latches the read command and the address into the ITQ when the cycle is first initiated by the PCI master. The ATU internal bus initiator interface takes the translated address and the command and performs a read on the internal bus. Reads can be any of the PCI memory read command types using the ATU inbound translation or an inbound configuration read using the specific configuration cycle translation. Once read data is available in the IRQ, the ATU generates one or more split completions to return read data to the PCI requester.

When operating in the conventional PCI mode, the exact amount of data (byte count) read by the master state machine on the internal bus interface depends upon the read command used and how much data the Internal Bus target device delivers. Table 74 shows the amount of data attempted to be read for the different memory read commands for the ATU, when operating in the conventional PCI mode.

Internal bus error conditions override all prefetch amounts. i.e. a master-abort and target-abort conditions.

#### Table 74. Inbound Read Prefetch Data Sizes

| PCI Read Command     | Prefetch Size (Bytes) |  |  |
|----------------------|-----------------------|--|--|
| Memory Read          | 4 to 32               |  |  |
| Memory Read Line     | 4 to 128              |  |  |
| Memory Read Multiple | 4 to 1024             |  |  |

164 October, 2003 **Document Number: 273942-002** 



## 3.5.1.3 Inbound Delayed Write Queue

The IDWQ is used specifically for inbound configuration write cycles to the ATU. I/O Write transactions are not accepted by the ATU and result in a Master Abort.

The IDWQ contains both the address and data of a configuration write cycle. When operating in the conventional PCI mode, the configuration writes are handled as delayed writes. When operating in the PCI-X mode, the configuration writes are handled as split writes. When the write cycle is initiated on the PCI bus, the address and data are entered into the 8 byte queue, and forwarded to the internal bus. The transaction is forwarded to the internal bus once transaction ordering has been satisfied. The status of the transaction (normal completion) is maintained in the IDWQ for return to the PCI master on the initiating bus. When operating in the PCI-X mode, a write completion message is generated by the ATU to indicate the successful execution of the configuration write transaction.

The IDWQ can only hold 32-bits of data and should never be accessed with **REQ64#** asserted per the *PCI Local Bus Specification*, Revision 2.3 which states that "only memory transactions support 64-bit data transfers". In addition, the cycle should always return only 32-bits of data on the internal bus.

## 3.5.1.4 Inbound Transaction Queues Command Translation Summary

#### Table 75. PCI to Internal Bus Command Translation for All Inbound Transactions

| PCI Command                                  | Conventional<br>Mode | PCI-X Mode  | Internal Bus Command     |
|----------------------------------------------|----------------------|-------------|--------------------------|
| Memory Write                                 | >                    | <b>&gt;</b> | Memory Write             |
| Memory Write and Invalidate                  | >                    |             | Memory Write Block       |
| Memory Write Block                           |                      | <b>&gt;</b> | Memory Write Block       |
| Alias to Memory Write Block                  |                      | <b>&gt;</b> | Memory Write Block       |
| Memory Read                                  | >                    |             | Memory Read Block        |
| Memory Read Line                             | >                    |             | Memory Read Block        |
| Memory Read Multiple                         | >                    |             | Memory Read Block        |
| Memory Read Block                            |                      | <b>&gt;</b> | Memory Read Block        |
| Alias to Memory Read Block                   |                      | <b>&gt;</b> | Memory Read Block        |
| Memory Read DWORD                            |                      | <b>&gt;</b> | Memory Read DWORD        |
| Configuration Read                           | >                    | <b>&gt;</b> | Configuration Read       |
| Configuration Write                          | >                    | <b>&gt;</b> | Configuration Write      |
| Split Read Completion                        |                      | <b>&gt;</b> | Split Read Completion    |
| Split Write Completion                       |                      | <b>&gt;</b> | None                     |
| Split Completion Message                     |                      | <b>&gt;</b> | Split Completion Message |
| All Other Commands Not<br>Claimed by the ATU | <b>~</b>             | <b>~</b>    | N/A                      |



## 3.5.2 Outbound Queues

The outbound queues of the ATU are used to hold read and write transactions from the core processor directed at the PCI bus. Each ATU outbound queue structure has a separate read queue, write queue, and address queue. Table 76 contains information about ATU outbound queues.

#### Table 76. Outbound Queues

| Queue Mnemonic | Queue Name                   | Queue Size<br>(Bytes)                              |
|----------------|------------------------------|----------------------------------------------------|
| OWQ            | Outbound Write Data Queue    | 4 KBytes (4*1024B)                                 |
| OWADQ          | Outbound Write Address Queue | 4 Transaction Addresses                            |
| ORQ            | Outbound Read Data Queue     | 2 or 4 KBytes (4* 512B or<br>4*1024B) <sup>a</sup> |
| OTQ            | Outbound Transaction Queue   | 8 Addresses/Commands                               |

a. The ORQ can be throttled between 2 Kbytes or 4 Kbytes depending on the setting of the Maximum Memory Read Byte Count (MMRBC) field of the PCI-X Command register (see Section 3.10.60, "PCI-X Command Register - PX\_CMD" on page 278). When the MMRBC is set to 512 bytes (default value), the ORQ is only capable of handling 2 Kbytes of SRC data, otherwise, the ORQ handles 4 Kbytes of SRC data.

The outbound queues are capable of holding outbound memory read, memory write, I/O read, and I/O write transactions. The type of transaction used is defined by the internal bus address and the command used on the internal bus. See Section 3.2.2 and Section 3.2.3 for details on outbound address translation.

When an internal bus agent initiates an outbound write transaction, the address is entered into the OWADQ (when not full). The data from the internal bus write is then entered into the OWQ and the transaction is forwarded to the PCI bus. When the write completes (or an error occurs), the address is flushed from the OWADQ. Data is flushed only for the master abort or target abort cases.

For outbound reads, the address is entered into the OTQ (when not full) and a split response termination is signaled to the requester on the internal bus. Read data is fetched and returned to the requester on the internal bus.



## 3.5.3 Transaction Ordering

Because the ATU can process multiple transactions, they must maintain proper ordering to avoid deadlock conditions and improve throughput. The ATU transaction ordering rules used by the 80331 are listed in Table 77 for the inbound direction and Table 78 on page 168 for the outbound direction. The tables are based on the direction the transaction is moving, i.e. the data for outbound delayed read moves in the same direction as the data for an inbound write or the address/command for an inbound read. When operating in the PCI-X mode, the ATU ignores the Relaxed Ordering Attribute.

Note: Outbound Non-Posted Writes are the result of Internal Bus Memory writes that are claimed by either the I/O translation window or the Outbound Configuration Cycle Data Register - OCCDR. Though these write requests arrive on the PCI bus as non-posted write requests, it is important to note that from the Intel<sup>®</sup> XScale core point of view, these internal bus memory write requests are posted into the Outbound ATU transaction queue. Furthermore, in PCI-X mode non-posted write requests have the potential to be split. Thus, even though a split write completion may be returned to the ATU on the PCI bus for a given outbound non-posted write request, the split write completion is not passed back through to the internal bus. Additionally, strong ordering between outbound memory (posted) write requests and outbound non-posted write requests is **not** maintained as indicated in Table 78 on page 168.

For best performance, the user should designate the two Outbound Memory Windows (8000.0000H to 83FF.FFFFH, 8400.0000H to 87FF.FFFFH) as non-cacheable and bufferable from the Intel® XScale Core. This assignment enables the Intel® XScale Core to issue multiple outstanding transactions to the Outbound Memory Windows, thereby, taking full advantage of the ATU outbound queue architecture. However, the user needs to be aware that the Outbound ATU queue architecture does not maintain strict ordering between read and write requests as described in Table 78, "ATU Outbound Data Flow Ordering Rules" on page 168. In the event that the user requires strict ordering to be maintained, the user can either change the designation of this region of memory to be non-cacheable and non-bufferable or enforce the requirement in software.

## Table 77. ATU Inbound Data Flow Ordering Rules

| Row Pass Column? <sup>a</sup>              | ATU Inbound<br>Writes | Inbound<br>Delayed<br>Read<br>Request<br>(PCI mode) | Inbound Split<br>Read<br>Request<br>(PCI-X mode) | Inbound<br>Configu-<br>ration Write<br>Request | Outbound<br>Split Read<br>Completion |
|--------------------------------------------|-----------------------|-----------------------------------------------------|--------------------------------------------------|------------------------------------------------|--------------------------------------|
| ATU Inbound Writes                         | No                    | Yes                                                 | Yes                                              | Yes                                            | Yes                                  |
| Inbound Delayed Read<br>Request (PCI mode) | No                    | No                                                  | NA                                               | No                                             | Yes                                  |
| Inbound Split Read<br>Request (PCI-X mode) | No                    | NA                                                  | No                                               | No                                             | Yes                                  |
| Inbound Configuration Write Request        | No                    | No                                                  | No                                               | NA                                             | Yes                                  |
| Outbound Split Read<br>Completion          | No                    | Yes                                                 | Yes                                              | Yes                                            | Yes                                  |

a. Outbound Non-Posted Write Completions are not included in this table since these transactions are never passed back to the Internal Bus Requester (Intel<sup>®</sup> XScale<sup>™</sup> core). The reason is that from the Intel<sup>®</sup> XScale<sup>™</sup> core point of view, these write requests are posted into the Outbound ATU transaction queue.



### Table 78. ATU Outbound Data Flow Ordering Rules

| Row Pass Column?                                  | Outbound Write |                | Outbound Read | Inbound Read<br>Completion |     | Inbound Write<br>Completion |                  |
|---------------------------------------------------|----------------|----------------|---------------|----------------------------|-----|-----------------------------|------------------|
| Now 1 ass column:                                 | Posted         | Non-<br>Posted | Request       | DRC                        | SRC | DWCa                        | SWC <sup>b</sup> |
| Outbound Posted Write<br>Request                  | No             | Yes            | Yes           | Yes                        | Yes | Yes                         | Yes              |
| Outbound Non-posted <sup>c</sup><br>Write Request | No             | No             | No            | Yes                        | Yes | Yes                         | Yes              |
| Outbound Read Request                             | No             | No             | No            | Yes                        | Yes | Yes                         | Yes              |
| Inbound Delayed Read<br>Completion (DRC)          | No             | Yes            | Yes           | Yes                        | NA  | Yes                         | NA               |
| Inbound Split Read<br>Completion (SRC)            | No             | Yes            | Yes           | NA                         | Yes | NA                          | No               |
| Inbound Delayed Write Completion (DWC)            | No             | Yes            | Yes           | Yes                        | NA  | NA                          | NA               |
| Inbound Split Write<br>Completion (SWC)           | No             | Yes            | Yes           | NA                         | Yes | NA                          | NA               |

a. Since the Inbound DWR transaction queue is one-deep, the passing rule associated with DWC vs. DWC is moot (i.e., NA).

Definitions of the terms used in Table 77 and Table 78 are as follows. PCI terms are noted in parenthesis:

- Inbound Write (PMW) Data from a write cycle initiated on PCI and targeted at the internal bus. Note that the address is in a separate transaction queue and is not referenced. Inbound writes can also come in through the Messaging Unit which is part of the ATU.
- Inbound Read Request (DRR-PCI mode and SRR-PCI-X mode) address information from a read transactions retried or split on the PCI bus. is mastered on the internal bus to retrieve data for the Inbound Read Completion.
- Inbound Configuration Write Request (DWR- PCI mode and SWR PCI-X mode) The address and data associated with a configuration write transaction from PCI and targeted at the ATU PCI configuration address space. Once completed on the internal bus, creates an Inbound Configuration Write Completion.
- Outbound Read Completion (SRC) The data read on PCI in the process of being returned to the internal bus. This data is the completion cycle that results from an Outbound Read Request.
- Outbound Write (PMW) The address and data from a write initiated on the internal bus and eventually completing on the PCI bus.
- Outbound Read Request (SRR) The address/command of a split read cycle initiated on the internal bus. The read data is returned in the Outbound Read Completion cycle.
- Inbound Read Completion (DRC-PCI mode and SRC-PCI-X mode) The data read on the internal bus in the process of being returned to the PCI bus. This data is the completion cycle for an Inbound Read Request.
- Inbound Configuration Write Completion (DWC-PCI mode and SWC-PCI-X mode) The status
  of an inbound write configuration cycle traveling from the internal bus back towards the PCI bus.

b. Since the Inbound SWR transaction queue is one-deep, the passing rule associated with SWC vs. SWC is moot (i.e., NA).

c. Outbound Non-posted writes include I/O writes and Configuration writes.



These transaction ordering rules define the way in which data moves in both directions through the ATU. In Table 77 and Table 78 a **NO** response in a box means that based on ordering rules, the current transaction (the row) can not pass the previous transaction (the column) under any circumstance. A **Yes** response in the box means that the current transaction is *allowed* to pass the previous transaction but is not required to, based on whether a consistent view of data or prevention of deadlocks is needed.

In the case of inbound write operations, multiple transactions may exist within the IWQ and the corresponding IWADQ at any point in time. The ordering of these transactions is based on a time stamp basis. Transactions entering the queue are stamped with a relative time in relation to all other transactions moving in a similar direction.

## **Example 1. Inbound Queue Completion**



In Example 1 on page 169, the inbound write and outbound read queues of the ATU are shown. In this example, transaction A entered the write queue at **Time 0**. Next, the ATU entered read data into the outbound read queue at **Time 1** (Transaction B). Finally, before the previous transactions could be cleared, another inbound write, Transaction C, was entered into the IWQ. The ordering in Table 77 states that nothing can pass an inbound write and therefore Transaction A must complete on the internal bus before Transaction B since an outbound read completion can not pass an inbound write. Also, Transaction A must complete before Transaction C since an inbound write can not pass another inbound write. Once Transaction A completes, Transaction C moves to the head of the IWQ. The two transactions at the head of the queues moving data in an inbound direction are now Transaction C, an inbound write, and Transaction B, an outbound read completion. Ordering states that an inbound write may pass an outbound read completion. This means that the arbitration mechanism now takes over to decide which completes. Note that ordering enforced the completion of Transaction A but arbitration dictated the completion of Transactions B and C.

The first action performed to determine which transaction is allowed to proceed (either inbound or outbound) is to apply the rules of ordering as defined in Table 77 and Table 78. Any box marked **No** must be satisfied first. For example, when an inbound read request is in ITQ and it was latched *after* the data in the IDWQ arrived (this is a configuration write), then ordering states that an Inbound Read Request may not pass an Inbound Configuration Write Request. Therefore, the Inbound Configuration Write Request must be cleared out of IDWQ before the Inbound Read Request is attempted on the internal bus. Once transaction ordering is satisfied, the boxes marked **Yes** are now resolved.



## 3.5.3.1 Transaction Ordering Summary

Table 79 and Table 80, define transaction ordering in relation to token assignment of the priority mechanism (this is discussed in Section 3.5.3). These tables are read as follows:

- 1. As the transaction enters the head of the respective queue, the question in column 2 is asked.
- 2. When all the answers in column 3 for a given transaction type assigns a token to the transaction at the head of the queue, a token is assigned. Otherwise, no token is assigned signifying that transaction ordering must first be satisfied. Any transaction with a token may be initiated on the bus.

## **Table 79.** Inbound Transaction Ordering Summary

| Transaction at Head of Queue   | Question                                                                    | Answer | Action                                 |
|--------------------------------|-----------------------------------------------------------------------------|--------|----------------------------------------|
|                                |                                                                             | Yes    | Do Not Assign Token                    |
| Inbound Write in IWO           | Is there an Inbound Write Request with an earlier time stamp?               | 163    | Allow previous Transaction to Complete |
| 2                              | an earner unit etamp                                                        | No     | Assign Token                           |
|                                | Le disease and labour disease with a con-                                   | Yes    | Do Not Assign Token                    |
|                                | Is there an Inbound Write with an earlier time stamp?                       | 163    | Allow previous Transaction to Complete |
|                                | oamer ame etamp                                                             | No     | Assign Token                           |
| Inhamad Band                   | le the second Band Band State (the                                          | Yes    | Do Not Assign Token                    |
| Inbound Read<br>Request in ITQ | Is there an Inbound Read Request with an earlier time stamp?                | 163    | Allow previous Transaction to Complete |
|                                | an earner anne etamp                                                        | No     | Assign Token                           |
|                                | Is there an Inbound Configuration Write Request with an earlier time stamp? | Yes    | Do Not Assign Token                    |
|                                |                                                                             |        | Allow previous Transaction to Complete |
|                                | Troquest min an earner anne etamp                                           | No     | Assign Token                           |
|                                | Le disease and labour disease with a con-                                   | Yes    | Do Not Assign Token                    |
| Inbound                        | Is there an Inbound Write with an earlier time stamp?                       |        | Allow previous Transaction to Complete |
| Configuration                  | oamer ame etamp                                                             | No     | Assign Token                           |
| Write Request in               |                                                                             | Yes    | Do Not Assign Token                    |
| IDWQ                           | Is there an Inbound Read Request with an earlier time stamp?                | 103    | Allow previous Transaction to Complete |
|                                | an earner anne etamp                                                        | No     | Assign Token                           |
| Outbound Read                  | le these as lede and Maite with a                                           | Yes    | Do Not Assign Token                    |
| Completion in                  | Is there an Inbound Write with an earlier time stamp?                       | 163    | Allow previous Transaction to Complete |
| ORQ                            |                                                                             | No     | Assign Token                           |



## Table 80. Outbound Transaction Ordering Summary

| Transaction at Head of Queue          | Question                                                              | Answer | Action                                                                                                                    |
|---------------------------------------|-----------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------|
| Outbound Write in OWQ                 | Is there an Outbound Write Request with an earlier time stamp?        | Yes    | Do Not Assign Token<br>Allow previous Transaction to<br>Complete                                                          |
|                                       |                                                                       | No     | Assign Token                                                                                                              |
|                                       | Is there an Outbound Write with an earlier time stamp?                | Yes    | Do Not Assign Token<br>Allow previous Transaction to<br>Complete                                                          |
| Outbound Read                         |                                                                       | No     | Assign Token                                                                                                              |
| Request in OTQ                        | Is there an Outbound Read Request with an earlier time stamp?         | Yes    | Do Not Assign Token<br>Allow previous Transaction to<br>Complete                                                          |
|                                       |                                                                       | No     | Assign Token                                                                                                              |
|                                       | Is there an Outbound Posted Write with an earlier time stamp?         | Yes    | Do Not Assign Token Allow previous Transaction to Complete                                                                |
| Inbound                               |                                                                       | No     | Assign Token                                                                                                              |
| Configuration Write Completion in IRQ | Is there an Inbound Read Completion with an earlier time stamp?       | Yes    | Do Not Assign Token and allow previous Transaction to Complete when in PCI-X Mode.                                        |
|                                       |                                                                       |        | Assign Token when in Conventional Mode                                                                                    |
|                                       |                                                                       | No     | Assign Token                                                                                                              |
|                                       | Is there an Outbound Posted Write with an earlier time stamp?         | Yes    | Do Not Assign Token Allow previous Transaction to Complete                                                                |
|                                       |                                                                       | No     | Assign Token                                                                                                              |
| Inbound Read<br>Completion in         | Is there an Inbound Read Completion with an earlier time stamp?       | Yes    | Do Not Assign Token and allow previous Transaction to Complete when in PCI-X Mode. Assign Token when in Conventional Mode |
| IRQ                                   |                                                                       | No     | Assign Token                                                                                                              |
|                                       | Is there a Configuration Write Completion with an earlier time stamp? | Yes    | Do Not Assign Token and allow previous Transaction to Complete when in PCI-X Mode. Assign Token when in Conventional Mode |
|                                       |                                                                       | No     | Assign Token                                                                                                              |



## 3.6 Private Device Control

Private devices are hidden from PCI configuration software but are accessible from the Address Translation Unit. To include private devices on the secondary PCI interface, 80331 bridge unit and ATU must be configured properly prior to system initialization following **P\_RST#** deassertion.

To configure the 80331 to control private devices, the PCI-to-PCI Bridge must be configured to:

- Enable private Type 0 commands on the Secondary Interface
- Enable the private memory space on the Secondary Interface

These capabilities are enabled through the reset straps **PRIVDEV** and **PRIVMEM** respectively. The ATU provides status information for these reset straps in the Table 125, "PCI Configuration and Status Register - PCSR" on page 253.

The ATU is internally mapped to PCI Device Number 14 (0EH) with AD30 used as the ATU IDSEL input. This mapping also has the ATU interrupt wired to the **P\_INTC**# output pin.

## 3.6.1 Private Type 0 Commands on the Secondary Interface

Type 0 configuration reads and write commands can be generated by the Address Translation Unit of the 80331. These Type 0 configuration commands are required to configure private PCI devices on the Secondary bus which are in private PCI address space. These commands are initiated by the Address Translation Unit and not by Type 1 commands on the Primary bus. Any device mapped into this private address space *is not* part of the standard Secondary PCI address space and therefore is not configured by the system host processor. These devices are hidden from PCI configuration software but are accessible from the Address Translation Unit.

In Type 0 commands on the Secondary interface, **S\_AD[31:11]** are used to select the **IDSEL** input of the target device. In Type 1 to Type 0 conversions, **P\_AD[15:11]** are decoded to assert a unique address line from **S\_AD[31:16]** on the Secondary interface.

The bridge can be configured to block 10 address lines during Configuration transactions from the Primary interface. Secondary address bits **S\_AD[25:16]** are the address lines that can be masked by the bridge private device control.



Figure 14 shows an example of connecting PCI Address/Data lines to **IDSEL** inputs of PCI devices and private PCI devices.

Figure 14. Private Device Example



1: AD30 is dedicated to the 80331 Address Translation Unit IDSEL input, and must not be used for an external Secondary PCI device.

## 3.6.2 Private Memory Space

When Private Memory Space Enable in the Bridge SDER (see Section 2.5.2.10, "Secondary Decode Enable Register - SDER" on page 116) is set, the bridge overrides its secondary inverse decode logic and not forward upstream any secondary bus initiated DAC Memory transactions with address in the upper half of 64-bit address space (i.e., AD(63)=1b). This establishes a private memory space for secondary bus usage, independent of bridge downstream forwarding configuration.



## 3.7 ATU Error Conditions

PCI and internal bus error conditions cause ATU state machines to exit normal operation and return to idle states. In addition, status bits are set to inform error handling code of exact cause of error condition. All of the Messaging Unit errors are reported in the same manner as ATU errors. Error conditions and status can be found in the ATUSR. The basic flow for a PCI error is as follows:

- Set the bit in the ATU Status Register which corresponds to the error condition (master abort, target abort, etc.)
- Set the bit in the ATU Interrupt Status Register which corresponds to the error condition (master abort, target abort, etc.). This function is maskable for all PCI error conditions.
- The setting of the bit in the ATU Interrupt Status Register results in an interrupt being driven to the Intel<sup>®</sup> XScale<sup>™</sup> core.

Error conditions on one side of the ATU are generally propagated to the other side of the ATU and have different effects depending on the error. Error conditions and their effects are described in the following sections.

PCI bus error conditions and the action taken on the bus are defined within the *PCI Local Bus Specification*, Revision 2.3, and the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a. The ATU adheres to the error conditions defined within the PCI specification for both requester and target operation. Error conditions on the internal bus are caused by an ECC error from the Memory Controller (see Section 8.5, "Interrupts/Error Conditions" on page 493 for details on memory controller error conditions) or by incorrect addressing resulting in an internal master abort. All actions on the PCI Bus for error situations are dependent on the error control bits found in the ATU Command Register (see Section 3.10.3, "ATU Command Register - ATUCMD" on page 214) for both Conventional and PCI-X modes. For PCI-X mode, the error response is also dependent on an error control bit in the PCI-X Command Register (see Section 3.10.60, "PCI-X Command Register - PX\_CMD" on page 278).

The following sections detail all ATU error conditions on the PCI and 80331 internal bus, action taken on these conditions, and status and control bits associated with error handling.



## 3.7.1 Address and Attribute Parity Errors on the PCI Interface

The ATUs must detect and report address and attribute (PCI-X mode only) parity errors for transactions on the PCI bus. When an address or attribute parity error occurs on the PCI interface of the ATU, the 80331 performs the following actions based on the constraints specified:

- In Conventional mode, when the Parity Error Response bit in ATUCMD is set, the ATU ignores (Master-Abort) the transaction by not asserting **DEVSEL**#. When clear, the transaction proceeds normally.
- In PCI-X mode, when the Parity Error Response bit in ATUCMD is set, the ATU completes the transaction on the PCI bus as though no error had occurred, but the request or completion is not forwarded to the internal bus. When clear, the transaction proceeds normally.
- Assert SERR# when the SERR# Enable bit and the Parity Error Response bit in the ATUCMD are set. When the ATU asserts SERR#, additional actions is taken:
  - Set the **SERR**# Asserted bit in the ATUSR
  - When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.
  - When the ATU SERR# Detected Interrupt Enable Bit in the ATUCR (see Section 3.10.39, "ATU Configuration Register ATUCR" on page 252) is set, set the SERR# Detected bit in the ATUISR. When clear, no action.
- Set the Detected Address or Attribute Parity Error bit in PCSR (PCI Configuration and Status Register).
- Set the Detected Parity Error bit in the ATUSR. When the ATU sets the Detected Parity Error bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.

**Note:** The Detected Parity Error bit with its associated interrupt along with the Detected Address or Attribute Parity Error bit provides software with the ability to distinguish between an Address or Attribute Parity error versus a Data Parity Error during a Detected Parity error interrupt.



## 3.7.2 Data Parity Errors on the PCI Interface

Two kinds of data parity errors can occur on the PCI interface: errors as an initiator and errors as a target.

Errors encountered as an initiator:

- Outbound Read Request
- Outbound Write Request
- Inbound Read Completions
- Inbound Configuration Write Completion Messages

As an initiator, the ATU provides an error response for data parity errors on outbound reads, and data parity errors occurring at the target for outbound writes. However, there is no error response for data parity errors on inbound configuration write completion messages and inbound read completions.

Errors encountered as a target:

- Inbound Read Request (Immediate Data Transfer)
- Inbound Write Request
- Outbound Read Completions
- Outbound Split (I/O or Configuration) Write Data Parity Error Messages
- Inbound Configuration Write
- Split Completion Messages

As a target, the ATU provides an error response for data parity errors on inbound writes, outbound read completions, outbound split write data parity error messages, inbound configuration writes, and split completion messages. However, there is no error response for data parity errors on inbound reads.



## 3.7.2.1 Outbound Read Request Data Parity Errors

#### 3.7.2.1.1 Immediate Data Transfer

As an initiator, the ATU may encounter this error condition in Conventional or PCI-X mode when the target transfers data immediately rather than signalling a Retry<sup>1</sup> (Conventional Delayed Read Request) or a Split Response Termination (PCI-X Split Read Request).

Data parity errors occurring during read operations initiated by the ATU are recorded, **PERR**# is asserted (when enabled) and **SERR**# is asserted (when enabled). Specifically, the following actions with the given constraints are taken by the ATU:

- **PERR**# is asserted two clocks cycles (three clock cycles when operating in the PCI-X mode) following the data phase in which the data parity error is detected on the bus. This is only done when the Parity Error Response bit in the ATUCMD is set. When the ATU asserts **PERR**#, additional actions is taken:
  - The Master Parity Error bit in the ATUSR is set.
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the ATU is operating in the PCI-X mode, the SERR# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert SERR#, otherwise no action. When the ATU asserts SERR#, additional actions is taken: Set the SERR# Asserted bit in the ATUSR.

When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.

- A completion error message (with message class=2h completer error and message index=82h PCI bus read parity error) is generated on the internal bus of the 80331.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.

**Document Number: 273942-002** October, 2003 177

Retry terminations may also be signaled in PCI-X mode when the target is too busy to handle the current request. However, this is not the same as a Delayed Read Request in Conventional PCI mode since the requester is not required or expected by the target to return with the same read request.





#### 3.7.2.1.2 **Split Response Termination**

As an initiator, the ATU may encounter this error condition in PCI-X mode when the target signals a Split Response Termination.

Parity errors occurring during Split Response Terminations of Read Requests by the ATU are recorded, PERR# is asserted (when enabled) and SERR# is asserted (when enabled). Specifically, the following actions with the given constraints are taken by the ATU:

- **PERR**# is asserted two clocks cycles (three clock cycles when operating in the PCI-X mode) following the Split Response Termination in which the parity error is detected on the bus. This is only done when the Parity Error Response bit in the ATUCMD is set. When the ATU asserts PERR#, additional actions is taken:
  - The Master Parity Error bit in the ATUSR is set.
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the **SERR**# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert **SERR**#, otherwise no action. When the ATU asserts **SERR#.** additional actions is taken:

Set the SERR# Asserted bit in the ATUSR.

When the ATU SERR# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU SERR# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action

- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.

The Outbound Read Request remains enqueued in the ATU as the completer is initiating completion transactions that are associated with this request.



## 3.7.2.2 Outbound Write Request Data Parity Errors

## 3.7.2.2.1 Outbound Writes that are not MSI (Message Signaled Interrupts)

As an initiator, the ATU may encounter this error condition when operating in either the Conventional or PCI-X modes.

Data parity errors occurring during write operations initiated by the ATU may record the assertion of **PERR**# from the target on the PCI Bus. In PCI-X mode, this includes the assertion of **PERR**# from the target on the PCI Bus following the split response termination of a non-posted write request. When an error occurs, the ATUs continues writing data to the target to clear the OWQ of the current outbound write transaction. Specifically, the following actions with the given constraints are taken by the ATU:

- When **PERR**# is sampled active and the Parity Error Response bit in the ATUCMD is set, set the Master Parity Error bit in the ATUSR. When the Parity Error Response bit in the ATUCMD is clear, no action is taken. When the Master Parity Error bit in the ATUSR is set, additional actions is taken:
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the ATU is operating in the PCI-X mode, the SERR# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert SERR#, otherwise no action. When the ATU asserts SERR#, additional actions is taken: Set the SERR# Asserted bit in the ATUSR

When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action

Outbound write parity errors, does not result in a master completion. In addition, when the target terminates the transaction (disconnect), the ATU master must reinitiate the transaction to clear the data from the OWO.



#### 3.7.2.2.2 **MSI Outbound Writes**

As an initiator, the ATU may encounter this error condition when operating in either the Conventional or PCI-X modes.

Data parity errors occurring during MSI write operations initiated by the ATU may record the assertion of PERR# from the target on the PCI Bus. When an error occurs, the ATU completes the transaction normally. Then, the following actions with the given constraints are taken by the ATU:

- When PERR# is sampled active and the Parity Error Response bit in the ATUCMD is set, set the Master Parity Error bit in the ATUSR. When the Parity Error Response bit in the ATUCMD is clear, no action is taken. When the Master Parity Error bit in the ATUSR is set, additional actions is taken:
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the **SERR**# Enable bit in the ATUCMD is set, assert **SERR**#, otherwise no action. When the ATU asserts **SERR#**, additional actions is taken:

Set the **SERR**# Asserted bit in the ATUSR.

When the ATU SERR# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU SERR# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.



## 3.7.2.3 Inbound Read Completions Data Parity Errors

As an initiator, the ATU may encounter this error condition when operating in the PCI-X mode.

When as the completer of a Split Read Request the ATU observes **PERR**# assertion during the split completion transaction, the ATU attempts to complete the transaction normally and no further action is taken.

## 3.7.2.4 Inbound Configuration Write Completion Message Data Parity Errors

As an initiator, the ATU may encounter this error condition when operating in the PCI-X mode.

When as the completer of a Configuration (Split) Write Request the ATU observes **PERR**# assertion during the split completion transaction, the ATU attempts to complete the transaction normally and no further action is taken.

# 3.7.2.5 Inbound Read Request Data Parity Errors

#### 3.7.2.5.1 Immediate Data Transfer

As a target, the ATU may encounter this error when operating in the Conventional PCI or PCI-X modes.

Inbound read data parity errors occur when read data delivered from the IRQ is detected as having bad parity by the initiator of the transaction who is receiving the data. The initiator may optionally report the error to the system by asserting **PERR**#. As a target device in this scenario, no action is required and no error bits are set.

#### 3.7.2.5.2 Split Response Termination

As a target, the ATU may encounter this error when operating in the PCI-X mode.

Inbound read data parity errors occur during the Split Response Termination. The initiator may optionally report the error to the system by asserting **PERR**#. As a target device in this scenario, no action is required and no error bits are set.

# 3.7.2.6 Inbound Write Request Data Parity Errors

As a target, the ATU may encounter this error when operating in the Conventional or PCI-X modes.

Data parity errors occurring during write operations received by the ATU may assert **PERR#** on the PCI Bus. When an error occurs, the ATU continues accepting data until the initiator of the write transaction completes or a queue fill condition is reached. Specifically, the following actions with the given constraints are taken by the ATU:

- **PERR**# is asserted two clocks cycles (three clock cycles when operating in the PCI-X mode) following the data phase in which the data parity error is detected on the bus. This is only done when the Parity Error Response bit in the ATUCMD is set.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.



# 3.7.2.7 Outbound Read Completion Data Parity Errors

As a target, the ATU may encounter this error when operating in the PCI-X mode.

Data parity errors occurring during read completion transactions that are claimed by the ATU are recorded, **PERR**# is asserted (when enabled) and **SERR**# is asserted (when enabled). Specifically, the following actions with the given constraints are taken by the ATU:

- **PERR**# is asserted two clocks cycles (three clock cycles when operating in the PCI-X mode) following the data phase in which the data parity error is detected on the bus. This is only done when the Parity Error Response bit in the ATUCMD is set. When the ATU asserts **PERR**#, additional actions is taken:
  - The Master Parity Error bit in the ATUSR is set.
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the **SERR**# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert **SERR**#, otherwise no action. When the ATU asserts **SERR**#, additional actions is taken:

Set the **SERR**# Asserted bit in the ATUSR.

When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.

- A completion error message (with message class=2h completer error and message index=82h PCI bus read parity error) is generated on the internal bus of the 80331.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.



## 3.7.2.8 Outbound Split Write Data Parity Error Message

The ATU claims a Split Completion Error Message that indicates a data parity error has occurred on one of the ATUs non-posted (I/O or Configuration) write requests (Message Class = 2h, Message Index = 01h -- Split Write Data Parity Error or Message Class = 1h, Message Index = 02h -- Write Data Parity Error).

When the ATU receives a Split Completion Error Message indicating a data parity error for an outstanding Configuration or I/O (split) write request, the error is recorded, and **SERR**# is asserted (when enabled). Specifically, the following actions with the given constraints are taken by the ATU:

- When the Parity Error Response bit in the ATUCMD is set, these actions is taken:
  - The Master Parity Error bit in the ATUSR is set.
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the **SERR**# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert **SERR**#, otherwise no action. When the ATU asserts **SERR**#, additional actions is taken:

Set the **SERR**# Asserted bit in the ATUSR.

When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.

- The Received Split Completion Error Message bit in the PCIXSR is set (based on bit 30 of the completer attributes being set). When the ATU sets this bit, additional actions is taken:
  - When the ATU Received Split Completion Error Message Interrupt Mask bit in the ATUIMR is clear, set the Received Split Completion Error Message bit in the ATUISR. When set, no action.
- The transaction associated with the Split Completion Error Message is discarded.



# 3.7.2.9 Inbound Configuration Write Request

As a target, the ATU may encounter this error when operating in the Conventional or PCI-X modes.

#### 3.7.2.9.1 Conventional PCI Mode

To allow for correct data parity calculations for delayed write transactions, the ATU delays the assertion of STOP# (signalling a Retry) until **PAR** is driven by the master. A parity error during a delayed write transaction (inbound configuration write cycle) can occur in any of the following parts of the transactions:

- During the initial Delayed Write Request cycle on the PCI bus when the ATU latches the address/command and data for delayed delivery to the internal configuration register.
- During the Delayed Write Completion cycle on the PCI bus when the ATU delivers the status of the operation back to the original master.

The 80331 ATU PCI interface has the following responses to a delayed write parity error for inbound transactions during Delayed Write Request cycles with the given constraints:

- When the Parity Error Response bit in the ATUCMD is set, the ATU asserts TRDY# (disconnects with data) and two clock cycles later asserts **PERR**# notifying the initiator of the parity error. The delayed write cycle is not enqueued and forwarded to the internal bus.
  - When the Parity Error Response bit in the ATUCMD is cleared, the ATU retries the transaction by asserting STOP# and enqueues the Delayed Write Request cycle to be forwarded to the internal bus. **PERR**# is not asserted.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.

For the original write transaction to be completed, the initiator retries the transaction on the PCI bus and the ATU returns the status from the internal bus, completing the transaction.

For the Delayed Write Completion transaction on the PCI bus where a data parity error occurs and therefore does not agree with the status being returned from the internal bus (i.e. status being returned is normal completion) the ATU performs the following actions with the given constraints:

- When the Parity Error Response Bit is set in the ATUCMD, the ATU asserts TRDY# (disconnects with data) and two clocks later asserts **PERR**#. The Delayed Completion cycle in the IDWQ remains since the data of retried command did not match the data within the queue.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.



#### 3.7.2.9.2 PCI-X Mode

Data parity errors occurring during configuration write operations received by the ATU may cause **PERR**# assertion and delivery of a Split Completion Error Message on the PCI Bus. When an error occurs, the ATU accepts the write data and complete with a Split Response Termination. Specifically, the following actions with the given constraints are then taken by the ATU:

- When the Parity Error Response bit in the ATUCMD is set, **PERR**# is asserted three clocks cycles following the Split Response Termination in which the data parity error is detected on the bus. When the ATU asserts **PERR**#, additional actions is taken:
  - A Split Write Data Parity Error message (with message class=2h completer error and message index=01h Split Write Data Parity Error) is initiated by the ATU on the PCI bus that addresses the requester of the configuration write.
  - When the Initiated Split Completion Error Message Interrupt Mask in the ATUIMR is clear, set the Initiated Split Completion Error Message bit in the ATUISR. When set, no action.
  - The Split Write Request is not enqueued and forwarded to the internal bus.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.



# 3.7.2.10 Split Completion Messages

As a target, the ATU may encounter this error when operating in the PCI-X mode.

Data parity errors occurring during Split Completion Messages claimed by the ATU may assert **PERR**# (when enabled) or **SERR**# (when enabled) on the PCI Bus. When an error occurs, the ATU accepts the data and complete normally. Specifically, the following actions with the given constraints are taken by the ATU:

- **PERR**# is asserted three clocks cycles following the data phase in which the data parity error is detected on the bus. This is only done when the Parity Error Response bit in the ATUCMD is set. When the ATU asserts **PERR**#, additional actions is taken:
  - The Master Parity Error bit in the ATUSR is set.
  - When the ATU PCI Master Parity Error Interrupt Mask Bit in the ATUIMR is clear, set the PCI Master Parity Error bit in the ATUISR. When set, no action.
  - When the SERR# Enable bit in the ATUCMD is set, and the Data Parity Error Recover Enable bit in the PCIXCMD register is clear, assert SERR#; otherwise no action is taken. When the ATU asserts SERR#, additional actions is taken:

Set the **SERR**# Asserted bit in the ATUSR.

When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.

When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.

- When the SCE bit (Split Completion Error -- bit 30 of the Completer Attributes) is set during the Attribute phase, the Received Split Completion Error Message bit in the PCIXSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Received Split Completion Error Message Interrupt Mask bit in the ATUIMR is clear, set the Received Split Completion Error Message bit in the ATUISR. When set, no action.
- The Detected Parity Error bit in the ATUSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Detected Parity Error Interrupt Mask bit in the ATUIMR is clear, set the Detected Parity Error bit in the ATUISR. When set, no action.
- The transaction associated with the Split Completion Message is discarded.
- When the discarded transaction was a read, a completion error message (with message class=2h - completer error and message index=82h - PCI bus read parity error) is generated on the internal bus of the 80331.



## 3.7.3 Master Aborts on the PCI Interface

As an initiator on the PCI bus, the ATU can encounter master abort conditions during:

- · Outbound Read Request
- Outbound Write Request
- Inbound Read Completion
- Inbound Configuration Write Completion Message

As a target, the ATU PCI interface is capable of signaling a master abort case during:

- Address Parity Error (Conventional Mode)
- Inbound Read Request (PCI-X Mode)

# 3.7.3.1 Master Aborts for Outbound Read or Write Request

This error may be encountered in both the Conventional and the PCI-X modes. For an Outbound transaction, there are two ways in which a Master-Abort may be signaled to the ATU:

- In the Conventional or PCI-X modes, a master abort is signaled when the target of the transaction does not assert **DEVSEL**# within 5 clocks (7 clocks when operating in the PCI-X mode) of the assertion of **FRAME**#.
- 2. In PCI-X mode, ATU may enqueue a Split request (Read or Write) on target-side interface of a PCI-to-PCI Bridge. When PCI-to-PCI Bridge detects a Master Abort on requester-side interface for that Split Request, master abort is signaled to ATU through a Master-Abort Split Completion Error Message (class=1h bridge error and index=00h Master Abort). The following actions with given constraints are performed by ATU when a master abort is detected by the PCI initiator interface or the PCI target interface receives a Master-Abort Split Completion error message:
- Set the Master Abort bit (bit 13) in the ATUSR.
- When the ATU PCI Master Abort Interrupt Mask bit in the ATUIMR is clear, set the PCI Master Abort bit in the ATUISR. When set, no action.
- When an outbound write or inbound completion, flush data and address.
- When the transaction is an MSI outbound write and the SERR# Enable bit in the ATUCMD is set, assert SERR#, otherwise no action. When the ATU asserts SERR#, additional actions is taken:
  - Set the **SERR**# Asserted bit in the ATUSR
  - When the ATU SERR# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the SERR# Asserted bit in the ATUISR. When set, no action.
  - When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action
- When operating in PCI-X mode and Master-Abort is signaled via a Split Completion Error Message, the Received Split Completion Error Message bit in PCIXSR is set. When ATU sets this bit, additional actions is taken:
  - When the ATU Received Split Completion Error Message Interrupt Mask bit in the ATUIMR is clear, set the Received Split Completion Error Message bit in the ATUISR. When set, no action.
- For an Outbound Read request, generate a split completion error message (class=1h 80331 Outbound Request error and index=00h - master abort) on the internal bus.
- Flush the address from the OTQ.



# 3.7.3.2 Inbound Read Completion or Inbound Configuration Write Completion Message

The ATU encounters this error only in the PCI-X mode.

A master abort is signaled when the target of the transaction does not assert **DEVSEL**# within 7 clocks of the assertion of **FRAME**#.

When the ATU is signaled a Master-Abort while initiating either a Split Read Completion Transaction or a Split Write Completion Message, the ATU discards the Split Completion and take no further action.

# 3.7.3.3 Master-Aborts Signaled by the ATU as a Target

## 3.7.3.3.1 Address Parity Errors

The ATU can only signal this error during an Address Parity Error in the Conventional mode.

Please see Section 3.7.1, "Address and Attribute Parity Errors on the PCI Interface" on page 175 for details on the ATU response to an Address Parity Error in the Conventional mode.

#### 3.7.3.3.2 Internal Bus Master-Abort

The ATU can only signal this error during an internal bus master abort in the PCI-X mode.

Please see Section 3.7.7.1, "Master Abort on the Internal Bus" on page 193 for details on the ATU response to an Internal Bus Master Abort in the PCI-X mode.



# 3.7.4 Target Aborts on the PCI Interface

As an initiator on the PCI bus, the ATU can encounter target abort conditions during:

- · Outbound Read Request
- Outbound Write Request
- Inbound Read Completion
- Inbound Configuration Write Completion Message

As a target, the ATU PCI interface is capable of signaling a target abort case during:

- Inbound Read Request (PCI-X and Conventional Modes)
- Inbound Write Request to EROM memory space (PCI-X and Conventional Modes)

# 3.7.4.1 Target Aborts for Outbound Read Request or Outbound Write Request

This error can be encountered by the ATU in both the Conventional and PCI-X modes. For an Outbound transaction, there are two ways in which a Target-Abort may be signaled to the ATU:

- 1. In the Conventional or PCI-X modes, a target abort is signaled when the target of the transaction simultaneously deasserts **DEVSEL**#, deasserts TRDY#, and asserts STOP#.
- 2. In PCI-X mode, ATU may enqueue a Split request (Read or Write) on target-side interface of a PCI-to-PCI Bridge. When PCI-to-PCI Bridge detects a Target Abort on requester-side interface for that Split Request, target abort is signaled to ATU through a Target-Abort Split Completion Error Message (class=1h bridge error and index=01h Target Abort). The following actions with the given constraints are performed by the ATU when a target abort is detected by the PCI initiator interface or the PCI target interface receives a Target-Abort Split Completion error message:
- Set the Target Abort (master) bit (bit 12) in the ATUSR.
- When the ATU PCI Target Abort (master) Interrupt Mask bit in the ATUIMR is clear, set the PCI Target Abort (master) bit in the ATUISR. When set, no action.
- When the transaction is an MSI outbound write and the SERR# Enable bit in the ATUCMD is set, assert SERR#; otherwise, no action is taken. When the ATU asserts SERR#, additional actions is taken:
  - Set the **SERR**# Asserted bit in the ATUSR.
  - When the ATU **SERR**# Asserted Interrupt Mask Bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.
  - When the ATU **SERR**# Detected Interrupt Enable Bit in the ATUCR is set, set the **SERR**# Detected bit in the ATUISR. When clear, no action.
- When operating in the PCI-X mode and the Target-Abort is signaled via a Split Completion Error Message, the Received Split Completion Error Message bit in the PCIXSR is set. When the ATU sets this bit, additional actions is taken:
  - When the ATU Received Split Completion Error Message Interrupt Mask bit in the ATUIMR is clear, set the Received Split Completion Error Message bit in the ATUISR. When set, no action.
- For an Outbound Read request, generate a split completion error message (message class=1h 80331 Outbound Request error and message index=01h target abort) on the internal bus.
- Flush the address from the OTQ.



# 3.7.4.2 Inbound Read Completion or Inbound Configuration Write Completion Message

The ATU encounters this error only in the PCI-X mode.

A target abort is signaled when the target of the transaction simultaneously deasserts **DEVSEL**#, deasserts TRDY#, and asserts STOP#.

When the ATU is signaled a Target-Abort while initiating either a Split Read Completion Transaction or a Split Write Completion Message, the ATU discards the Split Completion and take no further action

# 3.7.4.3 Target-Aborts Signaled by the ATU as a Target

#### 3.7.4.3.1 Internal Bus Master Abort

A target abort can be signaled by the ATU during an inbound read request where the internal bus cycle resulted in a master abort on the Internal Bus.

Please see Section 3.7.7.1, "Master Abort on the Internal Bus" on page 193 for details on the ATU response to an Internal Bus Master Abort.

#### 3.7.4.3.2 Internal Bus Target Abort

A target abort can be signaled by the ATU during an inbound read request where the internal bus cycle resulted in a Target Abort from the memory controller due to a non-recoverable multi-bit ECC error.

Please see Section 3.7.7.2, "Target Abort on the Internal Bus" on page 195 for details on the ATU response to an Internal Bus Target Abort.

#### 3.7.4.3.3 Inbound EROM Memory Write

Since the EROM memory window is defined to be read-only by the *PCI Local Bus Specification*, Revision 2.3, the ATU target-aborts when an inbound write transaction is claimed by the EROM memory window.

The following additional actions with the given constraints are performed by the ATU when a target abort is signaled by the PCI target interface during an inbound EROM Memory write transaction:

- Set the Target Abort (target) bit (bit 11) in the ATUSR.
  - When the ATU PCI Target Abort (target) Interrupt Mask bit in the ATUIMR is clear, set the PCI Target Abort (target) bit in the ATUISR. When set, no action.



# 3.7.5 Corrupted or Unexpected Split Completions

Warning:

When any of the errors discussed in this section actually occur, a catastrophic system failure is likely to result from which the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a provides no recovery mechanism. In these cases, the ATU may be communicating with a non-compliant target device or the system may not be configured properly.

## 3.7.5.1 Completer Address

The ATU only asserts **DEVSEL**# for split completion transactions where the Sequence ID (Requester ID and Tag) matches that of a currently outstanding split request in the OTQ.

Conversely, the ATU does not assert **DEVSEL#** for any split completion transaction where either the Requester ID does not match that of the ATU or the Tag does not match that of any currently outstanding split request. No further action is taken.

When the Sequence ID of a split completion transaction matches that of an outstanding request, but the Lower Address field is not valid, the ATU accepts the split completion transaction in its' entirety according to the invalid Lower Address field and set the Unexpected Split Completion bit in the PCIXSR. No further action is taken.

## 3.7.5.2 Completer Attributes

When the Sequence ID of a split completion transaction matches that of an outstanding request, but the Byte Count is not valid, the ATU accepts the split completion transaction in its' entirety according to the invalid byte count field and set the Unexpected Split Completion bit in the PCIXSR. In this case, the ATU discards all the data. No further action is taken.



## 3.7.6 SERR# Assertion and Detection

The ATU is capable of reporting error conditions through the use of the SERR# output.

The following conditions may result in the assertion of **SERR**# by the ATU:

- An address parity error (or an attribute parity error when operating in the PCI-X mode) is detected by the ATU PCI interface (see Section 3.7.1, "Address and Attribute Parity Errors on the PCI Interface" on page 175 for details).
- A Master Data Parity Error is recorded in the ATUSR while operating in the PCI-X mode (see Section 3.7.2, "Data Parity Errors on the PCI Interface" on page 176 for details).
- An outbound MSI write transaction is either signaled a Master-Abort or a Target-Abort by the target.
- An inbound write transaction is master aborted on the internal bus (see Section 3.7.7.1, "Master Abort on the Internal Bus" on page 193 for details).
- The **SERR**# Manual Assertion bit in the ATUCR has been set and the **SERR**# Enable bit is set in the ATUCMD.

Note that the **SERR**# manual assertion bits must be cleared manually before they can be set again resulting in **SERR**# asserted. Refer to Section 3.10.39, "ATU Configuration Register - ATUCR" on page 252 for details.

The following actions with the given constraints are performed by the ATU when **SERR**# is asserted by the PCI interface:

- Set the **SERR**# Asserted bit in the ATUSR.
- When the ATU **SERR**# Asserted Interrupt Mask bit in the ATUIMR is clear, set the **SERR**# Asserted bit in the ATUISR. When set, no action.
- When **SERR**# is asserted and the ATU **SERR**# Detected interrupt enable is set in the ATUCR, set the **SERR**# Detected bit in the ATUISR. When clear, no action.

The following actions with the given constraints are performed by the ATU when **SERR**# is detected by the PCI interface:

 When SERR# is detected and the ATU SERR# Detected interrupt enable is set in the ATUCR, set the SERR# Detected bit in the ATUISR. When clear, no action.

**Note:** Whenever the ATU asserts **SERR**#, both the asserted and detected status bits may be set in the corresponding ISR. To mask an interrupt to the core when the ATU asserts **SERR**#, the **SERR**# asserted mask bit must be set and the **SERR**# detected interrupt enable bit must be clear.



## 3.7.7 Internal Bus Error Conditions

The 80331 internal bus uses a protocol similar to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a. As such, master abort and target abort conditions are valid error states on the bus. The error handling protocol for internal bus conditions is similar to the PCI bus error protocol. An internal bus error results in a bit being set in the Interrupt Status Registers at which time an interrupt is driven to the Intel<sup>®</sup> XScale <sup>TM</sup> core. Unlike PCI errors, internal bus error conditions are not maskable.

The following sections detail internal bus error conditions for the ATU.

#### 3.7.7.1 Master Abort on the Internal Bus

A master abort on the internal bus is seen by the ATU when the inbound translated address presented on the internal bus is not claimed by the assertion of **I\_DEVSEL#**.

#### 3.7.7.1.1 Inbound Write Request

The following action with the given constraints are performed by the ATU when a master abort is detected by the internal master interface during an inbound write request transaction:

- Set the Internal Bus Master Abort bit (bit 7) in the ATUISR.
- When the Inbound Error SERR# Enable bit is set in the ATUIMR and the SERR# Enable bit
  is set in the ATUCMD, assert SERR# on the PCI interface. When both bits are not set, take no
  action. When SERR# is asserted, additional actions are taken:
  - Set the **SERR**# Asserted bit in the ATUSR
  - When the ATU SERR# Asserted Interrupt Mask bit in the ATUIMR is clear, set the SERR# Asserted bit in the ATUISR. When set, no action
  - When the ATU SERR# Detected interrupt enable is set in the ATUCR, set the SERR# Detected bit in the ATUISR. When clear, no action
- Flush the transaction that was master aborted from the IWQ.

The Internal Bus Master Abort bit is non-maskable and always results in an interrupt being driven to the core processor.



#### 3.7.7.1.2 Inbound Read Request

When operating in the Conventional mode, the following actions with the given constraints are performed by the ATU when a master abort is detected by the internal initiator interface during an inbound read transaction:

- Set the Internal Bus Master Abort bit (bit 7) in the ATUISR
- Return a target abort condition to the initiating master during the delayed completion cycle on the PCI bus. No data is ever read from the internal bus and returned to the PCI bus.

The following additional actions with the given constraints are performed by the ATU when a target abort is signaled by the PCI interface during an inbound delayed read completion cycle:

- Set the Target Abort (target) bit (bit 11) in the ATUSR.
- When the ATU PCI Target Abort (target) Interrupt Mask bit in the ATUIMR is clear, set the PCI Target Abort (target) bit in the ATUISR. When set, no action.
- Flush the transaction that was master aborted from the ITQ after the target abort is delivered on the PCI interface.

When operating in the PCI-X mode, the following actions with the given constraints are performed by the ATU when a master abort is detected by the internal master interface during an inbound split read transaction:

- Set the Internal Bus Master Abort bit (bit 7) in the ATUISR.
- Generate a Split Completion Error Message (with message class=2h completer error and message index=80h 80331 internal bus master abort) on the PCI bus.
- When the Initiated Split Completion Error Message Interrupt Mask in the ATUIMR is clear, set the Initiated Split Completion Error Message bit in the ATUISR. When set, no action.
- Flush the transaction that was master aborted.

**Note:** This split completion error message includes a device specific message index. The error handler would need to have knowledge of the device specific error messages of the 80331 in order to fully diagnose the problem.

The Internal Bus Master Abort bit is non-maskable and always results in an interrupt being driven to the core processor.



# 3.7.7.2 Target Abort on the Internal Bus

Target Aborts can be seen by the internal bus requester interface during inbound read operations to the memory controller. During inbound read operations, the memory controller is capable of signalling a target abort when a multi-bit, unrecoverable ECC error is encountered. This can occur during any read operation.

Note target aborts are signalled on a Qword basis. When either Dword of a Qword target aborts, both is considered to have target aborted.

The Memory Controller is responsible for creating an interrupt to the  $Intel^{\textcircled{R}}$  XScale  $^{TM}$  core for any multi-bit ECC errors.

#### 3.7.7.2.1 Conventional Mode

When operating in the Conventional PCI mode, when the data word which was target aborted on the internal bus is actually requested and delivered on the PCI Bus, and the ATU ECC Target Abort Enable bit is set in the ATUIMR, a target abort is returned to the PCI initiator on that data word. When the ATU ECC Target Abort Enable bit is clear in the ATUIMR, a disconnect with data is returned to the PCI initiator during the data word that was target aborted on the internal bus. In both cases, the IRQ is flushed after the completion cycle is performed on the PCI bus

The following additional actions with the given constraints are performed by the ATU when a target abort is signaled by the PCI target interface during an inbound read transaction:

- Set the Target Abort (target) bit (bit 11) in the ATUSR.
- When the ATU PCI Target Abort (target) Interrupt Mask bit in the ATUIMR is clear, set the PCI Target Abort (target) bit in the ATUISR. When set, no action.

#### 3.7.7.2.2 PCI-X Mode

When operating in the PCI-X mode, a Target-Abort of an inbound read transaction (split read request) on the Internal Bus results in the following actions.

- The ATU initiates a Split Completion Error Message (with message class=2h completer error and message index=81h 80331 internal bus target abort) on the PCI bus.
- When the Initiated Split Completion Error Message Interrupt Mask in the ATUIMR is clear, set the Initiated Split Completion Error Message bit in the ATUISR. When set, no action.

**Note:** This split completion error message includes a device specific message index. The error handler would need to have knowledge of the device specific error messages of the 80331 in order to fully diagnose the problem.



# 3.7.8 ATU Error Summary

Table 81 summarizes the ATU error reporting for PCI bus errors and Table 82 summarizes the ATU error reporting for internal bus errors. The tables assume that all error reporting is enabled through the appropriate command registers (unless otherwise noted). The ATU Status Register records PCI bus errors. Note that the SERR# Asserted bit in the Status Register is set only when the SERR# Enable bit in the Command Register is set. The ATU Interrupt Status Registers record Intel<sup>®</sup> XScale Torre interrupt status information.

## Table 81. ATU Error Reporting Summary - PCI Interface (Sheet 1 of 3)

| Error<br>Condition <sup>a</sup><br>(Bus Mode <sup>b</sup> )         | Bits Set in ATU Status Register (ATUSR <sup>c</sup> ) or PCI-X Status Register (PCIXSR <sup>d</sup> ) | Bits Set in<br>ATU Interrupt Status Register<br>(ATUISR)                       | Interrupt Mask Bit in<br>ATUIMR or ATUCR |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------|
|                                                                     | PCI Bus Error Response                                                                                | (i.e., signal Target-Abort, signal                                             | Master-Abort etc.)                       |
| Address or<br>Attribute Parity<br>Error (Both)                      |                                                                                                       | aster-Abort) the transaction, and ton and complete as though no errodetection. |                                          |
| (Both)                                                              | SERR# Asserted - bit 14                                                                               | SERR# Asserted - bit 10                                                        | ATUIMR bit 6                             |
| (Both)                                                              | N/A                                                                                                   | SERR# Detected - bit 4                                                         | ATUCR bit 9                              |
| (Both)                                                              | Detected Address or Attribute Parity Error - bit 18 of the PCI Configuration and Status Register      |                                                                                | N/A                                      |
| (Both)                                                              | Detected Parity Error - bit 15                                                                        | Detected Parity Error - bit 9                                                  | ATUIMR bit 7                             |
| Outbound Read<br>Request Parity<br>Error (Both)                     | Signal PERR# and SERR# (PCI                                                                           | -X Mode Only).                                                                 |                                          |
| (Both)                                                              | Master Parity Error - bit 8                                                                           | Master Parity Error - bit 0                                                    | ATUIMR bit 2                             |
| (PCI-X)                                                             | SERR# Asserted - bit 14                                                                               | SERR# Asserted - bit 10                                                        | ATUIMR bit 6                             |
| (PCI-X)                                                             | N/A                                                                                                   | SERR# Detected - bit 4                                                         | ATUCR bit 9                              |
| (Both)                                                              | Detected Parity Error - bit 15                                                                        | Detected Parity Error - bit 9                                                  | ATUIMR bit 7                             |
| Outbound Write<br>Request Parity<br>Error (Both)                    | Signal SERR# (only for PCI-X or                                                                       | r MSI Writes).                                                                 |                                          |
| (Both)                                                              | Master Parity Error - bit 8                                                                           | Master Parity Error - bit 0                                                    | ATUIMR bit 2                             |
| (PCI-X or MSI)                                                      | SERR# Asserted - bit 14                                                                               | SERR# Asserted - bit 10                                                        | ATUIMR bit 6                             |
| (PCI-X or MSI)                                                      | N/A                                                                                                   | SERR# Detected - bit 4                                                         | ATUCR bit 9                              |
| Inbound Read<br>Completions<br>Parity Error<br>(PCI-X)              | None.                                                                                                 |                                                                                |                                          |
| Inbound Configuration Write Completion Message Parity Error (PCI-X) | None.                                                                                                 |                                                                                |                                          |
| Inbound Read<br>Request Parity<br>Error (Both)                      | None.                                                                                                 |                                                                                |                                          |



# Table 81. ATU Error Reporting Summary - PCI Interface (Sheet 2 of 3)

| Error<br>Condition <sup>a</sup><br>(Bus Mode <sup>b</sup> )         | Bits Set in ATU Status Register (ATUSR <sup>c</sup> ) or PCI-X Status Register (PCIXSR <sup>d</sup> ) PCI Bus Error Response | Bits Set in ATU Interrupt Status Register (ATUISR)  (i.e., signal Target-Abort, signal | Interrupt Mask Bit in<br>ATUIMR or ATUCR<br>Master-Abort etc.) |
|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Inbound Write<br>Request Parity<br>Error (Both)                     | Signal PERR#.                                                                                                                |                                                                                        | ,                                                              |
| (Both)                                                              | Detected Parity Error - bit 15                                                                                               | Detected Parity Error - bit 9                                                          | ATUIMR bit 7                                                   |
| Outbound Split<br>Write Data Parity<br>Error Message<br>(PCI-X)     | Signal <b>SERR#</b> .                                                                                                        |                                                                                        |                                                                |
| (PCI-X)                                                             | Master Parity Error - bit 8                                                                                                  | Master Parity Error - bit 0                                                            | ATUIMR bit 2                                                   |
| (PCI-X)                                                             | SERR# Asserted - bit 14                                                                                                      | SERR# Asserted - bit 10                                                                | ATUIMR bit 6                                                   |
| (PCI-X)                                                             | N/A                                                                                                                          | SERR# Detected - bit 4                                                                 | ATUCR bit 9                                                    |
| (PCI-X)                                                             | Received Split Completion Error<br>Message - bit 29                                                                          | Received Split Completion Error<br>Message - bit 12                                    | ATUIMR bit 9                                                   |
| Inbound<br>Configuration<br>Write Request<br>Parity Error<br>(Both) | Signal <b>PERR#</b> . Initiate a Split Wr (PCI-X Mode Only).                                                                 | ite Data Parity Error Message add                                                      | ressed to the Requester                                        |
| (PCI-X)                                                             | N/A                                                                                                                          | Initiated Split Completion Error<br>Message - bit 13                                   | ATUIMR bit 10                                                  |
| (Both)                                                              | Detected Parity Error - bit 15                                                                                               | Detected Parity Error - bit 9                                                          | ATUIMR bit 7                                                   |
| Split Completion<br>Message Parity<br>Error (PCI-X)                 | Signal <b>PERR#</b> and <b>SERR#</b> .                                                                                       |                                                                                        |                                                                |
| (PCI-X)                                                             | Master Parity Error - bit 8                                                                                                  | Master Parity Error - bit 0                                                            | ATUIMR bit 2                                                   |
| (PCI-X)                                                             | SERR# Asserted - bit 14                                                                                                      | SERR# Asserted - bit 10                                                                | ATUIMR bit 6                                                   |
| (PCI-X)                                                             | N/A                                                                                                                          | SERR# Detected - bit 4                                                                 | ATUCR bit 9                                                    |
| (PCI-X and SCE <sup>e</sup> )                                       | Received Split Completion Error<br>Message - bit 29                                                                          | Received Split Completion Error<br>Message - bit 12                                    | ATUIMR bit 9                                                   |
| (PCI-X)                                                             | Detected Parity Error - bit 15                                                                                               | Detected Parity Error - bit 9                                                          | ATUIMR bit 7                                                   |
| Outbound Read<br>Request<br>Master-Abort<br>(Both)                  | None.                                                                                                                        |                                                                                        |                                                                |
| (Both)                                                              | Master Abort - bit 13                                                                                                        | PCI Master Abort - bit 3                                                               | ATUIMR bit 5                                                   |
| (PCI-X and SCE)                                                     | Received Split Completion Error<br>Message - bit 29                                                                          | Received Split Completion Error<br>Message - bit 12                                    | ATUIMR bit 9                                                   |
| Outbound Write<br>Request<br>Master-Abort<br>(Both)                 | None.                                                                                                                        |                                                                                        |                                                                |
| (Both)                                                              | Master Abort - bit 13                                                                                                        | PCI Master Abort - bit 3                                                               | ATUIMR bit 5                                                   |
| (MSI)                                                               | SERR# Asserted - bit 14                                                                                                      | SERR# Asserted - bit 10                                                                | ATUIMR bit 6                                                   |
| (MSI)                                                               | N/A                                                                                                                          | SERR# Detected - bit 4                                                                 | ATUCR bit 9                                                    |
| (PCI-X and<br>SCE)                                                  | Received Split Completion Error<br>Message - bit 29                                                                          | Received Split Completion Error<br>Message - bit 12                                    | ATUIMR bit 9                                                   |



## Table 81. ATU Error Reporting Summary - PCI Interface (Sheet 3 of 3)

| Error<br>Condition <sup>a</sup><br>(Bus Mode <sup>b</sup> )                           | Bits Set in ATU Status Register (ATUSR <sup>c</sup> ) or PCI-X Status Register (PCIXSR <sup>d</sup> ) | Bits Set in<br>ATU Interrupt Status Register<br>(ATUISR) | Interrupt Mask Bit in<br>ATUIMR or ATUCR |
|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------|
|                                                                                       | PCI Bus Error Response                                                                                | (i.e., signal Target-Abort, signal                       | Master-Abort etc.)                       |
| Inbound Read<br>Completions<br>Master-Abort<br>(PCI-X)                                | None.                                                                                                 |                                                          |                                          |
| Inbound<br>Configuration<br>Write<br>Completion<br>Message<br>Master-Abort<br>(PCI-X) | None.                                                                                                 |                                                          |                                          |
| Outbound Read<br>Request<br>Target-Abort<br>(Both)                                    | None.                                                                                                 |                                                          |                                          |
| (Both)                                                                                | Target Abort (master) - bit 12 PCI Target Abort (master) - bit 2                                      |                                                          | ATUIMR bit 4                             |
| (PCI-X and SCE)                                                                       | Received Split Completion Error Message - bit 29 Received Split Completion Error Message - bit 12     |                                                          | ATUIMR bit 9                             |
| Outbound Write<br>Request<br>Target-Abort<br>(Both)                                   | None.                                                                                                 |                                                          |                                          |
| (Both)                                                                                | Target Abort (master) - bit 12                                                                        | PCI Target Abort (master) - bit 2                        | ATUIMR bit 4                             |
| (MSI)                                                                                 | SERR# Asserted - bit 14                                                                               | SERR# Asserted - bit 10                                  | ATUIMR bit 6                             |
| (MSI)                                                                                 | N/A                                                                                                   | SERR# Detected - bit 4                                   | ATUCR bit 9                              |
| (PCI-X and SCE)                                                                       | Received Split Completion Error<br>Message - bit 29                                                   | Received Split Completion Error<br>Message - bit 12      | ATUIMR bit 9                             |
| Inbound EROM<br>Write Request<br>Target-Abort<br>(Both)                               | Signal Target-Abort.                                                                                  |                                                          |                                          |
| (Both)                                                                                | Target Abort (target) - bit 11                                                                        | PCI Target Abort (target) - bit 1                        | ATUIMR bit 3                             |
| Unexpected<br>Split Completion<br>(PCI-X)                                             | In the PCI-X mode, the transaction address field or invalid byte countries.                           | on completes normally according to<br>t.                 | o the invalid lower                      |
| (PCI-X)                                                                               | Unexpected Split Completion -<br>bit 19                                                               | N/A                                                      | N/A                                      |

- a. All parity errors refer to data parity errors except where otherwise noted.
- b. Codes for bus mode in which this error response applies: PCI-X means PCI-X Mode Only, Conventional means Conventional PCI Mode Only, and Both means that the error response applies both in the Conventional and PCI-X mode of operation. MSI stands for Message-Signaled Interrupts and refers to an Outbound Write transaction that is actually an MSI write transaction.
- c. Table assumes that Parity Error Response bit 6 of the ATUCMD register is set.
- d. Table assumes that Data Parity Recovery Enable bit 0 of the PCIXCMD is clear.
- e. When the SCE bit (bit 30 of the Completer Attributes) and the SCM bit (bit 29 of the Completer Attributes) are set during the Attribute phase of a Split Completion Transaction, the transaction is a Split Completion Message that is an Error Message. In this case, the Received Split Completion Error Message bit 29 of the PCIXSR is set.



## Table 82. ATU Error Reporting Summary - Internal Bus Interface

| Error<br>Condition <sup>a</sup><br>(Bus Mode <sup>b</sup> ) | Bits Set in<br>ATU Status Register<br>(ATUSR <sup>c</sup> )    | Bits Set in<br>ATU Interrupt Status Register<br>(ATUISR) | Interrupt Mask Bit in<br>ATUIMR or ATUCR |
|-------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------|------------------------------------------|
|                                                             | PCI Bus Error Response                                         | (i.e., signal Target-Abort, signal                       | Master-Abort etc.)                       |
| Inbound Write<br>Request<br>Master-Abort<br>(Both)          | Assert <b>SERR#</b> .                                          |                                                          |                                          |
| (Both)                                                      | N/A                                                            | Internal Bus Master Abort - bit 7                        | N/A                                      |
| (Both)                                                      | SERR# Asserted - bit 14                                        | SERR# Asserted - bit 10                                  | ATUIMR bit 6                             |
| (Both)                                                      | N/A                                                            | SERR# Detected - bit 4                                   | ATUCR bit 9                              |
| Inbound Read<br>Request<br>Master-Abort<br>(Both)           | In the Conventional Mode signal Split Completion Error Message | Target-Abort. In the PCI-X Mode s<br>to the Requester.   | end a device specific                    |
| (Both)                                                      | N/A                                                            | Internal Bus Master Abort - bit 7                        | N/A                                      |
| (Conventional)                                              | Target Abort (target) - bit 11                                 | PCI Target Abort (target) - bit 1                        | ATUIMR bit 3                             |
| (PCI-X)                                                     | N/A                                                            | Initiated Split Completion Error<br>Message - bit 13     | ATUIMR bit 10                            |
| Inbound Read<br>Request<br>Target-Abort<br>(Both)           | In the Conventional Mode signal Split Completion Error Message | Target-Abort. In the PCI-X Mode s<br>to the Requester.   | end a device specific                    |
| (Conventional)                                              | Target Abort (target) - bit 11                                 | PCI Target Abort (target) - bit 1                        | ATUIMR bit 3                             |
| (PCI-X)                                                     | N/A                                                            | Initiated Split Completion Error<br>Message - bit 13     | ATUIMR bit 10                            |

a. There are no Inbound Write Request Target-Abort Error Conditions.

b. Codes for bus mode in which this error response applies: PCI-X means PCI-X Mode Only, Conventional means Conventional PCI Mode Only, and Both means that the error response applies both in the Conventional and PCI-X mode of operation. MSI stands for Message-Signaled Interrupts and refers to an Outbound Write transaction that is actually an MSI write transaction.

Table assumes that the ATU Inbound SERR# Enable bit (bit 1 of the ATUIMR), the ATU ECC Target Abort Enable (bit 0 of the ATUIMR), and the SERR# Enable bit (bit 8 of the ATUCMD) are set.



# 3.8 Message-Signaled Interrupts

The Messaging Unit is responsible for the generation of all of the Outbound Interrupts from the 80331. These interrupts can be delivered to the Host Processor via the **P\_INTC**# output pin or the Message Signaled Interrupt (MSI) mechanism.

When a host processor enables Message-Signaled Interrupts (MSI) on the 80331, an outbound interrupt is signaled to the host via a PCI write instead of the assertion of the **P\_INTC**# output pin.

In support of MSI, the 80331 implements the MSI capability structure. The capability structure includes the Section 4.9.20, "MSI Capability Identifier Register - MSI\_CAPID" on page 323, the Section 4.9.21, "MSI Next Item Pointer Register - MSI\_NXTP" on page 324, the Section 4.9.23, "MSI Message Address Register - MSI\_MAR" on page 326, the Section 4.9.24, "MSI Message Upper Address Register - MSI\_MUAR" on page 327 and the Section 4.9.25, "MSI Message Data Register- MSI\_MDR" on page 328.

The Message Unit generates MSIs by writing to the MSI port via the internal bus. The ATU generates a write transaction whenever the Message Unit writes to the MSI port, using the address specified in the Section 4.9.23, "MSI Message Address Register - MSI\_MAR" on page 326, the Section 4.9.24, "MSI Message Upper Address Register - MSI\_MUAR" on page 327 and the Section 4.9.25, "MSI Message Data Register- MSI\_MDR" on page 328.



# 3.9 Vital Product Data

Vital Product Data (VPD) provides detailed information to the system regarding the hardware, software and microcode elements of a device. This information may include Part Number, Serial Number or other detailed information. This information resides on a non-volatile storage device (i.e., Flash Memory) attached to the 80331. In addition VPD also provides a mechanism for storing information such as performance or failure data on the device being monitored.

Support of VPD involves the implementation of the VPD Extended Capabilities List Item in the Primary ATU. The VPD Extended capabilities header consists of five registers, the "VPD Capability Identifier Register - VPD\_CAPID" on page 267, the "VPD Next Item Pointer Register - VPD\_NXTP" on page 268, the "VPD Address Register - VPD\_AR" on page 269, and the "VPD Data Register - VPD\_DR" on page 270.

Scheduled by Intel<sup>®</sup> XScale<sup>™</sup> core interrupts, the 80331 may be used to retrieve or store VPD information through the VPD extended capabilities list item.

Please consult Appendix I of the *PCI Local Bus Specification*, Revision 2.3 for the definitions of compliant VPD format.

# 3.9.1 Configuring Vital Product Data Operation

By default, the 80331 VPD functionality is not configured for operation. Specifically, the VPD Extended Capabilities List Item is not discovered during a PCI bus scan and the ATUs VPD interrupt status bit in the "ATU Interrupt Status Register - ATUISR" on page 257 is masked by the "ATU Interrupt Mask Register - ATUIMR" on page 259. The following steps should be followed to properly configure the Intel<sup>®</sup> 80331 I/O processor support for VPD:

- 1. The 80331 must be strapped to Retry Type 0 Configuration cycles following the deassertion of **P\_RST#**. Enabling this configuration cycle retry mechanism guarantees that the Intel<sup>®</sup> XScale<sup>™</sup> core can make the VPD Extended Capabilities List Item visible before the system configures the 80331. The configuration retry mechanism is controlled through bit 2 of the Table 125, "PCI Configuration and Status Register PCSR" on page 253.
- 2. When the configuration retry mechanism is strapped enabled as described in step 1, typically, the 80331 would also be strapped such that the Intel<sup>®</sup> XScale <sup>™</sup> core would immediately boot following the deassertion of **P\_RST#** (bit 1 of the PCSR), though this is not required.
- 3. The Intel<sup>®</sup> XScale<sup>™</sup> core writes E8H to the "PCI-X Next Item Pointer Register PX\_NXTP" on page 277. This links the PCI-X Capabilities List Item to the VPD Capabilities List Item.
- 4. The Intel<sup>®</sup> XScale<sup>™</sup> core clears bit 12 of the ATUIMR to enable the ATUs VPD interrupt status bit.



# 3.9.2 Accessing Vital Product Data

The VPD Capabilities List Item provides three fields which the system uses to access the Vital Product Data:

VPD AddressDWORD Aligned Byte address of the VPD to be accessed which is represented by VPDAR[14:0]. Note that this means that the maximum size of the VPD is 128 Kbytes. The user may pick any 128 Kbyte block of memory in the storage component for the VPD.

Flag The flag register is used to indicate when the transfer between the VPD Data Register and the storage component is completed. The flag is in VPDAR[15] which means that the Flag is written at the same time that VPD address is written.

VPD Data Four bytes of VPD Data can be read or written through this field which is represented by VPDDR[31:0]. The least significant byte of this register represents the byte at the VPD Address (VPDAR[14:0]). Four bytes are always transferred between this register and the VPD storage component.

# 3.9.2.1 Reading Vital Product Data

Using the fields defined in the VPD Capabilities List Item, the 80331 reads Vital Product Data using the following sequence of events:

- 1. Host processor executes a configuration write of the VPD address to the VPDAR with the Flag cleared.
- 2. An interrupt to the Intel<sup>®</sup> XScale<sup>™</sup> core is triggered and bit 17 of the ATUISR is set. Meanwhile, the host processor polls the VPDAR register waiting for the Flag to be set.

**Warning:** When any configuration writes to either the VPDAR or the VPDDR occur prior to the Flag being set, the results of the original read operation are unpredictable.

- 3. Using the VPD Address, the Intel<sup>®</sup> XScale<sup>™</sup> core retrieves the Vital Product Data from the VPD storage component (i.e., Flash Memory).
- 4. The Intel<sup>®</sup> XScale<sup>™</sup> core then writes this data to VPD Data Register (VPDDR).
- 5. The Intel<sup>®</sup> XScale<sup>™</sup> core clears the VPD interrupt status bit in the ATUISR.
- 6. The Intel<sup>®</sup>  $XScale^{TM}$  core then sets the Flag in the VPDAR register.
- 7. When the host processor detects that the Flag has been set, the host processor then reads the retrieved VPD from the VPDDR.



# 3.9.2.2 Writing Vital Product Data

Using the fields defined in the VPD Capabilities List Item, the 80331 writes Vital Product Data using the following sequence of events:

- 1. Host processor executes a configuration write of the VPD data to be written to the VPDDR.
- Host processor executes a configuration write of the VPD address to the VPDAR with the Flag set.
- 3. An interrupt to the Intel<sup>®</sup> XScale<sup>™</sup> core is triggered and bit 17 of the ATUISR is set. Meanwhile, the host processor polls the VPDAR register waiting for the Flag to be cleared.

#### Warning:

When any configuration writes to either the VPDAR or the VPDDR occur prior to the Flag being cleared, the results of the original write operation are unpredictable.

- 4. Using the VPD Address, the Intel<sup>®</sup> XScale<sup>™</sup> core writes the Vital Product Data from the VPDDR to the VPD storage component (i.e., Flash Memory).
- 5. The Intel<sup>®</sup> XScale<sup>™</sup> core clears the VPD interrupt status bit in the ATUISR.
- 6. The Intel<sup>®</sup> XScale  $^{\text{TM}}$  core then clears the Flag in the VPDAR register.
- 7. When the host processor detects that the Flag has been cleared, the host processor has been informed that the VPD write operation is complete.



# 3.10 Register Definitions

Every PCI device implements its own separate configuration address space and configuration registers. The *PCI Local Bus Specification*, Revision 2.3 requires that configuration space be 256 bytes, and the first 64 bytes must adhere to a predefined header format.

Figure 15 defines the header format. Table 84 shows the PCI configuration registers, listed by internal bus address offset. Table 84 shows the entire ATU configuration space (including header and extended registers) and the corresponding section that describes each register. Note that all configuration read and write transactions is accepted on the internal bus as 32-bit transactions. Refer to Chapter 17, "Peripheral Registers".

Figure 15. ATU Interface Configuration Header Format

| ATU Device ID                    |                 | Vend                 | lor ID         | 001             |
|----------------------------------|-----------------|----------------------|----------------|-----------------|
| Status                           |                 | Com                  | mand           | 041             |
|                                  | ATU Class Code  |                      | Revision ID    | 081             |
| ATUBISTR                         | Header Type     | Latency Timer        | Cacheline Size | 0CI             |
|                                  | Inbound ATU E   | Base Address 0       |                | 10l             |
|                                  | Inbound ATU Upp | er Base Address 0    |                | 141             |
|                                  | Inbound ATU E   | Base Address 1       |                | 18 <del>l</del> |
| Inbound ATU Upper Base Address 1 |                 |                      | 1C             |                 |
| Inbound ATU Base Address 2       |                 |                      | 201            |                 |
| Inbound ATU Upper Base Address 2 |                 |                      | 241            |                 |
| Reserved                         |                 |                      | 281            |                 |
| ATU Subs                         | system ID       | ATU Subsyst          | em Vendor ID   | 2C              |
|                                  | Expansion ROM   | /I Base Address      |                | 301             |
| Reserved Capabilities Pointe     |                 | Capabilities Pointer | 341            |                 |
|                                  | Rese            | erved                |                | 381             |
| Maximum Latency                  | Minimum Grant   | Interrupt Pin        | Interrupt Line | 3CI             |

The ATU is programmed via a Type 0 configuration command on the PCI interface. See Section 3.2.1.4, "Inbound Configuration Cycle Translation" on page 147. ATU configuration space is function number zero of the 80331 single-function PCI device.

Beyond the required 64 byte header format, ATU configuration space implements extended register space in support of the units functionality. Refer to the *PCI Local Bus Specification*, Revision 2.3 for details on accessing and programming configuration register space.

The ATU unit includes two 8 byte and one 16 byte extended capability configuration spaces beginning at configuration offset C0H, D0H and E0H. The extended configuration spaces can be accessed by a device on the PCI interface through a mechanism defined in the *PCI Local Bus Specification*, Revision 2.3.



In the ATU Status Register (Section 3.10.4) the appropriate bit is set indicating that the Extended Capability Configuration space is supported. When this bit is read, the device can then read the Capabilities Pointer register (Section 3.10.20) to determine the configuration offset of the Extended Capabilities Configuration Header. The format of these headers are depicted in Figure 16, Figure 17, Figure 18 and Figure 19.

### Figure 16. ATU Interface Extended Configuration Header Format (Power Management)

|                               |                   |                       | -   |
|-------------------------------|-------------------|-----------------------|-----|
| Power Management Capabilities | Next Item Pointer | Capability Identifier | C0H |
| Reserved                      | Power Manageme    | nt Control/Status     | C4H |

The first byte at the Extended Configuration Offset C0H is the ATU Capability Identifier Register (Section). This identifies this Extended Configuration Header space as the type defined by the *PCI Bus Power Management Interface Specification*, Revision 1.1.

Following the Capability Identifier Register is the single byte Next Item Pointer Register (Section 3.10.54) which indicates the configuration offset of an additional Extended Capabilities Header, when supported. In the ATU, the Next Item Pointer Register is set to D0H indicating that there is an additional Extended Capabilities Headers supported in the ATUs configuration space.

To enable the *PCI Bus Power Management Interface Specification*, Revision 1.1 compliance support, the Power State Transition interrupt mask in bit 8 of the ATUIMR needs to be cleared. It is the configuration software's responsibility to properly enable and initialize the ATUs Power Management Interface before the Configuration Cycle Retry Bit in the Table 125, "PCI Configuration and Status Register - PCSR" on page 253 is cleared in order for the ATU to be *Advanced Configuration and Power Interface Specification*, Revision 2.0 compliant.

#### Figure 17. ATU Interface Extended Configuration Header Format (MSI Capability)

| MSI Message Control       | MSI Next Item Pointer MSI Capability ID |                |
|---------------------------|-----------------------------------------|----------------|
| MSI Message Address       |                                         |                |
| MSI Message Upper Address |                                         |                |
| Reserved                  | MSI Message Data                        | 1 <sub>D</sub> |

The first byte at the Extended Configuration Offset D0H is the "MSI Capability Identifier Register - MSI\_CAPID" on page 323. This identifies this Extended Configuration Header space as the type defined by the *PCI Local Bus Specification*, Revision 2.3.

Following the Capability Identifier Register is the single byte "MSI Next Item Pointer Register - MSI\_NXTP" on page 324, which indicates the configuration offset of an additional Extended Capabilities Header, when supported. In the ATU, the Next Item Pointer Register is set to E0H indicating that there is an additional Extended Capabilities Headers supported in the ATUs configuration space.

#### Figure 18. ATU Interface Extended Configuration Header Format (PCI-X Capability)

| PCI-X Command |              | Next Item Pointer | PCI-X Capability ID | E0H |
|---------------|--------------|-------------------|---------------------|-----|
|               | PCI-X Status |                   | E4H                 |     |



The first byte at the Extended Configuration Offset E0H is the PCI-X Capability Identifier Register (Section 3.10.58). This identifies this Extended Configuration Header space as the type defined by the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

Following the Capability Identifier Register is the single byte Next Item Pointer Register (Section 3.10.59) which indicates the configuration offset of an additional Extended Capabilities Header, when supported. In the ATU, the Next Item Pointer Register is set to 00H by default to indicate there are no additional Extended Capabilities Headers in the ATUs configuration space. Software can set this pointer to B8H indicating that there is an additional Extended Capabilities Headers supported in the ATUs configuration space.

### Figure 19. ATU Interface Extended Configuration Header Format (VPD Capability)



The first byte at the Extended Configuration Offset B8H is the VPD Capability Identifier Register (Section 3.10.49). This identifies this Extended Configuration Header space as the type defined by the *PCI Local Bus Specification*, Revision 2.3.

Following the Capability Identifier Register is the single byte Next Item Pointer Register (Section 3.10.50) which indicates the configuration offset of an additional Extended Capabilities Header, when supported. In the ATU, the Next Item Pointer Register is set to 00H indicating that there are no additional Extended Capabilities Headers supported in the ATUs configuration space.

The following sections describe the ATU and Expansion ROM configuration registers. Configuration space consists of 8, 16, 24, and 32-bit registers arranged in a predefined format. Each register is described in functionality, access type (read/write, read/clear, read only) and reset default condition.

See Section 1.4, "Terminology and Conventions" on page 41 for a description of *reserved*, *read only*, and *read/clear*. All registers adhere to the definitions found in the *PCI Local Bus Specification*, Revision 2.3 unless otherwise noted.

The PCI register number for each register is given in Table 84. As stated, a Type 0 configuration command on the bus with an active **IDSEL** or a memory-mapped internal bus access is required to read or write these registers.

**Note:** Each configuration register's access type is individually defined for PCI configuration accesses. Some PCI read-only configuration registers have read/write capability from the 80331 core CPU. See also Chapter 17, "Peripheral Registers".



Table 83. Address Translation Unit Registers (Sheet 1 of 3)

| Register Name                                          | Bits | PCI Configu-<br>ration Cycle<br>Register<br>Number | Internal Bus<br>Address |
|--------------------------------------------------------|------|----------------------------------------------------|-------------------------|
| ATU Vendor ID Register - ATUVID                        | 16   | 0                                                  | FFFF.E100H              |
| ATU Device ID Register - ATUDID                        | 16   | 0                                                  | FFFF.E102H              |
| ATU Command Register - ATUCMD                          | 16   | 1                                                  | FFFF.E104H              |
| ATU Status Register - ATUSR                            | 16   | 1                                                  | FFFF.E106H              |
| ATU Revision ID Register - ATURID                      | 8    | 2                                                  | FFFF.E108H              |
| ATU Class Code Register - ATUCCR                       | 24   | 2                                                  | FFFF.E109H              |
| ATU Cacheline Size Register - ATUCLSR                  | 8    | 3                                                  | FFFF.E10CH              |
| ATU Latency Timer Register - ATULT                     | 8    | 3                                                  | FFFF.E10DH              |
| ATU Header Type Register - ATUHTR                      | 8    | 3                                                  | FFFF.E10EH              |
| ATU BIST Register - ATUBISTR                           | 8    | 3                                                  | FFFF.E10FH              |
| Inbound ATU Base Address Register 0 - IABAR0           | 32   | 4                                                  | FFFF.E110H              |
| Inbound ATU Upper Base Address Register 0 - IAUBAR0    | 32   | 5                                                  | FFFF.E114H              |
| Inbound ATU Base Address Register 1 - IABAR1           | 32   | 6                                                  | FFFF.E118H              |
| Inbound ATU Upper Base Address Register 1 - IAUBAR1    | 32   | 7                                                  | FFFF.E11CH              |
| Inbound ATU Base Address Register 2 - IABAR2           | 32   | 8                                                  | FFFF.E120H              |
| Inbound ATU Upper Base Address Register 2 - IAUBAR2    | 32   | 9                                                  | FFFF.E124H              |
| Reserved                                               | 32   | 10                                                 | FFFF.E128H              |
| ATU Subsystem Vendor ID Register - ASVIR               | 16   | 11                                                 | FFFF.E12CH              |
| ATU Subsystem ID Register - ASIR                       | 16   | 11                                                 | FFFF.E12EH              |
| Expansion ROM Base Address Register -ERBAR             | 32   | 12                                                 | FFFF.E130H              |
| ATU Capabilities Pointer Register - ATU_Cap_Ptr        | 8    | 13                                                 | FFFF.E134H              |
| Reserved                                               | 8    | 13                                                 | FFFF.E135H              |
| Reserved                                               | 16   | 13                                                 | FFFF.E136H              |
| Reserved                                               | 32   | 14                                                 | FFFF.E138H              |
| ATU Interrupt Line Register - ATUILR                   | 8    | 15                                                 | FFFF.E13CH              |
| ATU Interrupt Pin Register - ATUIPR                    | 8    | 15                                                 | FFFF.E13DH              |
| ATU Minimum Grant Register - ATUMGNT                   | 8    | 15                                                 | FFFF.E13EH              |
| ATU Maximum Latency Register - ATUMLAT                 | 8    | 15                                                 | FFFF.E13FH              |
| Inbound ATU Limit Register 0 - IALR0                   | 32   | 16                                                 | FFFF.E140H              |
| Inbound ATU Translate Value Register 0 - IATVR0        | 32   | 17                                                 | FFFF.E144H              |
| Expansion ROM Limit Register - ERLR                    | 32   | 18                                                 | FFFF.E148H              |
| Expansion ROM Translate Value Register - ERTVR         | 32   | 19                                                 | FFFF.E14CH              |
| Inbound ATU Limit Register 1 - IALR1                   | 32   | 20                                                 | FFFF.E150H              |
| Inbound ATU Limit Register 2 - IALR2                   | 32   | 21                                                 | FFFF.E154H              |
| Inbound ATU Translate Value Register 2 - IATVR2        | 32   | 22                                                 | FFFF.E158H              |
| Outbound I/O Window Translate Value Register - OIOWTVR | 32   | 23                                                 | FFFF.E15CH              |

**Document Number: 273942-002** October, 2003 207



Table 83. Address Translation Unit Registers (Sheet 2 of 3)

| Register Name                                                           | Bits | PCI Configuration Cycle Register Number          | Internal Bus<br>Address |
|-------------------------------------------------------------------------|------|--------------------------------------------------|-------------------------|
| Outbound Memory Window Translate Value Register 0- OMWTVR0              | 32   | 24                                               | FFFF.E160H              |
| Outbound Upper 32-bit Memory Window Translate Value Register 0-OUMWTVR0 | 32   | 25                                               | FFFF.E164H              |
| Outbound Memory Window Translate Value Register 1- OMWTVR1              | 32   | 26                                               | FFFF.E168H              |
| Outbound Upper 32-bit Memory Window Translate Value Register 1-OUMWTVR1 | 32   | 27                                               | FFFF.E16CH              |
| Reserved                                                                | 32   | 28                                               | FFFF.E170H              |
| Reserved                                                                | 32   | 29                                               | FFFF.E174H              |
| Outbound Upper 32-bit Direct Window Translate Value Register - OUDWTVR  | 32   | 30                                               | FFFF.E178H              |
| Reserved                                                                | 32   | 31                                               | FFFF.E17CH              |
| ATU Configuration Register - ATUCR                                      | 32   | 32                                               | FFFF.E180H              |
| PCI Configuration and Status Register - PCSR                            | 32   | 33                                               | FFFF.E184H              |
| ATU Interrupt Status Register - ATUISR                                  | 32   | 34                                               | FFFF.E188H              |
| ATU Interrupt Mask Register - ATUIMR                                    | 32   | 35                                               | FFFF.E18CH              |
| Inbound ATU Base Address Register 3 - IABAR3                            | 32   | 36                                               | FFFF.E190H              |
| Inbound ATU Upper Base Address Register 3 - IAUBAR3                     | 32   | 37                                               | FFFF.E194H              |
| Inbound ATU Limit Register 3 - IALR3                                    | 32   | 38                                               | FFFF.E198H              |
| Inbound ATU Translate Value Register 3 - IATVR3                         | 32   | 39                                               | FFFF.E19CH              |
| Reserved                                                                | 32   | 40                                               | FFFF.E1A0H              |
| Outbound Configuration Cycle Address Register - OCCAR                   | 32   | 41                                               | FFFF.E1A4H              |
| Reserved                                                                | 32   | 42                                               | FFFF.E1A8H              |
| Outbound Configuration Cycle Data Register - OCCDR                      | 32   | Not Available in<br>PCI Configu-<br>ration Space | FFFF.E1ACH              |
| Reserved                                                                | 32   | 44                                               | FFFF.E1B0H              |
| Reserved                                                                | 32   | 45                                               | FFFF.E1B4H              |
| VPD Capability Identifier Register - VPD_CAPID                          | 8    | 46                                               | FFFF.E1B8H              |
| VPD Next Item Pointer Register - VPD_NXTP                               | 8    | 46                                               | FFFF.E1B9H              |
| VPD Address Register - VPD_AR                                           | 16   | 47                                               | FFFF.E1BAH              |
| VPD Data Register - VPD_DR                                              | 32   | 47                                               | FFFF.E1BCH              |
| Power Management Capability Identifier Register - PM_CAPID              | 8    | 48                                               | FFFF.E1C0H              |
| Power Management Next Item Pointer Register - PM_NXTP                   | 8    | 48                                               | FFFF.E1C1H              |
| Power Management Capabilities Register - PM_CAP                         | 16   | 48                                               | FFFF.E1C2H              |
| Power Management Control/Status Register - PM_CSR                       | 16   | 49                                               | FFFF.E1C4H              |
| Reserved                                                                | 16   | 49                                               | FFFF.E1C6H              |
| Reserved                                                                | 32   | 50                                               | FFFF.E1C8H              |
| Reserved                                                                | 32   | 51                                               | FFFF.E1CCH              |

208 October, 2003 **Document Number: 273942-002** 



# Table 83. Address Translation Unit Registers (Sheet 3 of 3)

| Register Name                                               | Bits | PCI Configu-<br>ration Cycle<br>Register<br>Number | Internal Bus<br>Address |
|-------------------------------------------------------------|------|----------------------------------------------------|-------------------------|
| MSI Capability Identifier Register - MSI_CAPID              | 8    | 52                                                 | FFFF.E1D0H              |
| MSI Next Item Pointer Register - MSI_NXTP                   | 8    | 52                                                 | FFFF.E1D1H              |
| MSI Message Control Register - MSI_MCR                      | 16   | 52                                                 | FFFF.E1D2H              |
| MSI Message Address Register - MSI_MAR                      | 32   | 53                                                 | FFFF.E1D4H              |
| MSI Message Upper Address Register - MSI_MUAR               | 32   | 54                                                 | FFFF.E1D8H              |
| MSI Message Data Register- MSI_MDR                          | 16   | 55                                                 | FFFF.E1DCH              |
| Reserved                                                    | 16   | 55                                                 | FFFF.E1DEH              |
| PCI-X_Capability Identifier Register - PX_CAPID             | 8    | 56                                                 | FFFF.E1E0H              |
| PCI-X Next Item Pointer Register - PX_NXTP                  | 8    | 56                                                 | FFFF.E1E1H              |
| PCI-X Command Register - PX_CMD                             | 16   | 56                                                 | FFFF.E1E2H              |
| PCI-X Status Register - PX_SR                               | 32   | 57                                                 | FFFF.E1E4H              |
| "PCI Interrupt Routing Select Register - PIRSR" on page 717 | 32   | 59                                                 | FFFF.E1ECH              |
| Secondary PCIDrive Strength Control Register - SPDSCR       | 32   | n/a                                                | FFFF.F5C0H              |
| Primary PCIDrive Strength Control Register - PPDSCR         | 32   | n/a                                                | FFFF.F5C8H              |



Table 84. ATU PCI Configuration Register Space (Sheet 1 of 2)

| Address<br>Offset | ATU PCI Configuration Register Section, Name, Page                                                       |
|-------------------|----------------------------------------------------------------------------------------------------------|
| 00H               | Section 3.10.1, "ATU Vendor ID Register - ATUVID" on page 212                                            |
| 02H               | Section 3.10.2, "ATU Device ID Register - ATUDID" on page 213                                            |
| 04H               | Section 3.10.3, "ATU Command Register - ATUCMD" on page 214                                              |
| 06H               | Section 3.10.4, "ATU Status Register - ATUSR" on page 215                                                |
| 08H               | Section 3.10.5, "ATU Revision ID Register - ATURID" on page 217                                          |
| 09H               | Section 3.10.6, "ATU Class Code Register - ATUCCR" on page 218                                           |
| 0CH               | Section 3.10.7, "ATU Cacheline Size Register - ATUCLSR" on page 219                                      |
| 0DH               | Section 3.10.8, "ATU Latency Timer Register - ATULT" on page 220                                         |
| 0EH               | Section 3.10.9, "ATU Header Type Register - ATUHTR" on page 221                                          |
| 0FH               | Section 3.10.10, "ATU BIST Register - ATUBISTR" on page 222                                              |
| 10H               | Section 3.10.11, "Inbound ATU Base Address Register 0 - IABAR0" on page 223                              |
| 14H               | Section 3.10.12, "Inbound ATU Upper Base Address Register 0 - IAUBAR0" on page 224                       |
| 18H               | Section 3.10.13, "Inbound ATU Base Address Register 1 - IABAR1" on page 225                              |
| 1CH               | Section 3.10.14, "Inbound ATU Upper Base Address Register 1 - IAUBAR1" on page 226                       |
| 20H               | Section 3.10.15, "Inbound ATU Base Address Register 2 - IABAR2" on page 227                              |
| 24H               | Section 3.10.16, "Inbound ATU Upper Base Address Register 2 - IAUBAR2" on page 228                       |
| 2CH               | Section 3.10.17, "ATU Subsystem Vendor ID Register - ASVIR" on page 229                                  |
| 2EH               | Section 3.10.18, "ATU Subsystem ID Register - ASIR" on page 230                                          |
| 30H               | Section 3.10.19, "Expansion ROM Base Address Register - ERBAR" on page 231                               |
| 34H               | Section 3.10.20, "ATU Capabilities Pointer Register - ATU_Cap_Ptr" on page 232                           |
| 3CH               | Section 3.10.22, "ATU Interrupt Line Register - ATUILR" on page 235                                      |
| 3DH               | Section 3.10.23, "ATU Interrupt Pin Register - ATUIPR" on page 236                                       |
| 3EH               | Section 3.10.24, "ATU Minimum Grant Register - ATUMGNT" on page 237                                      |
| 3FH               | Section 3.10.25, "ATU Maximum Latency Register - ATUMLAT" on page 238                                    |
| 40H               | Section 3.10.26, "Inbound ATU Limit Register 0 - IALR0" on page 239                                      |
| 44H               | Section 3.10.27, "Inbound ATU Translate Value Register 0 - IATVR0" on page 240                           |
| 48H               | Section 3.10.28, "Expansion ROM Limit Register - ERLR" on page 241                                       |
| 4CH               | Section 3.10.29, "Expansion ROM Translate Value Register - ERTVR" on page 242                            |
| 50H               | Section 3.10.30, "Inbound ATU Limit Register 1 - IALR1" on page 243                                      |
| 54H               | Section 3.10.31, "Inbound ATU Limit Register 2 - IALR2" on page 244                                      |
| 58H               | Section 3.10.32, "Inbound ATU Translate Value Register 2 - IATVR2" on page 245                           |
| 5CH               | Section 3.10.33, "Outbound I/O Window Translate Value Register - OIOWTVR" on page 246                    |
| 60H               | Section 3.10.34, "Outbound Memory Window Translate Value Register 0 - OMWTVR0" on page 247               |
| 64H               | Section 3.10.35, "Outbound Upper 32-bit Memory Window Translate Value Register 0 - OUMWTVR0" on page 248 |
| 68H               | Section 3.10.36, "Outbound Memory Window Translate Value Register 1 - OMWTVR1" on page 249               |
| 6CH               | Section 3.10.37, "Outbound Upper 32-bit Memory Window Translate Value Register 1 - OUMWTVR1" on page 250 |
| 80H               | Section 3.10.39, "ATU Configuration Register - ATUCR" on page 252                                        |
| 84H               | Section 3.10.40, "PCI Configuration and Status Register - PCSR" on page 253                              |
| 88H               | Section 3.10.41, "ATU Interrupt Status Register - ATUISR" on page 257                                    |
| 8CH               | Section 3.10.42, "ATU Interrupt Mask Register - ATUIMR" on page 259                                      |
| 90H               | Section 3.10.43, "Inbound ATU Base Address Register 3 - IABAR3" on page 261                              |



# Table 84. ATU PCI Configuration Register Space (Sheet 2 of 2)

| Address<br>Offset | ATU PCI Configuration Register Section, Name, Page                                        |
|-------------------|-------------------------------------------------------------------------------------------|
| 94H               | Section 3.10.44, "Inbound ATU Upper Base Address Register 3 - IAUBAR3" on page 262        |
| 98H               | Section 3.10.45, "Inbound ATU Limit Register 3 - IALR3" on page 263                       |
| 9CH               | Section 3.10.46, "Inbound ATU Translate Value Register 3 - IATVR3" on page 264            |
| A4H               | Section 3.10.47, "Outbound Configuration Cycle Address Register - OCCAR" on page 265      |
| ACH               | Section 3.10.48, "Outbound Configuration Cycle Data Register - OCCDR" on page 266         |
| B8H               | Section 3.10.49, "VPD Capability Identifier Register - VPD_CAPID" on page 267             |
| В9Н               | Section 3.10.50, "VPD Next Item Pointer Register - VPD_NXTP" on page 268                  |
| BAH               | Section 3.10.51, "VPD Address Register - VPD_AR" on page 269                              |
| BCH               | Section 3.10.52, "VPD Data Register - VPD_DR" on page 270                                 |
| C0H               | Section 3.10.53, "Power Management Capability Identifier Register - PM_CAPID" on page 271 |
| C1H               | Section 3.10.54, "Power Management Next Item Pointer Register - PM_NXTP" on page 272      |
| C2H               | Section 3.10.55, "Power Management Capabilities Register - PM_CAP" on page 273            |
| C4H               | Section 3.10.56, "Power Management Control/Status Register - PM_CSR" on page 274          |
| D0H               | Section 4.9.20, "MSI Capability Identifier Register - MSI_CAPID" on page 323              |
| D1H               | Section 4.9.21, "MSI Next Item Pointer Register - MSI_NXTP" on page 324                   |
| D2H               | Section 4.9.22, "MSI Message Control Register - MSI_MCR" on page 325                      |
| D4H               | Section 4.9.23, "MSI Message Address Register - MSI_MAR" on page 326                      |
| D8H               | Section 4.9.24, "MSI Message Upper Address Register - MSI_MUAR" on page 327               |
| DCH               | Section 4.9.25, "MSI Message Data Register- MSI_MDR" on page 328                          |
| E0H               | Section 3.10.58, "PCI-X Capability Identifier Register - PX_CAPID" on page 276            |
| E1H               | Section 3.10.59, "PCI-X Next Item Pointer Register - PX_NXTP" on page 277                 |
| E2H               | Section 3.10.60, "PCI-X Command Register - PX_CMD" on page 278                            |
| E4H               | Section 3.10.61, "PCI-X Status Register - PX_SR" on page 279                              |
| ECH               | Section 15.7.17, "PCI Interrupt Routing Select Register - PIRSR" on page 717              |
| n/a               | Section 3.10.63, "Secondary PCIDrive Strength Control Register - SPDSCR" on page 282      |
| n/a               | Section 3.10.64, "Primary PCIDrive Strength Control Register - PPDSCR" on page 283        |



# 3.10.1 ATU Vendor ID Register - ATUVID

ATU Vendor ID Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3.

Table 85. ATU Vendor ID Register - ATUVID





# 3.10.2 ATU Device ID Register - ATUDID

ATU Device ID Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3.

Table 86. ATU Device ID Register - ATUDID





# 3.10.3 ATU Command Register - ATUCMD

ATU Command Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3 and in most cases, affect the behavior of the PCI ATU and devices on the PCI bus.

Table 87. ATU Command Register - ATUCMD





# 3.10.4 ATU Status Register - ATUSR

The ATU Status Register bits adhere to the *PCI Local Bus Specification*, Revision 2.3 definitions. The read/clear bits can only be set by internal hardware and cleared by either a reset condition or by writing a  $1_2$  to the register.

Table 88. ATU Status Register - ATUSR (Sheet 1 of 2)





Table 88. ATU Status Register - ATUSR (Sheet 2 of 2)





## 3.10.5 ATU Revision ID Register - ATURID

Revision ID Register bit definitions adhere to PCI Local Bus Specification, Revision 2.3.

### Table 89. ATU Revision ID Register - ATURID





## 3.10.6 ATU Class Code Register - ATUCCR

Class Code Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. Auto configuration software reads this register to determine the PCI device function.

Table 90. ATU Class Code Register - ATUCCR





## 3.10.7 ATU Cacheline Size Register - ATUCLSR

Cacheline Size Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register is programmed with the system cacheline size in DWORDs (32-bit words). Cacheline Size is restricted to either 0, 8 or 16 DWORDs; the ATU interprets any other value as "0".

Table 91. ATU Cacheline Size Register - ATUCLSR





## 3.10.8 ATU Latency Timer Register - ATULT

ATU Latency Timer Register bit definitions apply to the PCI interface.

### Table 92. ATU Latency Timer Register - ATULT





## 3.10.9 ATU Header Type Register - ATUHTR

Header Type Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register indicates the layout of ATU configuration space bytes 10H to 3FH. The MSB indicates whether or not the device is multi-function.

Table 93. ATU Header Type Register - ATUHTR





## 3.10.10 ATU BIST Register - ATUBISTR

The ATU BIST Register controls the functions the Intel<sup>®</sup> XScale<sup>™</sup> core performs when BIST is initiated. This register is the interface between the host processor requesting BIST functions and the 80331 replying with the results from the software implementation of the BIST functionality.

Table 94. ATU BIST Register - ATUBISTR





## 3.10.11 Inbound ATU Base Address Register 0 - IABAR0

The Inbound ATU Base Address Register 0 (IABAR0) together with the Inbound ATU Upper Base Address Register 0 (IAUBAR0) defines the block of memory addresses where the inbound translation window 0 begins. The inbound ATU decodes and forwards the bus request to the 80331 internal bus with a translated address to map into 80331 local memory. The IABAR0 and IAUBAR0 define the base address and describes the required memory block size; see Section 3.10.21, "Determining Block Sizes for Base Address Registers" on page 233. Bits 31 through 12 of the IABAR0 is either read/write bits or read only with a value of 0 depending on the value located within the IALR0. This configuration allows the IABAR0 to be programmed per *PCI Local Bus Specification*, Revision 2.3.

The first 4 Kbytes of memory defined by the IABAR0, IAUBAR0 and the IALR0 is reserved for the Messaging Unit.

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

#### Warning:

When IALR0 is cleared prior to host configuration, the user should also clear the Prefetchable Indicator and the Type Indicator. Assuming IALR0 is not cleared:

- a. Since non prefetchable memory windows can never be placed above the 4 Gbyte address boundary, when the Prefetchable Indicator is cleared prior to host configuration, the user should also set the Type Indicator for 32 bit addressability.
- b. For compliance to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a, when the Prefetchable Indicator is set prior to host configuration, the user should also set the Type Indicator for 64 bit addressability. This is the default for IABARO.

Table 95. Inbound ATU Base Address Register 0 - IABAR0





## 3.10.12 Inbound ATU Upper Base Address Register 0 - IAUBAR0

This register contains the upper base address when decoding PCI addresses beyond 4 GBytes. Together with the Translation Base Address this register defines the actual location the translation function is to respond to when addressed from the PCI bus for addresses > 4GBytes (for DACs).

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

*Note:* When the Type indicator of IABAR0 is set to indicate 32 bit addressability, the IAUBAR0 register attributes are read-only.

Table 96. Inbound ATU Upper Base Address Register 0 - IAUBAR0





## 3.10.13 Inbound ATU Base Address Register 1 - IABAR1

The Inbound ATU Base Address Register (IABAR1) together with the Inbound ATU Upper Base Address Register 1 (IAUBAR1) defines the block of memory addresses where the inbound translation window 1 begins. This window is used merely to allocate memory on the PCI bus and, the ATU does not process any PCI bus transactions to this memory range.

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

When enabled, the ATU interrupts the Intel<sup>®</sup> XScale <sup>™</sup> core when the IABAR1 register is written from the PCI bus. Please see Section 3.10.41, "ATU Interrupt Status Register - ATUISR" on page 257 for more details.

#### Warning:

When a non-zero value is not written to IALR1 prior to host configuration, the user should not set either the Prefetchable Indicator or the Type Indicator for 64 bit addressability. This is the default for IABAR1. Assuming a non-zero value is written to IALR1, the user may set the Prefetchable Indicator or the Type Indicator:

- c. Since non prefetchable memory windows can never be placed above the 4 Gbyte address boundary, when the Prefetchable Indicator is not set prior to host configuration, the user should also leave the Type Indicator set for 32 bit addressability. This is the default for IABAR1.
- d. For compliance to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a, when the Prefetchable Indicator is set prior to host configuration, the user should also set the Type Indicator for 64 bit addressability.

Table 97. Inbound ATU Base Address Register 1 - IABAR1





## 3.10.14 Inbound ATU Upper Base Address Register 1 - IAUBAR1

This register contains the upper base address when locating this window for PCI addresses beyond 4 GBytes. Together with the IABAR1 this register defines the actual location for this memory window for addresses > 4GBytes (for DACs). This window is used merely to allocate memory on the PCI bus and, the ATU does not process any PCI bus transactions to this memory range.

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

When enabled, the ATU interrupts the Intel<sup>®</sup> XScale<sup>™</sup> core when the IAUBAR1 register is written from the PCI bus. Please see Section 3.10.41, "ATU Interrupt Status Register - ATUISR" on page 257 for more details.

**Note:** When the Type indicator of IABAR1 is set to indicate 32 bit addressability, the IAUBAR1 register attributes are read-only. This is the default for IABAR1.

Table 98. Inbound ATU Upper Base Address Register 1 - IAUBAR1





## 3.10.15 Inbound ATU Base Address Register 2 - IABAR2

The Inbound ATU Base Address Register 2 (IABAR2) together with the Inbound ATU Upper Base Address Register 2 (IAUBAR2) defines the block of memory addresses where the inbound translation window 2 begins. The inbound ATU decodes and forwards the bus request to the 80331 internal bus with a translated address to map into 80331 local memory. The IABAR2 and IAUBAR2 define the base address and describes the required memory block size; see Section 3.10.21, "Determining Block Sizes for Base Address Registers" on page 233. Bits 31 through 12 of the IABAR2 is either read/write bits or read only with a value of 0 depending on the value located within the IALR2. This configuration allows the IABAR2 to be programmed per *PCI Local Bus Specification*, Revision 2.3.

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

#### Warning:

When a non-zero value is not written to IALR2 prior to host configuration, the user should not set either the Prefetchable Indicator or the Type Indicator for 64 bit addressability. This is the default for IABAR2. Assuming a non-zero value is written to IALR2, the user may set the Prefetchable Indicator or the Type Indicator:

- 1. Since non prefetchable memory windows can never be placed above the 4 Gbyte address boundary, when the Prefetchable Indicator is not set prior to host configuration, the user should also leave the Type Indicator set for 32 bit addressability. This is the default for IABAR2.
- 2. For compliance to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a, when the Prefetchable Indicator is set prior to host configuration, the user should also set the Type Indicator for 64 bit addressability.

Table 99. Inbound ATU Base Address Register 2 - IABAR2





## 3.10.16 Inbound ATU Upper Base Address Register 2 - IAUBAR2

This register contains the upper base address when decoding PCI addresses beyond 4 GBytes. Together with the Translation Base Address this register defines the actual location the translation function is to respond to when addressed from the PCI bus for addresses > 4GBytes (for DACs).

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

*Note:* When the Type indicator of IABAR2 is set to indicate 32 bit addressability, the IAUBAR2 register attributes are read-only. This is the default for IABAR2.

Table 100. Inbound ATU Upper Base Address Register 2 - IAUBAR2





## 3.10.17 ATU Subsystem Vendor ID Register - ASVIR

ATU Subsystem Vendor ID Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3.

Table 101. ATU Subsystem Vendor ID Register - ASVIR





## 3.10.18 ATU Subsystem ID Register - ASIR

ATU Subsystem ID Register bit definitions adhere to PCI Local Bus Specification, Revision 2.3.

Table 102. ATU Subsystem ID Register - ASIR





## 3.10.19 Expansion ROM Base Address Register - ERBAR

The Expansion ROM Base Address Register defines the block of memory addresses used for containing the Expansion ROM. It permits the inclusion of multiple code images, allowing the device to be initialized. The code image supplied consists of either executable code or an interpreted code. Each code image must start on a 512 byte boundary and each must contain the PCI Expansion ROM header. Image placement in ROM space depends on the length of code images which precede it within ROM. ERBAR defines the base address and describes the required memory block size; see Section 3.10.21. Expansion ROM address space (limit size) can be a maximum of 16 MBytes. Bits 31 through 12 of the ERBAR is either read/write bits or read only with a value of 0 depending on the value located within the ERLR. This configuration allows the ERBAR to be programmed per *PCI Local Bus Specification*, Revision 2.3.

The Expansion ROM Base Address Register's programmed value must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming Expansion ROM base address registers.

Table 103. Expansion ROM Base Address Register - ERBAR





## 3.10.20 ATU Capabilities Pointer Register - ATU\_Cap\_Ptr

The Capabilities Pointer Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register provides an offset in this function's PCI Configuration Space for the location of the first item in the first Capability list. In the case of the 80331, this is the PCI Bus Power Management extended capability as defined by the *PCI Bus Power Management Interface Specification*, Revision 1.1.

Table 104. ATU Capabilities Pointer Register - ATU\_Cap\_Ptr





## 3.10.21 Determining Block Sizes for Base Address Registers

The required address size and type can be determined by writing ones to a base address register and reading from the registers. By scanning the returned value from the least-significant bit of the base address registers upwards, the programmer can determine the required address space size. The binary-weighted value of the first non-zero bit found indicates the required amount of space. Table 105 describes the relationship between the values read back and the byte sizes the base address register requires.

#### Table 105. Memory Block Size Read Response

| Response After Writing all 1s to the Base Address Register | Size<br>(in Bytes) | Response After Writing all 1s to the Base Address Register | Size<br>(in Bytes) |
|------------------------------------------------------------|--------------------|------------------------------------------------------------|--------------------|
| FFFFFF0H                                                   | 16                 | FFF00000H                                                  | 1 M                |
| FFFFFE0H                                                   | 32                 | FFE00000H                                                  | 2 M                |
| FFFFFC0H                                                   | 64                 | FFC00000H                                                  | 4 M                |
| FFFFF80H                                                   | 128                | FF800000H                                                  | 8 M                |
| FFFFF00H                                                   | 256                | FF000000H                                                  | 16 M               |
| FFFFE00H                                                   | 512                | FE000000H                                                  | 32 M               |
| FFFFC00H                                                   | 1K                 | FC000000H                                                  | 64 M               |
| FFFF800H                                                   | 2K                 | F8000000H                                                  | 128 M              |
| FFFF000H                                                   | 4K                 | F000000H                                                   | 256 M              |
| FFFE000H                                                   | 8K                 | E000000H                                                   | 512 M              |
| FFFFC000H                                                  | 16K                | C000000H                                                   | 1 G                |
| FFFF8000H                                                  | 32K                | H00000008                                                  | 2 G                |
| FFFF0000H                                                  | 64K                |                                                            | Register not       |
| FFFE0000H                                                  | 128K               | imple-<br>mented, no<br>address<br>space                   |                    |
| FFFC0000H                                                  | 256K               |                                                            |                    |
| FFF80000H                                                  | 512K               |                                                            | required.          |

As an example, assume that FFFF.FFFFH is written to the ATU Inbound Base Address Register 0 (IABAR0) and the value read back is FFF0.0008H. Bit zero is a zero, so the device requires memory address space. Bit three is one, so the memory does supports prefetching. Scanning upwards starting at bit four, bit twenty is the first one bit found. The binary-weighted value of this bit is 1,048,576, indicated that the device requires 1 Mbyte of memory space.

The ATU Base Address Registers and the Expansion ROM Base Address Register use their associated limit registers to enable which bits within the base address register are read/write and which bits are read only (0). This allows the programming of these registers in a manner similar to other PCI devices even though the limit is variable.



### Table 106. ATU Base Registers and Associated Limit Registers

| Base Address Register                               | Limit Register               | Description                                                                                                                                                                                                                       |  |
|-----------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Inbound ATU Base Address<br>Register 0              | Inbound ATU Limit Register 0 | Defines the inbound translation window 0 from the PCI bus.                                                                                                                                                                        |  |
| Inbound ATU Upper Base Address<br>Register 0        | N/A                          | Together with ATU Base Address<br>Register 0 defines the inbound<br>translation window 0 from the PCI<br>bus for DACs.                                                                                                            |  |
| Inbound ATU Base Address<br>Register 1 <sup>a</sup> | Inbound ATU Limit Register 1 | Defines inbound window 1 from the PCI bus.                                                                                                                                                                                        |  |
| Inbound ATU Upper Base Address<br>Register 1        | N/A                          | Together with ATU Base Address<br>Register 1 defines inbound window<br>1 from the PCI bus for DACs.                                                                                                                               |  |
| Inbound ATU Base Address<br>Register 2              | Inbound ATU Limit Register 2 | Defines the inbound translation window 2 from the PCI bus.                                                                                                                                                                        |  |
| Inbound ATU Upper Base Address<br>Register 2        | N/A                          | Together with ATU Base Address<br>Register 2 defines the inbound<br>translation window 2 from the PCI<br>bus for DACs.                                                                                                            |  |
| Inbound ATU Base Address<br>Register 3              | Inbound ATU Limit Register 3 | Defines the inbound translation window 3 from the PCI bus.                                                                                                                                                                        |  |
| Inbound ATU Upper Base Address<br>Register 3        | N/A                          | Together with ATU Base Address Register 3 defines the inbound translation window 3 from the PCI bus for DACs.  NOTE: This is a private BAR that resides outside of the standard PCI configuration header space (offsets 00H-3FH). |  |
| Expansion ROM Base Address<br>Register              | Expansion ROM Limit Register | Defines the window of addresses used by a bus master for reading from an Expansion ROM.                                                                                                                                           |  |

a. ATU Inbound Window 1 is **not** a translate window. The ATU does not claim any PCI accesses that fall within this range. This window is used to allocate host memory for use by Private Devices. When enabled, the ATU interrupts the Intel<sup>®</sup> XScale core when either the IABAR1 register or the IAUBAR1 register is written from the PCI bus. Please see Section 3.10.41, "ATU Interrupt Status Register - ATUISR" on page 257 for more details.

234 October, 2003 **Document Number: 273942-002** 



## 3.10.22 ATU Interrupt Line Register - ATUILR

ATU Interrupt Line Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register identifies the system interrupt controller's interrupt request lines which connect to the device's PCI interrupt request lines (as specified in the interrupt pin register).

In a PC environment, for example, the register values and corresponding connections are:

- 0 (00H) through 15 (0FH) correspond to IRQ0 through IRQ15
- 16 (10H) through 254 (FEH) are reserved
- 255 (FFH) indicates "unknown" or "no connection"

The operating system or device driver can examine each device's interrupt pin and interrupt line register to determine which system interrupt request line the device uses to issue requests for service.

Table 107. ATU Interrupt Line Register - ATUILR





## 3.10.23 ATU Interrupt Pin Register - ATUIPR

ATU Interrupt Pin Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register identifies the interrupt pin the ATU and Messaging Unit interface uses. The 80331 is, a PCI single-function device and, as such, generates only one interrupt output. The interrupt output is for the Messaging Unit on **INTA**#.

Because the ATU is integrated within 80331 and is attached to the Secondary PCI bus, its **INTA**# interrupt is wired internally to **P\_INTC**#. This interrupt wiring coincides with the ATU device number 0xE based on S\_AD30 used as the IDSEL input to the ATU device.

Table 108. ATU Interrupt Pin Register - ATUIPR





## 3.10.24 ATU Minimum Grant Register - ATUMGNT

ATU Minimum Grant Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register specifies the burst period the device requires in increments of 8 PCI clocks.

This register and the ATU Maximum Latency register are information-only registers which the configuration uses to determine how often a bus master typically requires access to the PCI bus and the duration of a typical transfer when it does acquire the bus. This information is useful in determining the values to be programmed into the bus master latency timers and in programming the algorithm to be used by the PCI bus arbiter.

Table 109. ATU Minimum Grant Register - ATUMGNT





## 3.10.25 ATU Maximum Latency Register - ATUMLAT

ATU Maximum Latency Register bit definitions adhere to *PCI Local Bus Specification*, Revision 2.3. This register specifies how often the device needs to access the PCI bus in increments of 8 PCI clocks.

This register and the Minimum Grant Register are information-only registers which the configuration uses to determine how often a bus master typically requires access to the PCI bus and the duration of a typical transfer when it does acquire the bus. This information is useful in determining the values to be programmed into the bus master latency timers and in programming the algorithm to be used by the PCI bus arbiter.

Table 110. ATU Maximum Latency Register - ATUMLAT



238 October, 2003 **Document Number: 273942-002** 



## 3.10.26 Inbound ATU Limit Register 0 - IALR0

Inbound address translation for memory window 0 occurs for data transfers occurring from the PCI bus (originated from the PCI bus) to the 80331 internal bus. The address translation block converts PCI addresses to internal bus addresses.

The inbound translation base address for inbound window 0 is specified in Section 3.10.11. When determining block size requirements — as described in Section 3.10.21 — the translation limit register provides the block size requirements for the base address register. The remaining registers used for performing address translation are discussed in Section 3.2.1.1.

The 80331 translate value register's programmed value must be naturally aligned with the base address register's programmed value. The limit register is used as a mask; thus, the lower address bits programmed into the 80331 translate value register are invalid. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

Bits 31 to 12 within the IALR0 have a direct effect on the IABAR0 register, bits 31 to 12, with a one to one correspondence. A value of 0 in a bit within the IALR0 makes the corresponding bit within the IABAR0 a read only bit which always returns 0. A value of 1 in a bit within the IALR0 makes the corresponding bit within the IABAR0 read/write from PCI. Note that a consequence of this programming scheme is that unless a valid value exists within the IALR0, all writes to the IABAR0 has no effect since a value of all zeros within the IALR0 makes the IABAR0 a read only register.

Table 111. Inbound ATU Limit Register 0 - IALRO





## 3.10.27 Inbound ATU Translate Value Register 0 - IATVR0

The Inbound ATU Translate Value Register 0 (IATVR0) contains the internal bus address used to convert PCI bus addresses. The converted address is driven on the internal bus as a result of the inbound ATU address translation.

Table 112. Inbound ATU Translate Value Register 0 - IATVR0





## 3.10.28 Expansion ROM Limit Register - ERLR

The Expansion ROM Limit Register (ERLR) defines the block size of addresses the ATU defines as Expansion ROM address space. The block size is programmed by writing a value into the ERLR.

Bits 31 to 12 within the ERLR have a direct effect on the ERBAR register, bits 31 to 12, with a one to one correspondence. A value of 0 in a bit within the ERLR makes the corresponding bit within the ERBAR a read only bit which always returns 0. A value of 1 in a bit within the ERLR makes the corresponding bit within the ERBAR read/write from PCI.

Table 113. Expansion ROM Limit Register - ERLR





## 3.10.29 Expansion ROM Translate Value Register - ERTVR

The Expansion ROM Translate Value Register contains the 80331 internal bus address which the ATU converts the PCI bus access. This address is driven on the internal bus as a result of the Expansion ROM address translation.

Table 114. Expansion ROM Translate Value Register - ERTVR





## 3.10.30 Inbound ATU Limit Register 1 - IALR1

Bits 31 to 12 within the IALR1 have a direct effect on the IABAR1 register, bits 31 to 12, with a one to one correspondence. A value of 0 in a bit within the IALR1 makes the corresponding bit within the IABAR1 a read only bit which always returns 0. A value of 1 in a bit within the IALR1 makes the corresponding bit within the IABAR1 read/write from PCI. Note that a consequence of this programming scheme is that unless a valid value exists within the IALR1, all writes to the IABAR1 has no effect since a value of all zeros within the IALR1 makes the IABAR1 a read only register.

The inbound memory window 1 is used merely to allocate memory on the PCI bus. The ATU does not process any PCI bus transactions to this memory range.

**Warning:** The ATU does not claim any PCI accesses that fall within the range defined by IABAR1, IAUBAR1, and IALR1.

Table 115. Inbound ATU Limit Register 1 - IALR1





## 3.10.31 Inbound ATU Limit Register 2 - IALR2

Inbound address translation for memory window 2 occurs for data transfers occurring from the PCI bus (originated from the PCI bus) to the 80331 internal bus. The address translation block converts PCI addresses to internal bus addresses.

The inbound translation base address for inbound window 2 is specified in Section 3.10.15. When determining block size requirements — as described in Section 3.10.21 — the translation limit register provides the block size requirements for the base address register. The remaining registers used for performing address translation are discussed in Section 3.2.1.1.

The 80331 translate value register's programmed value must be naturally aligned with the base address register's programmed value. The limit register is used as a mask; thus, the lower address bits programmed into the 80331 translate value register are invalid. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

Bits 31 to 12 within the IALR2 have a direct effect on the IABAR2 register, bits 31 to 12, with a one to one correspondence. A value of 0 in a bit within the IALR2 makes the corresponding bit within the IABAR2 a read only bit which always returns 0. A value of 1 in a bit within the IALR2 makes the corresponding bit within the IABAR2 read/write from PCI. Note that a consequence of this programming scheme is that unless a valid value exists within the IALR2, all writes to the IABAR2 has no effect since a value of all zeros within the IALR2 makes the IABAR2 a read only register.

Table 116. Inbound ATU Limit Register 2 - IALR2





## 3.10.32 Inbound ATU Translate Value Register 2 - IATVR2

The Inbound ATU Translate Value Register 2 (IATVR2) contains the internal bus address used to convert PCI bus addresses. The converted address is driven on the internal bus as a result of the inbound ATU address translation.

Table 117. Inbound ATU Translate Value Register 2 - IATVR2





## 3.10.33 Outbound I/O Window Translate Value Register - OIOWTVR

The Outbound I/O Window Translate Value Register (OIOWTVR) contains the PCI I/O address used to convert the internal bus access to a PCI address. This address is driven on the PCI bus as a result of the outbound ATU address translation. See Section 3.2.2.1, "Outbound Address Translation - Single Address Cycle (SAC) Internal Bus Transactions" on page 149 for details on outbound address translation.

The I/O window is from 80331 internal bus address  $9000\,000H$  to  $9000\,FFFFH$  with the fixed length of  $64\,K$  bytes.

Table 118. Outbound I/O Window Translate Value Register - OIOWTVR





# 3.10.34 Outbound Memory Window Translate Value Register 0 - OMWTVR0

The Outbound Memory Window Translate Value Register 0 (OMWTVR0) contains the PCI address used to convert 80331 internal bus addresses for outbound transactions. This address is driven on the PCI bus as a result of the outbound ATU address translation. See Section 3.2.2.1, "Outbound Address Translation - Single Address Cycle (SAC) Internal Bus Transactions" on page 149 for details on outbound address translation.

The memory window is from internal bus address  $8000\ 000\text{H}$  to 83FF FFFFH with the fixed length of  $64\ \text{Mbytes}$ .

Table 119. Outbound Memory Window Translate Value Register 0- OMWTVR0





# 3.10.35 Outbound Upper 32-bit Memory Window Translate Value Register 0 - OUMWTVR0

The Outbound Upper 32-bit Memory Window Translate Value Register 0 (OUMWTVR0) defines the upper 32-bits of address used during a dual address cycle. This enables the outbound ATU to directly address anywhere within the 64-bit host address space. When this register is all-zero, then a SAC is generated on the PCI bus.

The memory window is from internal bus address 8000 000H to 83FF FFFFH with the fixed length of 64 Mbytes.

Table 120. Outbound Upper 32-bit Memory Window Translate Value Register 0- OUMWTVR0



248 October, 2003 **Document Number: 273942-002** 



# 3.10.36 Outbound Memory Window Translate Value Register 1 - OMWTVR1

The Outbound Memory Window Translate Value Register 1 (OMWTVR1) contains the PCI address used to convert 80331 internal bus addresses for outbound transactions. This address is driven on the PCI bus as a result of the outbound ATU address translation. See Section 3.2.2.1, "Outbound Address Translation - Single Address Cycle (SAC) Internal Bus Transactions" on page 149 for details on outbound address translation.

The memory window is from internal bus address  $8400\ 000\text{H}$  to 87FF FFFFH with the fixed length of  $64\ \text{Mbytes}$ .

Table 121. Outbound Memory Window Translate Value Register 1- OMWTVR1





## 3.10.37 Outbound Upper 32-bit Memory Window Translate Value Register 1 - OUMWTVR1

The Outbound Upper 32-bit Memory Window Translate Value Register 1 (OUMWTVR1) defines the upper 32-bits of address used during a dual address cycle. This enables the outbound ATU to directly address anywhere within the 64-bit host address space. When this register is all-zero, then a SAC is generated on the PCI bus.

The memory window is from internal bus address 8400 000H to 87FF FFFFH with the fixed length of 64 Mbytes.

Table 122. Outbound Upper 32-bit Memory Window Translate Value Register 1- OUMWTVR1



250 October, 2003 **Document Number: 273942-002** 



# 3.10.38 Outbound Upper 32-bit Direct Window Translate Value Register - OUDWTVR

The Outbound Upper 32-bit Direct Window Translate Value Register (OUDWTVR) defines the upper 32-bits of address used during a dual address cycle for the transactions via Direct Addressing Window. This enables the outbound ATU to directly address anywhere within the 64-bit host address space. When this register is all-zero, then a SAC is generated on the PCI bus.

Table 123. Outbound Upper 32-bit Direct Window Translate Value Register - OUDWTVR





## 3.10.39 ATU Configuration Register - ATUCR

The ATU Configuration Register controls the outbound address translation for address translation unit. It also contains bits for Conventional PCI Delayed Read Command (DRC) aliasing, discard timer status, **SERR**# manual assertion, **SERR**# detection interrupt masking, and ATU BIST interrupt enabling.

Table 124. ATU Configuration Register - ATUCR





#### 3.10.40 PCI Configuration and Status Register - PCSR

The PCI Configuration and Status Register has additional bits for controlling and monitoring various features of the PCI bus interface.

Table 125. PCI Configuration and Status Register - PCSR (Sheet 1 of 4)





Table 125. PCI Configuration and Status Register - PCSR (Sheet 2 of 4)





Table 125. PCI Configuration and Status Register - PCSR (Sheet 3 of 4)





Table 125. PCI Configuration and Status Register - PCSR (Sheet 4 of 4)





#### 3.10.41 ATU Interrupt Status Register - ATUISR

The ATU Interrupt Status Register is used to notify the core processor of the source of an ATU interrupt. In addition, this register is written to clear the source of the interrupt to the interrupt unit of the 80331. All bits in this register are Read/Clear.

Bits 4:0 are a direct reflection of bits 14:11 and bit 8 (respectively) of the ATU Status Register (these bits are set at the same time by hardware but need to be cleared independently). Bit 7 is set by an error associated with the internal bus of the 80331. Bit 8 is for software BIST. The conditions that result in an ATU interrupt are cleared by writing a 1 to the appropriate bits in this register.

**Note:** Bits 4:0, and bits 15 and 13:7 can result in an interrupt being driven to the Intel<sup>®</sup> XScale<sup>™</sup> core.

Table 126. ATU Interrupt Status Register - ATUISR (Sheet 1 of 2)





Table 126. ATU Interrupt Status Register - ATUISR (Sheet 2 of 2)





#### 3.10.42 ATU Interrupt Mask Register - ATUIMR

The ATU Interrupt Mask Register contains the control bit to enable and disable interrupts generated by the ATU.

Table 127. ATU Interrupt Mask Register - ATUIMR (Sheet 1 of 2)





Table 127. ATU Interrupt Mask Register - ATUIMR (Sheet 2 of 2)





#### 3.10.43 Inbound ATU Base Address Register 3 - IABAR3

The Inbound ATU Base Address Register 3 (IABAR3) together with the Inbound ATU Upper Base Address Register 3 (IAUBAR3) defines the block of memory addresses where the inbound translation window 3 begins. The inbound ATU decodes and forwards the bus request to the 80331 internal bus with a translated address to map into 80331 local memory. The IABAR3 and IAUBAR3 define the base address and describes the required memory block size; see Section 3.10.21, "Determining Block Sizes for Base Address Registers" on page 233. Bits 31 through 12 of the IABAR3 is either read/write bits or read only with a value of 0 depending on the value located within the IALR3. This configuration allows the IABAR3 to be programmed per *PCI Local Bus Specification*, Revision 2.3.

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

*Note:* Since IABAR3 does not appear in the standard PCI configuration header space (offsets 00H - 3CH), IABAR3 is not configured by the host during normal system initialization.

Warning:

When a non-zero value is not written to IALR3, the user should not set either the Prefetchable Indicator or the Type Indicator for 64 bit addressability. This is the default for IABAR3. Assuming a non-zero value is written to IALR3, the user may set the Prefetchable Indicator or the Type Indicator:

- 1. Since non prefetchable memory windows can never be placed above the 4 Gbyte address boundary, when the Prefetchable Indicator is not set, the user should also leave the Type Indicator set for 32 bit addressability. This is the default for IABAR3.
- 2. For compliance to the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a, when the Prefetchable Indicator is set, the user should also set the Type Indicator for 64 bit addressability.

Table 128. Inbound ATU Base Address Register 3 - IABAR3





#### 3.10.44 Inbound ATU Upper Base Address Register 3 - IAUBAR3

This register contains the upper base address when decoding PCI addresses beyond 4 GBytes. Together with the Translation Base Address this register defines the actual location the translation function is to respond to when addressed from the PCI bus for addresses > 4GBytes (for DACs).

The programmed value within the base address register must comply with the PCI programming requirements for address alignment. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

*Note:* When the Type indicator of IABAR3 is set to indicate 32 bit addressability, the IAUBAR3 register attributes are read-only. This is the default for IABAR3.

Table 129. Inbound ATU Upper Base Address Register 3 - IAUBAR3





#### 3.10.45 Inbound ATU Limit Register 3 - IALR3

Inbound address translation for memory window 3 occurs for data transfers occurring from the PCI bus (originated from the PCI bus) to the 80331 internal bus. The address translation block converts PCI addresses to internal bus addresses.

The inbound translation base address for inbound window 3 is specified in Section 3.10.15. When determining block size requirements — as described in Section 3.10.21 — the translation limit register provides the block size requirements for the base address register. The remaining registers used for performing address translation are discussed in Section 3.2.1.1.

The 80331 translate value register's programmed value must be naturally aligned with the base address register's programmed value. The limit register is used as a mask; thus, the lower address bits programmed into the 80331 translate value register are invalid. Refer to the *PCI Local Bus Specification*, Revision 2.3 for additional information on programming base address registers.

Bits 31 to 12 within the IALR3 have a direct effect on the IABAR3 register, bits 31 to 12, with a one to one correspondence. A value of 0 in a bit within the IALR3 makes the corresponding bit within the IABAR3 a read only bit which always returns 0. A value of 1 in a bit within the IALR3 makes the corresponding bit within the IABAR3 read/write from PCI. Note that a consequence of this programming scheme is that unless a valid value exists within the IALR3, all writes to the IABAR3 has no effect since a value of all zeros within the IALR3 makes the IABAR3 a read only register.

Table 130. Inbound ATU Limit Register 3 - IALR3





#### 3.10.46 Inbound ATU Translate Value Register 3 - IATVR3

The Inbound ATU Translate Value Register 3 (IATVR3) contains the internal bus address used to convert PCI bus addresses. The converted address is driven on the internal bus as a result of the inbound ATU address translation.

Table 131. Inbound ATU Translate Value Register 3 - IATVR3





#### 3.10.47 Outbound Configuration Cycle Address Register - OCCAR

The Outbound Configuration Cycle Address Register is used to hold the 32-bit PCI configuration cycle address. The Intel<sup>®</sup> XScale<sup>™</sup> core writes the PCI configuration cycles address which then enables the outbound configuration read or write. The Intel<sup>®</sup> XScale<sup>™</sup> core then performs a read or write to the Outbound Configuration Cycle Data Register to initiate the configuration cycle on the PCI bus.

Note: Bits 15:11 of the configuration cycle address for Type 0 configuration cycles are defined differently for Conventional versus PCI-X modes. When 80331 software programs the OCCAR to initiate a Type 0 configuration cycle, the OCCAR should always be loaded based on the PCI-X definition for the Type 0 configuration cycle address. When operating in Conventional mode, the 80331 clears bits 15:11 of the OCCAR prior to initiating an outbound Type 0 configuration cycle. See the PCI-X Addendum to the PCI Local Bus Specification, Revision 1.0a for details on the two formats.

Table 132. Outbound Configuration Cycle Address Register - OCCAR





#### 3.10.48 Outbound Configuration Cycle Data Register - OCCDR

The Outbound Configuration Cycle Data Register is used to initiate a configuration read or write on the PCI bus. The register is logical rather than physical meaning that it is an address not a register. The Intel<sup>®</sup> XScale<sup>™</sup> core reads or writes the data registers memory-mapped address to initiate the configuration cycle on the PCI bus with the address found in the OCCAR. For a configuration write, the data is latched from the internal bus and forwarded directly to the OWQ. For a read, the data is returned directly from the ORQ to the Intel<sup>®</sup> XScale<sup>™</sup> core and is never actually entered into the data register (which does not physically exist).

The OCCDR is only visible from 80331 internal bus address space and appears as a reserved value within the ATU configuration space.

Table 133. Outbound Configuration Cycle Data Register - OCCDR





#### 3.10.49 VPD Capability Identifier Register - VPD\_CAPID

The Capability Identifier Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register in the PCI Extended Capability header identifies the type of Extended Capability contained in that header. In the case of the 80331, this is the VPD extended capability with an ID of 03H as defined by the *PCI Local Bus Specification*, Revision 2.3.

Table 134. VPD Capability Identifier Register - VPD\_CAPID





#### 3.10.50 VPD Next Item Pointer Register - VPD\_NXTP

The Next Item Pointer Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register describes the location of the next item in the function's capability list. For the 80331, this the final capability list, and hence, this register is set to 00H.

Table 135. VPD Next Item Pointer Register - VPD\_NXTP



268 October, 2003 **Document Number: 273942-002** 



#### 3.10.51 VPD Address Register - VPD\_AR

The VPD Address register (VPDAR) contains the DWORD-aligned byte address of the VPD to be accessed. The register is read/write and the initial value at power-up is indeterminate.

A PCI Configuration Write to the VPDAR interrupts the  $Intel^{\textcircled{8}}$  XScale  $^{\texttt{TM}}$  core. Software can use the Flag setting to determine whether the configuration write was intended to initiate a read or write of the VPD through the VPD Data Register.

Table 136. VPD Address Register - VPD\_AR





#### 3.10.52 VPD Data Register - VPD\_DR

This register is used to transfer data between the 80331 and the VPD storage component.

Table 137. VPD Data Register - VPD\_DR





## 3.10.53 Power Management Capability Identifier Register - PM CAPID

The Capability Identifier Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register in the PCI Extended Capability header identifies the type of Extended Capability contained in that header. In the case of the 80331, this is the PCI Bus Power Management extended capability with an ID of 01H as defined by the *PCI Bus Power Management Interface Specification*, Revision 1.1.

Table 138. Power Management Capability Identifier Register - PM\_CAPID





#### 3.10.54 Power Management Next Item Pointer Register - PM\_NXTP

The Next Item Pointer Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register describes the location of the next item in the function's capability list. For the 80331, the next capability (MSI capability list) is located at off-set D0H.

Table 139. Power Management Next Item Pointer Register - PM\_NXTP





#### 3.10.55 Power Management Capabilities Register - PM\_CAP

Power Management Capabilities bits adhere to the definitions in the *PCI Bus Power Management Interface Specification*, Revision 1.1. This register is a 16-bit read-only register which provides information on the capabilities of the ATU function related to power management.

Table 140. Power Management Capabilities Register - PM\_CAP





#### 3.10.56 Power Management Control/Status Register - PM\_CSR

Power Management Control/Status bits adhere to the definitions in the *PCI Bus Power Management Interface Specification*, Revision 1.1. This 16-bit register is the control and status interface for the power management extended capability.

Table 141. Power Management Control/Status Register - PM\_CSR





#### 3.10.57 MSI Capability Registers

The MSI capability registers are defined in the Messaging Unit. See "MSI Capability Identifier Register - MSI\_CAPID" on page 323, "MSI Next Item Pointer Register - MSI\_NXTP" on page 324, "MSI Message Control Register - MSI\_MCR" on page 325, "MSI Message Address Register - MSI\_MAR" on page 326, "MSI Message Upper Address Register - MSI\_MUAR" on page 327 and "MSI Message Data Register- MSI\_MDR" on page 328.



#### 3.10.58 PCI-X Capability Identifier Register - PX\_CAPID

The Capability Identifier Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register in the PCI Extended Capability header identifies the type of Extended Capability contained in that header. In the case of the 80331, this is the PCI-X extended capability with an ID of 07H as defined by the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a.

Table 142. PCI-X\_Capability Identifier Register - PX\_CAPID





#### 3.10.59 PCI-X Next Item Pointer Register - PX\_NXTP

The Next Item Pointer Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.3. This register describes the location of the next item in the function's capability list.

By default, the PCI-X capability is the last capabilities list for the 80331, thus this register defaults to 00H.

However, this register may be written to B8H prior to host configuration to include the VPD capability located at off-set B8H.

#### Warning:

Writing this register to any value other than 00H (default) or B8H is not supported and may produce unpredictable system behavior.

In order to guarantee that this register is written prior to host configuration, the 80331 must be initialized at **P\_RST**# assertion to Retry Type 0 configuration cycles (bit 2 of PCSR). Typically, the Intel<sup>®</sup> XScale<sup>TM</sup> core would be enabled to boot immediately following **P\_RST**# assertion in this case (bit 1 of PCSR), as well. Please see Table 125, "PCI Configuration and Status Register-PCSR" on page 253 for more details on the 80331 initialization modes.

Table 143. PCI-X Next Item Pointer Register - PX\_NXTP





#### 3.10.60 PCI-X Command Register - PX\_CMD

This register controls various modes and features of ATU and Message Unit when operating in the PCI-X mode.

Table 144. PCI-X Command Register - PX\_CMD





#### 3.10.61 PCI-X Status Register - PX\_SR

This register identifies the capabilities and current operating mode of ATU, DMAs and Message Unit when operating in the PCI-X mode.

Table 145. PCI-X Status Register - PX\_SR (Sheet 1 of 2)





Table 145. PCI-X Status Register - PX\_SR (Sheet 2 of 2)





#### 3.10.62 PCI Interrupt Routing Select Register - PIRSR

The PCI Interrupt Routing Select Register (PIRSR) determines the routing of the external input pins. This register is addressed in the ATU register space, but is defined in Section 15.7.17, "PCI Interrupt Routing Select Register - PIRSR" on page 717. Refer to that page for functional details and programming information.

**Document Number: 273942-002** October, 2003 281



### 3.10.63 Secondary PCIDrive Strength Control Register - SPDSCR

When necessary, the Secondary drive strength control register is used to manually control the slew rate and drive strength of the PCI bus interface.

*Note:* By default, the user is **not** required to program this register.

Table 146. Secondary PCIDrive Strength Control Register - SPDSCR





#### 3.10.64 Primary PCIDrive Strength Control Register - PPDSCR

When necessary, the Primary drive strength control register is used to manually control the slew rate and drive strength of the PCI bus interface.

*Note:* By default, the user is **not** required to program this register.

Table 147. Primary PCIDrive Strength Control Register - PPDSCR





## This Page Intentionally Left Blank



# Messaging Unit

4

This chapter describes the Messaging Unit (MU) of the Intel® 80331 I/O processor (80331). The MU is closely related to the Address Translation Unit (ATU) described in Chapter 3, "Address Translation Unit".

#### 4.1 Overview

The Messaging Unit (MU) provides a mechanism for data to be transferred between the PCI bus and the Intel<sup>®</sup> XScale core and notifying the respective system of the arrival of new data through an interrupt. The MU can be used to send and receive messages.

The MU has four distinct messaging mechanisms. Each allows a host processor or external PCI agent and the 80331 to communicate through message passing and interrupt generation. The four mechanisms are:

- Message Registers allow the 80331 and external PCI agents to communicate by passing messages in one of four 32-bit Message Registers. In this context, a message is any 32-bit data value. Message registers combine aspects of mailbox registers and doorbell registers. Writes to the message registers may optionally cause interrupts.
- **Doorbell Registers** allow the 80331 to assert the PCI interrupt signal and allow external PCI agents to generate an interrupt to the Intel<sup>®</sup> XScale To core.
- Circular Queues support a message passing scheme that uses four circular queues.
- **Index Registers** support a message passing scheme that uses a portion of the 80331 local memory to implement a large set of message registers.

Each of the above are available to the system designer at the same time. No special mode selection is needed.



#### 4.2 Theory of Operation

The MU has four independent messaging mechanisms.

There are four Message Registers that are similar to a combination of mailbox and doorbell registers. Each holds a 32-bit value and generates an interrupt when written.

The two Doorbell Registers support software interrupts. When a bit is set in a Doorbell Register, an interrupt is generated.

The Circular Queues support a message passing scheme that uses 4 circular queues. The 4 circular queues are implemented in 80331 local memory. Two queues are used for inbound messages and two are used for outbound messages. Interrupts may be generated when the queue is written.

The Index Registers use a portion of the 80331 local memory to implement a large set of message registers. When one of the Index Registers is written, an interrupt is generated and the address of the register written is captured.

Interrupt status for all interrupts is recorded in the Inbound Interrupt Status Register and the Outbound Interrupt Status Register. Each interrupt generated by the Messaging Unit can be masked.

Multi-DWORD PCI burst accesses are not supported by the Messaging Unit, with the exception of Multi-DWORD reads to the index registers. In Conventional mode, the MU terminates Multi-DWORD PCI transactions (other than index register reads) with a disconnect at the next Qword boundary, with the exception of queue ports. In PCI-X mode, the MU terminates a Multi-DWORD PCI read transaction with a Split Response and the data is returned through split completion transaction(s); however, when the burst request crosses into or through the range of offsets 40h to 4Ch (e.g., this includes the queue ports) the transaction is signaled target-abort immediately on the PCI bus. In PCI-X mode, Multi-DWORD PCI writes is signaled a Single-Data-Phase Disconnect which means that no data beyond the first Qword (Dword when the MU does not assert **P\_ACK64#**) is written.

All registers needed to configure and control the Messaging Unit are memory-mapped registers.

The MU uses the first 4 Kbytes of the inbound translation window in the Address Translation Unit (ATU). This PCI address window is used for PCI transactions that access the 80331 local memory. The PCI address of the inbound translation window is contained in the Inbound ATU Base Address Register. See Chapter 3, "Address Translation Unit" for more details on inbound ATU addressing and the ATU.

From the PCI perspective, the Messaging Unit is part of the Address Translation Unit. The Messaging Unit uses the PCI configuration registers of the ATU for control and status information. The Messaging Unit must observe all PCI control bits in the ATU Command Register and ATU Configuration Register. The Messaging Unit reports all PCI errors in the ATU Status Register.

Parts of the Messaging Unit can be accessed as a 64-bit PCI device. The register interface, message registers, doorbell registers, and index registers returns a **P\_ACK64#** in response to a **P\_REQ64#** on the PCI interface. Up to 1 Qword of data can be read or written per transaction (except Index Register reads, see Section 4.6, "Index Registers" on page 300). The Inbound and Outbound Queue Ports are always 32-bit addresses and the MU does not assert **P\_ACK64#** to offsets 40H and 44H.



Figure 20. PCI Memory Map



*Note:* See Table 154, "Message Unit Register".



Figure 21. Internal Bus Memory Map

| FFFF E300H | reserved                            |  |
|------------|-------------------------------------|--|
| FFFF E310H | Inbound Message Register 0          |  |
| FFFF E314H | Inbound Message Register 1          |  |
| FFFF E318H | Outbound Message Register 0         |  |
| FFFF E31CH | Outbound Message Register 1         |  |
| FFFF E320H | Inbound Doorbell Register           |  |
| FFFF E324H | Inbound Interrupt Status Register   |  |
| FFFF E328H | Inbound Interrupt Mask Register     |  |
| FFFF E32CH | Outbound Doorbell Register          |  |
| FFFF E330H | Outbound Interrupt Status Register  |  |
| FFFF E334H | Outbound Interrupt Mask Register    |  |
| FFFF E338H | reserved                            |  |
| FFFF E33CH | reserved                            |  |
| FFFF E340H | reserved                            |  |
| FFFF E344H | reserved                            |  |
| FFFF E348H | reserved                            |  |
| FFFF E34CH | reserved                            |  |
| FFFF E350H | MU Configuration Register           |  |
| FFFF E354H | Queue Base Address Register         |  |
| FFFF E358H | reserved                            |  |
| FFFF E35CH | reserved                            |  |
| FFFF E360H | Inbound Free Head Pointer Register  |  |
| FFFF E364H | Inbound Free Tail Pointer Register  |  |
| FFFF E368H | Inbound Post Head pointer Register  |  |
| FFFF E36CH | Inbound Post Tail Pointer Register  |  |
| FFFF E370H | Outbound Free Head Pointer Register |  |
| FFFF E374H | Outbound Free Tail Pointer Register |  |
| FFFF E378H | Outbound Post Head pointer Register |  |
| FFFF E37CH | Outbound Post Tail Pointer Register |  |
| FFFF E380H | Index Address Register              |  |



Table 148 provides a summary of the four messaging mechanisms used in the Messaging Unit.

#### Table 148. MU Summary

| Mechanism          | Quantity                        | Assert PCI Interrupt<br>Signals | Generate I/O Processor<br>Interrupt |
|--------------------|---------------------------------|---------------------------------|-------------------------------------|
| Message Registers  | 2 Inbound<br>2 Outbound         | Optional                        | Optional                            |
| Doorbell Registers | 1 Inbound<br>1 Outbound         | Optional                        | Optional                            |
| Circular Queues    | 4 Circular Queues               | Under certain conditions        | Under certain conditions            |
| Index Registers    | 1004 32-bit Memory<br>Locations | No                              | Optional                            |

# 4.2.1 Transaction Ordering

From a PCI standpoint, the Messaging Unit is a piece of the ATU and therefore must maintain ordering requirements against ATU transactions. Transaction ordering is achieved for the Index Registers, the Doorbell Register, and the Message Registers since these transactions are routed through the standard set of ATU read/write queues.

The Circular Queues (Inbound/Outbound Queue Port) are separate queue structures and therefore require ordering. The Inbound Post Queue (contains PCI writes) must be ordered against the inbound write queue of the ATU to allow the data that is represented by the Inbound Post interrupt to be written to local memory before the interrupt is delivered. See Table 149 for a summary of Messaging Unit transaction ordering.

#### Table 149. Circular Queue Ordering Requirements

| Messaging Unit Feature |               | Transaction Ordering Mechanism                                           |  |
|------------------------|---------------|--------------------------------------------------------------------------|--|
| Message Registers      |               | Through ATU Queues                                                       |  |
| Doorbell Registers     |               | Through ATU Queues                                                       |  |
| Index Registers        |               | Through ATU Queues                                                       |  |
| Circular Queues        | Inbound Post  | Ordered Against ATU Inbound Write Queue (PN<br>Can Not Pass Another PMW) |  |
|                        | Inbound Free  | No Specific Hardware Ordering                                            |  |
|                        | Outbound Post | No Specific Hardware Ordering                                            |  |
|                        | Outbound Free | No Specific Hardware Ordering                                            |  |



# 4.3 Message Registers

Messages can be sent and received by the 80331 through the use of the Message Registers. When written, the message registers may cause an interrupt to be generated to either the Intel<sup>®</sup> XScale core or the host processor. Inbound messages are sent by the host processor and received by the 80331. Outbound messages are sent by the 80331 and received by the host processor.

The interrupt status for outbound messages is recorded in the Outbound Interrupt Status Register. Interrupt status for inbound messages is recorded in the Inbound Interrupt Status Register.

### 4.3.1 Outbound Messages

When an outbound message register is written by the Intel<sup>®</sup> XScale<sup>™</sup> core, an interrupt may be generated on the **P\_INTC**# interrupt pin (**P\_INTA**# with **BRG\_EN** and **ARB\_EN** straps low) interrupt pin or a message signaled interrupt is generated when MSI is enabled.

The PCI interrupt is recorded in the Outbound Interrupt Status Register. The interrupt causes the Outbound Message Interrupt bit to be set in the Outbound Interrupt Status Register. This is a Read/Clear bit that is set by the MU hardware and cleared by software.

The interrupt is cleared when an external PCI agent writes a value of 1 to the Outbound Message Interrupt bit in the Outbound Interrupt Status Register to clear the bit.

The interrupt may be masked by the mask bits in the Outbound Interrupt Mask Register.

# 4.3.2 Inbound Messages

When an inbound message register is written by an external PCI agent, an interrupt may be generated to the  $Intel^{\otimes}$  XScale core. The interrupt may be masked by the mask bits in the Inbound Interrupt Mask Register.

The Intel<sup>®</sup> XScale<sup>™</sup> core interrupt is recorded in the Inbound Interrupt Status Register. The interrupt causes the Inbound Message Interrupt bit to be set in the Inbound Interrupt Status Register. This is a Read/Clear bit that is set by the MU hardware and cleared by software.

The interrupt is cleared when the Intel<sup>®</sup> XScale<sup>™</sup> core writes a value of 1 to the Inbound Message Interrupt bit in the Inbound Interrupt Status Register.



# 4.4 Doorbell Registers

There are two Doorbell Registers: the Inbound Doorbell Register and the Outbound Doorbell Register. The Inbound Doorbell Register allows external PCI agents to generate interrupts to the Intel<sup>®</sup> XScale Core. The Outbound Doorbell Register allows the Intel<sup>®</sup> XScale Core to generate a PCI interrupt. Both Doorbell Registers may generate interrupts whenever a bit in the register is set.

#### 4.4.1 Outbound Doorbells

When the Outbound Doorbell Register is written by the Intel<sup>®</sup> XScale<sup>TM</sup> core, an interrupt may be generated on the **P\_INTA**# interrupt pin (**P\_INTA**# with **BRG\_EN** and **ARB\_EN** straps low) or a message signaled interrupt is generated when MSI is enabled. An interrupt is generated when any of the bits in the doorbell register is written to a value of 1. Writing a value of 0 to any bit does not change the value of that bit and does not cause an interrupt to be generated. Once a bit is set in the Outbound Doorbell Register, it cannot be cleared by the Intel<sup>®</sup> XScale<sup>TM</sup> core.

The interrupt is recorded in the Outbound Interrupt Status Register.

The interrupt may be masked by the mask bits in the Outbound Interrupt Mask Register. When the mask bit is set for a particular bit, no interrupt is generated for that bit. The Outbound Interrupt Mask Register affects only the generation of the interrupt and not the values written to the Outbound Doorbell Register.

The interrupt is cleared when an external PCI agent writes a value of 1 to the bits in the Outbound Doorbell Register that are set. Writing a value of 0 to any bit does not change the value of that bit and does not clear the interrupt.

In summary, the Intel<sup>®</sup> XScale<sup> $^{TM}$ </sup> core generates an interrupt and external PCI agents clear the interrupt by setting bits in the Outbound Doorbell Register.

#### 4.4.2 Inbound Doorbells

When the Inbound Doorbell Register is written by an external PCI agent, an interrupt may be generated to the Intel<sup>®</sup> XScale<sup>™</sup> core. An interrupt is generated when any of the bits in the doorbell register is written to a value of 1. Writing a value of 0 to any bit does not change the value of that bit and does not cause an interrupt to be generated. Once a bit is set in the Inbound Doorbell Register, it cannot be cleared by any external PCI agent. The interrupt is recorded in the Inbound Interrupt Status Register.

The interrupt may be masked by the Inbound Doorbell Interrupt mask bit in the Inbound Interrupt Mask Register. When the mask bit is set for a particular bit, no interrupt is generated for that bit. The Inbound Interrupt Mask Register affects only the generation of the normal messaging unit interrupt and not the values written to the Inbound Doorbell Register. One bit in the Inbound Doorbell Register is reserved for an Error Doorbell interrupt.

The interrupt is cleared when the Intel<sup>®</sup>  $XScale^{TM}$  core writes a value of 1 to the bits in the Inbound Doorbell Register that are set. Writing a value of 0 to any bit does not change the value of that bit and does not clear the interrupt.



#### 4.5 Circular Queues

The MU implements four circular queues. There are 2 inbound queues and 2 outbound queues. In this case, inbound and outbound refer to the direction of the flow of posted messages.

Inbound messages are either:

- posted messages by other processors for the  $Intel^{\mathbb{R}}$  XScale  $^{\mathsf{TM}}$  core to process or
- free (or empty) messages that can be reused by other processors.

Outbound messages are either:

- posted messages by the Intel<sup>®</sup> XScale<sup>TM</sup> core for other processors to process or
- free (or empty) messages that can be reused by the Intel<sup>®</sup> XScale<sup>TM</sup> core.

Therefore, free inbound messages flow away from the and free outbound messages flow toward the 80331.

The four Circular Queues are used to pass messages in the following manner. The two inbound queues are used to handle inbound messages and the two outbound queues are used to handle outbound messages. One of the inbound queues is designated the Free queue and it contains inbound free messages. The other inbound queue is designated the Post queue and it contains inbound posted messages. Similarly, one of the outbound queues is designated the Free queue and the other outbound queue is designated the Post queue. Table 150 contains a summary of the queues.

#### Table 150. Circular Queue Summary

| Queue Name             | Purpose                                                                                  | Action on PCI<br>Interface |
|------------------------|------------------------------------------------------------------------------------------|----------------------------|
| Inbound Post<br>Queue  | Queue for inbound messages from other processors waiting to be processed by the 80331    | Written                    |
| Inbound Free<br>Queue  | Queue for empty inbound messages from the 80331 available for use by other processors    | Read                       |
| Outbound Post<br>Queue | Queue for outbound messages from the 80331 that are being posted to the other processors | Read                       |
| Outbound Free<br>Queue | Queue for empty outbound messages from other processors available for use by the 80331   | Written                    |

The two outbound queues allow the Intel<sup>®</sup> XScale<sup>TM</sup> core to post outbound messages in one queue and to receive free messages returning from the host processor. The Intel<sup>®</sup> XScale<sup>TM</sup> core posts outbound messages, the host processor receives the posted message and when it is finished with the message, places it back on the outbound free queue for reuse by the Intel<sup>®</sup> XScale<sup>TM</sup> core.

The two inbound queues allow the host processor to post inbound messages for the 80331 in one queue and to receive free messages returning from the 80331. The host processor posts inbound messages, the Intel<sup>®</sup> XScale<sup>™</sup> core receives the posted message and when it is finished with the message, places it back on the inbound free queue for reuse by the host processor.

Figure 22 provides an overview of the Circular Queue operation.

The circular queues are accessed by external PCI agents through two port locations in the PCI address space: Inbound Queue Port and Outbound Queue Port. The Inbound Queue Port is used by external PCI agents to read the Inbound Free Queue and write the Inbound Post Queue. The



Outbound Queue Port is used by external PCI agents to read the Outbound Post Queue and write the Outbound Free Queue. Note that a PCI transaction to the inbound or outbound queue ports with null byte enables ( $P_C/BE[3:0]\# = 1111_2$ ) does not cause the MU hardware to increment the queue pointers. This is treated as when the PCI transaction did not occur. The Inbound and Outbound Queue Ports never respond with P ACK64# on the PCI interface.

Figure 22. Overview of Circular Queue Operation



The data storage for the circular queues must be provided by the 80331 local memory. The base address of the circular queues is contained in the Queue Base Address Register (Section 4.9.10, "Queue Base Address Register - QBAR" on page 313). Each entry in the queue is a 32-bit data value. Each read from or write to the queue may access only one queue entry. Multi-DWORD accesses to the circular queues are not allowed. Sub-DWORD accesses are promoted to DWORD accesses.

Each circular queue has a head pointer and a tail pointer. The pointers are offsets from the Queue Base Address. Writes to a queue occur at the head of the queue and reads occur from the tail. The head and tail pointers are incremented by either the Intel<sup>®</sup> XScale<sup>™</sup> core or the Messaging Unit hardware. Which unit maintains the pointer is determined by the writer of the queue. More details about the pointers are given in the queue descriptions below. The pointers are incremented after the queue access. Both pointers wrap around to the first address of the circular queue when they reach the circular queue size.

# Intel® 80331 I/O Processor Developer's Manual Messaging Unit



The Messaging Unit generates an interrupt to the Intel<sup>®</sup> XScale TM core or generate a PCI interrupt under certain conditions. In general, when a Post queue is written, an interrupt is generated to notify the receiver that a message was posted.

The size of each circular queue can range from 4K entries (16 Kbytes) to 64K entries (256 Kbytes). All four queues must be the same size and may be contiguous. Therefore, the total amount of local memory needed by the circular queues ranges from 64 Kbytes to 1 Mbytes. The Queue size is determined by the Queue Size field in the MU Configuration Register.

There is one base address for all four queues. It is stored in the Queue Base Address Register (QBAR). The starting addresses of each queue is based on the Queue Base Address and the Queue Size field. Table 151 shows an example of how the circular queues should be set up based on the Intelligent I/O ( $I_2O$ ) Architecture Specification. Other ordering of the circular queues is possible.

#### Table 151. Queue Starting Addresses

| Queue               | Starting Address      |
|---------------------|-----------------------|
| Inbound Free Queue  | QBAR                  |
| Inbound Post Queue  | QBAR + Queue Size     |
| Outbound Post Queue | QBAR + 2 * Queue Size |
| Outbound Free Queue | QBAR + 3 * Queue Size |



Figure 23 provides a more detailed diagram of the usage of the Circular Queues.

Figure 23. Circular Queue Operation





#### 4.5.1 Inbound Free Queue

The Inbound Free Queue holds free inbound messages placed there by the Intel<sup>®</sup> XScale<sup>TM</sup> core for other processors to use. This queue is read from the queue tail by external PCI agents. It is written to the queue head by the Intel<sup>®</sup> XScale<sup>TM</sup> core. The tail pointer is maintained by the MU hardware. The head pointer is maintained by the Intel<sup>®</sup> XScale<sup>TM</sup> core.

For a PCI read transaction that accesses the Inbound Queue Port, the MU attempts to read the data at the local memory address in the Inbound Free Tail Pointer. When the queue is not empty (head and tail pointers are not equal) or full (head and tail pointers are equal but the head pointer was last written by software), the data is returned. When the queue is empty (head and tail pointers are equal and the head pointer was last updated by hardware), the value of -1 (FFFF.FFFFH) is returned. When the queue was not empty and the MU succeeded in returning the data at the tail, the MU hardware must increment the value in the Inbound Free Tail Pointer Register.

To reduce latency for the PCI read access, the MU implements a prefetch mechanism to anticipate accesses to the Inbound Free Queue. The MU hardware prefetches the data at the tail of the Inbound Free Queue and load it into an internal prefetch register. When the PCI read access occurs, the data is read directly from the prefetch register.

The prefetch mechanism loads a value of -1 (FFFF.FFFFH) into the prefetch register when the head and tail pointers are equal and the queue is empty. In order to update the prefetch register when messages are added to the queue and it becomes non-empty, the prefetch mechanism automatically starts a prefetch when the prefetch register contains FFFF.FFFH and the Inbound Free Head Pointer Register is written. The Intel<sup>®</sup> XScale<sup>TM</sup> core needs to update the Inbound Free Head Pointer Register when it adds messages to the queue.

A prefetch must appear atomic from the perspective of the external PCI agent. When a prefetch is started, any PCI transaction that attempts to access the Inbound Free Queue is signalled a Retry until the prefetch is completed.

The Intel<sup>®</sup> XScale<sup>™</sup> core may place messages in the Inbound Free Queue by writing the data to the local memory location pointed to by the Inbound Free Head Pointer Register. The processor must then increment the Inbound Free Head Pointer Register.



#### 4.5.2 Inbound Post Queue

The Inbound Post Queue holds posted messages placed there by other processors for the Intel<sup>®</sup> XScale<sup>TM</sup> core to process. This queue is read from the queue tail by the Intel<sup>®</sup> XScale<sup>TM</sup> core. It is written to the queue head by external PCI agents. The tail pointer is maintained by the Intel<sup>®</sup> XScale<sup>TM</sup> core. The head pointer is maintained by the MU hardware.

For a PCI write transaction that accesses the Inbound Queue Port, the MU writes the data to the local memory location address in the Inbound Post Head Pointer Register.

When the data written to the Inbound Queue Port is written to local memory, the MU hardware increments the Inbound Post Head Pointer Register.

An Intel<sup>®</sup> XScale<sup>™</sup> core interrupt may be generated when the Inbound Post Queue is written. The Inbound Post Queue Interrupt bit in the Inbound Interrupt Status Register indicates the interrupt status. The interrupt is cleared when the Inbound Post Queue Interrupt bit is cleared. The interrupt can be masked by the Inbound Interrupt Mask Register. Software must be aware of the state of the Inbound Post Queue Interrupt Mask bit to guarantee that the full condition is recognized by the core processor. In addition, to guarantee that the queue does not get overwritten, software must process messages from the tail of the queue before incrementing the tail pointer and clearing this interrupt. Once cleared, an interrupt is NOT generated when the head and tail pointers remain unequal (i.e. queue status is Not Empty). Only a new message posting the in the inbound queue generates a new interrupt. Therefore, when software leaves any unprocessed messages in the post queue when the interrupt is cleared, software must retain the information that the Inbound Post queue status.

From the time that the PCI write transaction is received until the data is written in local memory and the Inbound Post Head Pointer Register is incremented, any PCI transaction that attempts to access the Inbound Post Queue Port is signalled a Retry.

The Intel<sup>®</sup> XScale<sup>™</sup> core may read messages from the Inbound Post Queue by reading the data from the local memory location pointed to by the Inbound Post Tail Pointer Register. The Intel<sup>®</sup> XScale<sup>™</sup> core must then increment the Inbound Post Tail Pointer Register. When the Inbound Post Queue is full (head and tail pointers are equal and the head pointer was last updated by hardware), the hardware retries any PCI writes until a slot in the queue becomes available. A slot in the post queue becomes available by the Intel<sup>®</sup> XScale<sup>™</sup> core incrementing the tail pointer.



#### 4.5.3 Outbound Post Queue

The Outbound Post Queue holds outbound posted messages placed there by the Intel<sup>®</sup> XScale<sup>™</sup> core for other processors to process. This queue is read from the queue tail by external PCI agents. It is written to the queue head by the Intel<sup>®</sup> XScale<sup>™</sup> core. The tail pointer is maintained by the MU hardware. The head pointer is maintained by the Intel<sup>®</sup> XScale<sup>™</sup> core.

For a PCI read transaction that accesses the Outbound Queue Port, the MU attempts to read the data at the local memory address in the Outbound Post Tail Pointer Register. When the queue is not empty (head and tail pointers are not equal) or full (head and tail pointers are equal but the head pointer was last written by software), the data is returned. When the queue is empty (head and tail pointers are equal and the head pointer was last updated by hardware), the value of -1 (FFFF.FFFFH) is returned. When the queue was not empty and the MU succeeded in returning the data at the tail, the MU hardware must increment the value in the Outbound Post Tail Pointer Register.

To reduce latency for the PCI read access, the MU implements a prefetch mechanism to anticipate accesses to the Outbound Post Queue. The MU hardware prefetches the data at the tail of the Outbound Post Queue and load it into an internal prefetch register. When the PCI read access occurs, the data is read directly from the prefetch register.

The prefetch mechanism loads a value of -1 (FFFF.FFFFH) into the prefetch register when the head and tail pointers are equal and the queue is empty. In order to update the prefetch register when messages are added to the queue and it becomes non-empty, the prefetch mechanism automatically starts a prefetch when the prefetch register contains FFFF.FFFFH and the Outbound Post Head Pointer Register is written. The Intel<sup>®</sup> XScale<sup>TM</sup> core needs to update the Outbound Post Head Pointer Register when it adds messages to the queue.

A prefetch must appear atomic from the perspective of the external PCI agent. When a prefetch is started, any PCI transaction that attempts to access the Outbound Post Queue is signalled a Retry until the prefetch is completed.

A PCI interrupt may be generated when data in the prefetch buffer is valid. When the prefetch queue is clear, no interrupt is generated. The Outbound Post Queue Interrupt bit in the Outbound Interrupt Status Register shall indicate the status of the prefetch buffer data and therefore the interrupt status. The interrupt is cleared when any prefetched data has been read from the Outbound Queue Port. The interrupt can be masked by the Outbound Interrupt Mask Register.

The Intel<sup>®</sup>  $XScale^{TM}$  core may place messages in the Outbound Post Queue by writing the data to the local memory address in the Outbound Post Head Pointer Register. The processor must then increment the Outbound Post Head Pointer Register.



#### 4.5.4 Outbound Free Queue

The Outbound Free Queue holds free messages placed there by other processors for the Intel<sup>®</sup> XScale<sup>TM</sup> core to use. This queue is read from the queue tail by the Intel<sup>®</sup> XScale<sup>TM</sup> core. It is written to the queue head by external PCI agents. The tail pointer is maintained by the Intel<sup>®</sup> XScale<sup>TM</sup> core. The head pointer is maintained by the MU hardware.

For a PCI write transaction that accesses the Outbound Queue Port, the MU writes the data to the local memory address in the Outbound Free Head Pointer Register. When the data written to the Outbound Queue Port is written to local memory, the MU hardware increments the Outbound Free Head Pointer Register.

When the head pointer and the tail pointer become equal and the queue is full, the MU may signal an interrupt to the Intel<sup>®</sup> XScale <sup>TM</sup> core to register the queue full condition. This interrupt is recorded in the Inbound Interrupt Status Register. The interrupt is cleared when the Outbound Free Queue Full Interrupt bit is cleared and not by writing to the head or tail pointers. The interrupt can be masked by the Inbound Interrupt Mask Register. Software must be aware of the state of the Outbound Free Queue Interrupt Mask bit to guarantee that the full condition is recognized by the core processor.

From the time that a PCI write transaction is received until the data is written in local memory and the Outbound Free Head Pointer Register is incremented, any PCI transaction that attempts to access the Outbound Free Queue Port is signalled a retry.

The Intel<sup>®</sup> XScale<sup>™</sup> core may read messages from the Outbound Free Queue by reading the data from the local memory address in the Outbound Free Tail Pointer Register. The processor must then increment the Outbound Free Tail Pointer Register. When the Outbound Free Queue is full, the hardware must retry any PCI writes until a slot in the queue becomes available.

Table 152. Circular Queue Summary

| Queue Name             | PCI Port       | Generate PCI<br>Interrupt               | Generate Intel <sup>®</sup><br>Xscale <sup>™</sup> Core<br>Interrupt | Head Pointer maintained by                                  | Tail Pointer maintained by                               |
|------------------------|----------------|-----------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------|
| Inbound Post<br>Queue  | Inbound Queue  | No                                      | Yes, when queue is written                                           | MU hardware                                                 | Intel <sup>®</sup> XScale <sup>™</sup> microarchitecture |
| Inbound Free<br>Queue  | Port           | No                                      | No                                                                   | Intel <sup>®</sup> XScale <sup>™</sup><br>microarchitecture | MU hardware                                              |
| Outbound Post<br>Queue | Outbound Queue | Yes, when prefetch buffer data is valid | No                                                                   | Intel <sup>®</sup> XScale <sup>™</sup><br>microarchitecture | MU hardware                                              |
| Outbound Free<br>Queue | Port           | No                                      | Yes, when queue is full                                              | MU hardware                                                 | Intel <sup>®</sup> XScale <sup>™</sup> microarchitecture |

Table 153. Circular Queue Status Summary

| Queue Name          | Queue Status | Head & Tail Pointer | Last Pointer Update                   |
|---------------------|--------------|---------------------|---------------------------------------|
| Inbound Post Queue  | Empty        | Equal               | Tail pointer last updated by software |
| &                   | Not Empty    | Not Equal           | N/A                                   |
| Outbound Free Queue | Full         | Equal               | Head pointer last updated by hardware |
| Inbound Free Queue  | Empty        | Equal               | Head pointer last updated by hardware |
| &                   | Not Empty    | Not Equal           |                                       |
| Outbound Post Queue | Full         | Equal               | Tail pointer last updated by software |



# 4.6 Index Registers

The Index Registers are a set of 1004 registers that when written by an external PCI agent can generate an interrupt to the Intel<sup>®</sup> XScale<sup>™</sup> core. These registers are for inbound messages only. The interrupt is recorded in the Inbound Interrupt Status Register.

The storage for the Index Registers is allocated from the 80331 local memory. PCI write accesses to the Index Registers write the data to local memory. PCI read accesses to the Index Registers read the data from local memory. The local memory used for the Index Registers ranges from Inbound ATU Translate Value Register + 050H to Inbound ATU Translate Value Register + FFFH. Chapter 3, "Address Translation Unit" describes how PCI addresses are translated to local memory addresses.

The address of the first write access is stored in the Index Address Register. This register is written during the earliest write access and provides a means to determine which Index Register was written. Once updated by the MU, the Index Address Register is not updated until the Index Register Interrupt bit in the Inbound Interrupt Status Register is cleared. When the interrupt is cleared, the Index Address Register is re-enabled and stores the address of the next Index Register write access.

Writes by the Intel<sup>®</sup>  $XScale^{TM}$  core to the local memory used by the Index Registers does not cause an interrupt and does not update the Index Address Register.

The index registers can be accessed with Multi-DWORD reads and single QWORD aligned writes.

# 4.7 Messaging Unit Error Conditions

The Messaging Unit, like the ATU, encounters error conditions on the PCI interface as well as the internal bus interface. As a PCI target, all PCI errors (parity and aborts) are captured and recorded in the ATU Status Register and can be masked using the ATU mechanisms. Refer to Chapter 3, "Address Translation Unit" for further details.



# 4.8 Message-Signaled Interrupts

The Messaging Unit is responsible for the generation of all of the Outbound Interrupts from the 80331. These interrupts can be delivered to the Host Processor via the **P\_INTC**# output pin (**P\_INTA**# with **BRG\_EN** and **ARB\_EN** straps low) or the Message Signaled Interrupt (MSI) mechanism.

When a host processor enables Message-Signaled Interrupts (MSI) on the 80331, an outbound interrupt is signaled to the host via a PCI write instead of the assertion of the **P\_INTC**# output pin (**P\_INTA**# with **BRG\_EN** and **ARB\_EN** straps low).

The *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a states that "PCI-X devices that generate interrupts are required to support message-signaled interrupts, as defined by the *PCI Local Bus Specification*, Revision 2.2 and must support a 64-bit message address." "Devices that require interrupts in systems that do not support message-signaled interrupts, must implement interrupt pins." Thus, the 80331 needs to implement both wired and message-signaled interrupt delivery mechanisms.

In support of MSI, the 80331 implements the MSI capability structure. The capability structure includes the "MSI Message Control Register - MSI\_MCR" on page 325, the "MSI Message Address Register - MSI\_MAR" on page 326, the "MSI Message Upper Address Register - MSI\_MUAR" on page 327 and the "MSI Message Data Register- MSI\_MDR" on page 328.

During system initialization, the configuration software for an MSI system reads the Message Control Register to determine that the 80331 supports a 64-bit Message Address, and that it is capable of generating two unique interrupt messages.

After gathering this data from all of the MSI capable devices in the system, the configuration software decides where to initialize the Message Address and how many unique messages each MSI capable device is allowed. Then, software writes the Message Address Registers (and the Message Upper Address Registers when Message Address is above the 4G address boundary 1), and the Message Data Register. This system specified data is used to route the interrupt request message to the appropriate entry in a host processor Local APIC table.

Configuration of MSI completes with a write to the Message Control Register which includes an update to the Multiple Message Enable field and the MSI enable bit of each device. This informs the device how many unique messages (Local APIC table entries) have been allocated for exclusive use by that device and enable that device for MSI. Device hardware is required to handle allocation of fewer unique interrupt messages than requested by the Multiple Message Capable field.

80331 is able to handle generating only one message, even though the device is capable of generating two unique messages. When two unique messages are enabled, one message is reserved for Outbound Post Queue Interrupt and the other message represents all of Outbound Doorbell and Outbound Message Interrupts. When only one message is enabled, all interrupts are represented by a single message. Interrupt handler software needs to read 80331 Outbound Interrupt Status Register to determine the interrupt cause when more than one source is represented by a single message.

To signal an Outbound Interrupt with MSI enabled, the 80331 creates an outbound write transaction using the Message Address and the Message Data. When two unique messages are enabled, the lowest order bit of the Message Data is modified by hardware so that the host processor can distinguish between them.

When host software enables MSI, a Messaging Unit Interrupt does not result in the assertion of the P\_INTC# output pin (P\_INTA# with BRG\_EN and ARB\_EN straps low). However, all the S\_INT[D:A]# pins is functional for steering of interrupts from other PCI devices that may not be MSI capable.

**Document Number: 273942-002** October, 2003 301

<sup>1.</sup> When host software writes the Message Upper address register to a non-zero value, device hardware uses a write transaction with a Dual Address Cycle (DAC) to present the full 64-bit address to the bus.



### 4.8.1 Level-Triggered Versus Edge-Triggered Interrupts

When MSI is disabled, the **P\_INTC#** output pin (**P\_INTA#** with **BRG\_EN** and **ARB\_EN** straps low) remains asserted and pended to the host when **any** of the MU interrupt sources requires service (Outbound Post Queue, Outbound Doorbell and Outbound Message). Since the PCI pin signaled interrupt is **level-triggered**, the interrupt service routine does not drop out of the service routine until the interrupt signal is deasserted. This guarantees that an interrupt is not missed.

MSI interrupts are inherently edge-triggered, in that an interrupt is only pended to the host as a write event when any of the MU interrupt sources requires service. The MU generates a MSI message when a interrupt status bit in the OISR is set. Additional MSI messages is generated by the MU when other bits are set in the OISR, that are previously clear.

**Note:** The MU does NOT generate a MSI message when one pending interrupt is cleared in the OISR and other pending interrupt status bits remain set. Interrupt service routines must service and clear all pending interrupts from the OISR before exiting to insure no interrupts are missed.

302 October, 2003 **Document Number: 273942-002** 



# 4.9 Register Definitions

The following registers are located in the PCI address space and in the Peripheral Memory-Mapped Register (PMMR) address space. They are accessible through PCI bus transactions and through Intel<sup>®</sup> XScale TM core internal bus accesses. In the PCI address space, they are mapped into the first 80 bytes of the inbound address window of the ATU.

- Inbound Message 0 Register
- Inbound Message 1 Register
- Outbound Message 0 Register
- Outbound Message 1 Register
- Inbound Doorbell Register

- Inbound Interrupt Status Register
- Inbound Interrupt Mask Register
- · Outbound Doorbell Register
- Outbound Interrupt Status Register
- Outbound Interrupt Mask Register

The following registers are located in the Peripheral Memory-Mapped Register (PMMR) address space as described in Chapter 17, "Peripheral Registers".

- MU Configuration Register
- Queue Base Address Register
- Inbound Free Head Pointer Register
- Inbound Free Tail Pointer Register
- Inbound Post Head Pointer Register
- Inbound Post Tail Pointer Register
- Outbound Free Head Pointer Register
- Outbound Free Tail Pointer Register
- Outbound Post Head Pointer Register
- Outbound Post Tail Pointer Register
- Index Address Register

Reading or writing a register that is reserved is undefined.

#### Table 154. Message Unit Register

| Internal Bus Address | Section, Register Name - Acronym (Page)                                   |  |  |
|----------------------|---------------------------------------------------------------------------|--|--|
| FFFF.E310H           | Section 4.9.1, "Inbound Message Register - IMRx" on page 304              |  |  |
| FFFF.E314H           | Section 4.9.1, "Inbound Message Register - IMRx" on page 304              |  |  |
| FFFF.E318H           | Section 4.9.2, "Outbound Message Register - OMRx" on page 305             |  |  |
| FFFF.E31CH           | Section 4.9.2, "Outbound Message Register - OMRx" on page 305             |  |  |
| FFFF.E320H           | Section 4.9.3, "Inbound Doorbell Register - IDR" on page 306              |  |  |
| FFFF.E324H           | Section 4.9.4, "Inbound Interrupt Status Register - IISR" on page 307     |  |  |
| FFFF.E328H           | Section 4.9.5, "Inbound Interrupt Mask Register - IIMR" on page 308       |  |  |
| FFFF.E32CH           | Section 4.9.6, "Outbound Doorbell Register - ODR" on page 309             |  |  |
| FFFF.E330H           | Section 4.9.7, "Outbound Interrupt Status Register - OISR" on page 310    |  |  |
| FFFF.E334H           | Section 4.9.8, "Outbound Interrupt Mask Register - OIMR" on page 311      |  |  |
| FFFF.E350H           | Section 4.9.9, "MU Configuration Register - MUCR" on page 312             |  |  |
| FFFF.E354H           | Section 4.9.10, "Queue Base Address Register - QBAR" on page 313          |  |  |
| FFFF.E360H           | Section 4.9.11, "Inbound Free Head Pointer Register - IFHPR" on page 314  |  |  |
| FFFF.E364H           | Section 4.9.12, "Inbound Free Tail Pointer Register - IFTPR" on page 315  |  |  |
| FFFF.E368H           | Section 4.9.13, "Inbound Post Head Pointer Register - IPHPR" on page 316  |  |  |
| FFFF.E36CH           | Section 4.9.14, "Inbound Post Tail Pointer Register - IPTPR" on page 317  |  |  |
| FFFF.E370H           | Section 4.9.15, "Outbound Free Head Pointer Register - OFHPR" on page 318 |  |  |
| FFFF.E374H           | Section 4.9.16, "Outbound Free Tail Pointer Register - OFTPR" on page 319 |  |  |
| FFFF.E378H           | Section 4.9.17, "Outbound Post Head Pointer Register - OPHPR" on page 320 |  |  |
| FFFF.E37CH           | Section 4.9.18, "Outbound Post Tail Pointer Register - OPTPR" on page 321 |  |  |
| FFFF.E380H           | Section 4.9.19, "Index Address Register - IAR" on page 322                |  |  |

**Document Number: 273942-002** October, 2003 303



# 4.9.1 Inbound Message Register - IMRx

There are two Inbound Message Registers: IMR0 and IMR1. When the IMR register is written, an interrupt to the Intel<sup>®</sup> XScale <sup>TM</sup> core may be generated. The interrupt is recorded in the Inbound Interrupt Status Register and may be masked by the Inbound Message Interrupt Mask bit in the Inbound Interrupt Mask Register.

Table 155. Inbound Message Register - IMRx





# 4.9.2 Outbound Message Register - OMRx

There are two Outbound Message Registers: OMR0 and OMR1. When the OMR register is written, a PCI interrupt may be generated. The interrupt is recorded in the Outbound Interrupt Status Register and may be masked by the Outbound Message Interrupt Mask bit in the Outbound Interrupt Mask Register.

Table 156. Outbound Message Register - OMRx





# 4.9.3 Inbound Doorbell Register - IDR

The Inbound Doorbell Register (IDR) is used to generate interrupts to the Intel<sup>®</sup> XScale<sup>TM</sup> core. Bit 31 is reserved for generating an Error Doorbell interrupt. When bit 31 is set, an Error interrupt may be generated to the Intel<sup>®</sup> XScale<sup>TM</sup> core. All other bits, when set, cause the Normal Messaging Unit interrupt line of the Intel<sup>®</sup> XScale<sup>TM</sup> core to be asserted, when the interrupt is not masked by the Inbound Doorbell Interrupt Mask bit in the Inbound Interrupt Mask Register. The bits in the IDR register can only be set by an external PCI agent and can only be cleared by the Intel<sup>®</sup> XScale<sup>TM</sup> core.

Table 157. Inbound Doorbell Register - IDR





### 4.9.4 Inbound Interrupt Status Register - IISR

The Inbound Interrupt Status Register (IISR) contains hardware interrupt status. It records the status of Intel<sup>®</sup> XScale<sup>™</sup> core interrupts generated by the Message Registers, Doorbell Registers, and the Circular Queues. All interrupts are routed to the Normal Messaging Unit interrupt input of the Intel<sup>®</sup> XScale<sup>™</sup> core, except for the Error Doorbell Interrupt and the Outbound Free Queue Full interrupt; these two are routed to the Messaging Unit Error interrupt input. The generation of interrupts recorded in the Inbound Interrupt Status Register may be masked by setting the corresponding bit in the Inbound Interrupt Mask Register. Some of the bits in this register are Read Only. For those bits, the interrupt must be cleared through another register.

Table 158. Inbound Interrupt Status Register - IISR





# 4.9.5 Inbound Interrupt Mask Register - IIMR

The Inbound Interrupt Mask Register (IIMR) provides the ability to mask Intel<sup>®</sup> XScale<sup>™</sup> core interrupts generated by the Messaging Unit. Each bit in the Mask register corresponds to an interrupt bit in the Inbound Interrupt Status Register.

Setting or clearing bits in this register does not affect the Inbound Interrupt Status Register. They only affect the generation of the  $Intel^{\mathbb{R}}$  XScale  $^{TM}$  core interrupt.

Table 159. Inbound Interrupt Mask Register - IIMR





### 4.9.6 Outbound Doorbell Register - ODR

The Outbound Doorbell Register (ODR) allows software interrupt generation. It allows the Intel<sup>®</sup> XScale<sup>™</sup> core to generate PCI interrupts to the host processor by writing to this register. The generation of PCI interrupts through the Outbound Doorbell Register may be masked by setting the Outbound Doorbell Interrupt Mask bit in the Outbound Interrupt Mask Register.

The Software Interrupt bits in this register can only be set by the Intel<sup>®</sup> XScale<sup>™</sup> core and can only be cleared by an external PCI agent.

Table 160. Outbound Doorbell Register - ODR





# 4.9.7 Outbound Interrupt Status Register - OISR

The Outbound Interrupt Status Register (OISR) contains hardware interrupt status. It records the status of PCI interrupts generated by the Message Registers, Doorbell Registers, and the Circular Queues. The generation of PCI interrupts recorded in the Outbound Interrupt Status Register may be masked by setting the corresponding bit in the Outbound Interrupt Mask Register. Some of the bits in this register are Read Only. For those bits, the interrupt must be cleared through another register.

Table 161. Outbound Interrupt Status Register - OISR





### 4.9.8 Outbound Interrupt Mask Register - OIMR

The Outbound Interrupt Mask Register (OIMR) provides the ability to mask outbound PCI interrupts generated by the Messaging Unit. Each bit in the mask register corresponds to a hardware interrupt bit in the Outbound Interrupt Status Register. When the bit is set, the PCI interrupt is not generated. When the bit is clear, the interrupt is allowed to be generated.

Setting or clearing bits in this register does not affect the Outbound Interrupt Status Register. They only affect the generation of the PCI interrupt.

Table 162. Outbound Interrupt Mask Register - OIMR





### 4.9.9 MU Configuration Register - MUCR

The MU Configuration Register (MUCR) contains the Circular Queue Enable bit and the size of one Circular Queue. The Circular Queue Enable bit enables or disables the Circular Queues. The Circular Queues are disabled at reset to allow the software to initialize the head and tail pointer registers before any PCI accesses to the Queue Ports. Each Circular Queue may range from 4 K entries (16 Kbytes) to 64 K entries (256 Kbytes) and there are four Circular Queues.

Table 163. MU Configuration Register - MUCR





# 4.9.10 Queue Base Address Register - QBAR

The Queue Base Address Register (QBAR) contains the local memory address of the Circular Queues. The base address is required to be located on a 1 Mbyte address boundary.

All Circular Queue head and tail pointers are based on the QBAR. When the head and tail pointer registers are read, the Queue Base Address is returned in the upper 12 bits. Writing to the upper 12 bits of the head and tail pointer registers does not affect the Queue Base Address or Queue Base Address Register.

**Warning:** The QBAR must designate a range allocated to the 80331 DDR SDRAM interface (Chapter 8, "Memory Controller").

Table 164. Queue Base Address Register - QBAR





# 4.9.11 Inbound Free Head Pointer Register - IFHPR

The Inbound Free Head Pointer Register (IFHPR) contains the local memory offset from the Queue Base Address of the head pointer for the Inbound Free Queue. The Head Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored. This register is maintained by software.

Table 165. Inbound Free Head Pointer Register - IFHPR





# 4.9.12 Inbound Free Tail Pointer Register - IFTPR

The Inbound Free Tail Pointer Register (IFTPR) contains the local memory offset from the Queue Base Address of the tail pointer for the Inbound Free Queue. The Tail Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 166. Inbound Free Tail Pointer Register - IFTPR





# 4.9.13 Inbound Post Head Pointer Register - IPHPR

The Inbound Post Head Pointer Register (IPHPR) contains the local memory offset from the Queue Base Address of the head pointer for the Inbound Post Queue. The Head Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 167. Inbound Post Head Pointer Register - IPHPR





# 4.9.14 Inbound Post Tail Pointer Register - IPTPR

The Inbound Post Tail Pointer Register (IPTPR) contains the local memory offset from the Queue Base Address of the tail pointer for the Inbound Post Queue. The Tail Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 168. Inbound Post Tail Pointer Register - IPTPR





# 4.9.15 Outbound Free Head Pointer Register - OFHPR

The Outbound Free Head Pointer Register (OFHPR) contains the local memory offset from the Queue Base Address of the head pointer for the Outbound Free Queue. The Head Pointer must be aligned on a DWORD address boundary. This register is maintained by software. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 169. Outbound Free Head Pointer Register - OFHPR





# 4.9.16 Outbound Free Tail Pointer Register - OFTPR

The Outbound Free Tail Pointer Register (OFTPR) contains the local memory offset from the Queue Base Address of the tail pointer for the Outbound Free Queue. The Tail Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 170. Outbound Free Tail Pointer Register - OFTPR



319



# 4.9.17 Outbound Post Head Pointer Register - OPHPR

The Outbound Post Head Pointer Register (OPHPR) contains the local memory offset from the Queue Base Address of the head pointer for the Outbound Post Queue. The Head Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 171. Outbound Post Head Pointer Register - OPHPR



321



# 4.9.18 Outbound Post Tail Pointer Register - OPTPR

The Outbound Post Tail Pointer Register (OPTPR) contains the local memory offset from the Queue Base Address of the tail pointer for the Outbound Post Queue. The Tail Pointer must be aligned on a DWORD address boundary. When read, the Queue Base Address is provided in the upper 12 bits of the register. Writes to the upper 12 bits of the register are ignored.

Table 172. Outbound Post Tail Pointer Register - OPTPR





# 4.9.19 Index Address Register - IAR

The Index Address Register (IAR) contains the offset of the least recently accessed Index Register. It is written by the MU when the Index Registers are written by a PCI agent. The register is not updated until the Index Interrupt bit in the Inbound Interrupt Status Register is cleared.

The local memory address of the Index Register least recently accessed is computed by adding the Index Address Register to the Inbound ATU Translate Value Register.

Table 173. Index Address Register - IAR





# 4.9.20 MSI Capability Identifier Register - MSI\_CAPID

The MSI Capability Identifier Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.2. This register in the PCI Extended Capability header identifies the type of Extended Capability contained in that header. The value of 05H in this field identifies the function as message signaled interrupt capable.

Table 174. MSI Capability Identifier Register - MSI\_CAPID





# 4.9.21 MSI Next Item Pointer Register - MSI\_NXTP

The Next Item Pointer Register bits adhere to the definitions in the *PCI Local Bus Specification*, Revision 2.2. This register describes the location of the next item in the function capability list. For the 80331 that is the PCI-X capability header at offset E0H.

Table 175. MSI Next Item Pointer Register - MSI\_NXTP



324 October, 2003 **Document Number: 273942-002** 



# 4.9.22 MSI Message Control Register - MSI\_MCR

The Message Control Register provides system software control over MSI. After reset, MSI is disabled. System software is permitted to modify the Message Control register's read/write bits and fields while a device driver is not permitted to modify them.

Table 176. MSI Message Control Register - MSI\_MCR





# 4.9.23 MSI Message Address Register - MSI\_MAR

The Message address register specifies the DWORD aligned address for the MSI memory write transaction. The value is set by system software during initialization.

Table 177. MSI Message Address Register - MSI\_MAR





# 4.9.24 MSI Message Upper Address Register - MSI\_MUAR

The Message Upper Address register is set during system initialization when system software wishes to place the MSI address location above the 4G address boundary. When this register is set to a non-zero value, the 80331 generates a dual address cycle for the MSI write command and uses the contents of this register as the upper 32-bits of that address.

Table 178. MSI Message Upper Address Register - MSI\_MUAR





# 4.9.25 MSI Message Data Register- MSI\_MDR

The value in the Message Data Register contains the data used during an MSI write transaction. When two unique messages are enabled, one message is reserved for the Outbound Post Queue Interrupt and the other message represents all of the Outbound Doorbell and Outbound Message Interrupts. When only one message is enabled, all of these interrupts is represented by a single message. Interrupt handler software needs to read the 80331 Outbound Interrupt Status Register to determine the cause of the interrupt when more than one source is represented by a single message.

During an MSI write data phase, the value in the Message Data Register is driven on to **AD[15:0]** while **AD[31:16]** is driven to zero. **C/BE[3:0]**# are asserted during the data phase of the memory write transaction.

Table 179. MSI Message Data Register - MSI\_MDR





# 4.10 Power/Default Status

The software is responsible for initializing the Circular Queue Size in the MU Configuration Register and all head and tail pointer registers before setting the Circular Queue Enable bit.

**Document Number: 273942-002** October, 2003 329



# This Page Intentionally Left Blank



# Intel<sup>®</sup> XScale<sup>™</sup> Core Bus Interface Unit 5

This chapter describes the Intel<sup>®</sup> XScale<sup>TM</sup> core (ARM\* architecture compliant) Bus Interface Unit (BIU) for the Intel<sup>®</sup> 80331 I/O processor (80331).

#### 5.1 Overview

The BIU provides the interfaces between the Intel<sup>®</sup> XScale<sup>™</sup> core and the Internal Bus and Memory Controller outbound ports. The BIU decodes transactions from the core and sends them to the appropriate outbound port. Transactions which address the DDR SDRAM are sent to the MCU port, and all other transactions are sent to the 80331 64-bit internal bus.

The high performance Internal Bus is used in the 80331 to interconnect major peripheral blocks as shown in Figure 24. A detailed block diagram of the BIU and Memory Controller Unit (MCU) is shown in Figure 24.

The BIU acts as a Master for all the read and write requests issued by the Intel<sup>®</sup> XScale<sup>™</sup> core targeting the Internal Bus, and acts as a Slave for split completions of BIU split requests. The BIU has software accessible state information in the form of registers which reside in Peripheral Memory Mapped Register space.



# **5.2** Theory of Operation

The BIU accepts  $Intel^{\circledR}$  XScale<sup>TM</sup> core bus accesses. It decodes core transactions and forwards them to the memory controller or internal bus outbound ports accordingly. The BIU translates the  $Intel^{\circledR}$  XScale<sup>TM</sup> core bus transactions to the protocol for the internal bus port, and the format for the Core Memory Transaction Queue of the MCU for the Core MCU port.

#### 5.2.1 Functional Blocks

The memory controller and Intel<sup>®</sup> XScale<sup>™</sup> core processor bus interface unit (BIU) logically comprises the blocks illustrated in Figure 24. The memory controller is a multiported unit, supporting an inbound path for both the BIU and Internal Bus (IB) to the DDR SDRAM.

Figure 24. Intel<sup>®</sup> 80331 I/O Processor BIU and MCU Architecture



332 October, 2003 **Document Number: 273942-002** 



#### 5.2.1.1 Core Processor Port Address Decode

The address decode block for the Core Processor transactions resides in the BIU. The Core MCU port therefore does not require any decode, and any transactions received from the BIU via the Core MCU Port are decoded to determine when they address the DDR SDRAM Memory Space. When a transaction addresses the DDR SDRAM Memory Space, it is sent to the Core MCU port of the MCU which is a direct connection to the Core Memory Transaction Queue. When the transaction does not address that space, it is sent to the Core Internal Bus Transaction Queue to be issued on the Internal Bus. Core processor transactions addressing the MCU MMR Space, are directed to the Internal Bus, and subsequently claimed by the Internal Bus Port interface of the MCU.

#### **5.2.1.2** Transaction Queues

The BIU has one transaction queue for transactions directed to the Internal Bus. The Core IB Transaction Queue (CIBTQ) has 8 read entries, 4 write entries, and 4 return data entries. The CIBTQ holds 4 outstanding read transactions up to 32-Bytes each, and 4 posted write transactions up to 16-Bytes each. The BIU acts as a Master for all the read and write requests issued by the Intel® XScale To core targeting the Internal Bus, and acts as a Slave for split completions of BIU split requests. The transaction queue for MCU directed transactions exists in the MCU, and is defined in Section 8.3.1.3, "Memory Transaction Queues" on page 442. The BIU has software accessible state information in the form of memory mapped registers. All BIU registers reside in the Peripheral Memory Mapped Register space.

The Core Internal Bus port propagates read accesses to the Internal Bus and returns the read data to the Intel<sup>®</sup> XScale<sup>TM</sup> core. It completes write accesses for the Intel<sup>®</sup> XScale<sup>TM</sup> core. The BIU follows the ordering rules below for Internal Bus targeted transactions:

- Writes can pass Read requests
- Read requests does not pass read requests
- Writes does not pass Writes

The BIU may address any target on the Internal Bus. The BIU divides the core processor clock domain from the Internal Bus clock domain. The BIU has several address/data buffers:

- 4-Deep Write Transaction Queue
- 8-Deep Read Transaction Queue

• Write Data Buffer

• Read Data Buffer

In the Read transaction queue, each entry can be associated with an instruction or data cache line fill, a non-cacheable DWORD read. In the Write transaction queue, each entry can be associated with a write varying from 1 to 16 bytes of data.

The Write Data Buffer associated with each transaction queue entry can temporarily store write accesses that are destined for the Internal Bus. The BIU is responsible for forwarding all write accesses to the Internal Bus and ensuring their completion.

The Read Data Buffer associated with each transaction queue entry can temporarily store return data from the Internal Bus. The BIU is responsible for returning all read accesses to the Intel<sup>®</sup> XScale<sup>TM</sup> core.

A given transaction queue entry remains busy until the last byte of write data is transmitted or the last byte of read data is received across the Internal Bus.



# 5.3 Addressing

The BIU byte enables need to be adjusted depending on whether the 32-bit address resides in the even (A2='0') or odd (A2='1') DWORD.

See Table 180 for the Byte Enable encodings.

The BIU only reads and writes data on the Internal Bus as indicated by the Byte address generated by the Intel<sup>®</sup> XScale <sup>TM</sup> core. The BIU assumes that all accesses are to non-prefetchable memory. It does not promote Intel<sup>®</sup> XScale <sup>TM</sup> microarchitecture Byte or Intel<sup>®</sup> XScale <sup>TM</sup> microarchitecture Short accesses to DWORD accesses.

See Table 180 for the Byte Enable encodings.

#### Table 180. Contiguous Byte Enable Encodings<sup>a</sup>

| Access<br>Type <sup>b</sup> | DWORD<br>Address <sup>c</sup> | Intel <sup>®</sup> XScale <sup>™</sup><br>Core Address | Internal Bus |     |     |     |     |     |     |     |
|-----------------------------|-------------------------------|--------------------------------------------------------|--------------|-----|-----|-----|-----|-----|-----|-----|
|                             |                               | A[2:0]                                                 | BE7          | BE6 | BE5 | BE4 | BE3 | BE2 | BE1 | BE0 |
| Word                        | Even                          | 0                                                      | 1            | 1   | 1   | 1   | 0   | 0   | 0   | 0   |
|                             | Odd                           | 4                                                      | 0            | 0   | 0   | 0   | 1   | 1   | 1   | 1   |
| Short                       | Even                          | 0                                                      | 1            | 1   | 1   | 1   | 1   | 1   | 0   | 0   |
|                             |                               | 2                                                      | 1            | 1   | 1   | 1   | 0   | 0   | 1   | 1   |
|                             | Odd                           | 4                                                      | 1            | 1   | 0   | 0   | 1   | 1   | 1   | 1   |
|                             |                               | 6                                                      | 0            | 0   | 1   | 1   | 1   | 1   | 1   | 1   |
| Byte                        | Even                          | 0                                                      | 1            | 1   | 1   | 1   | 1   | 1   | 1   | 0   |
|                             |                               | 1                                                      | 1            | 1   | 1   | 1   | 1   | 1   | 0   | 1   |
|                             |                               | 2                                                      | 1            | 1   | 1   | 1   | 1   | 0   | 1   | 1   |
|                             |                               | 3                                                      | 1            | 1   | 1   | 1   | 0   | 1   | 1   | 1   |
|                             | Odd                           | 4                                                      | 1            | 1   | 1   | 0   | 1   | 1   | 1   | 1   |
|                             |                               | 5                                                      | 1            | 1   | 0   | 1   | 1   | 1   | 1   | 1   |
|                             |                               | 6                                                      | 1            | 0   | 1   | 1   | 1   | 1   | 1   | 1   |
|                             |                               | 7                                                      | 0            | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

Table assumes that write coalescing is turned off. When write coalescing is enabled, many other non-contiguous byte enable patterns are possible including all disabled.

## 5.3.1 Bus Width

The BIU supports a bus width of 32-bit for the core interface, 64-bits for the Internal Bus data bus and a width of 128 bits for the Core MCU port to the Core Memory Transaction Queue in the MCU.

334 October, 2003 **Document Number: 273942-002** 

b. For the purposes of this column, definitions are: Word equals 32-bits, Short = 16-bits, Byte = 8-bits.

c. For the purposes of this column, Even and Odd is based on Address bit A2.



# 5.4 Internal Bus Commands

For data read accesses, the BIU uses the Memory Read Block command for Intel<sup>®</sup> XScale<sup>™</sup> microarchitecture cacheline (32 bytes) fills, and Memory Read DWORD command for read accesses include Byte, Short, and Word accesses (1-, 2-, or 4-byte). The BIU supports Critical Word First (CWF) address ordering for Intel<sup>®</sup> XScale<sup>™</sup> microarchitecture cacheline (32 bytes) fills. For Intel<sup>®</sup> XScale<sup>™</sup> core transactions targeting the PCI bus through the Address Translation Unit, refer to Chapter 3, "Address Translation Unit" for command translation.

For all write accesses including cache line flushes, the BIU uses the Memory Write command.

*Note:* The Intel<sup>®</sup> XScale<sup>TM</sup> core promotes all Intel<sup>®</sup> XScale<sup>TM</sup> microarchitecture Byte and Short read accesses to Intel<sup>®</sup> XScale<sup>TM</sup> microarchitecture Word read accesses when the data cache is enabled.

Table 181 contains a summary of the Internal Bus commands used by the BIU.

#### **Table 181.** Internal Bus Command Summary

| Internal Bus Command           | Intel <sup>®</sup> XScale <sup>™</sup> Microarchitecture Word Size               | Usage                                                         |  |  |
|--------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------|--|--|
| Memory Read DWORD              | Intel <sup>®</sup> XScale <sup>™</sup> microarchitecture<br>Byte, Short, or Word | Read 1, 2, 4 bytes                                            |  |  |
| Memory Read Block              | Intel <sup>®</sup> XScale <sup>™</sup> microarchitecture core cacheline fills    | Read 32 bytes (CWF)                                           |  |  |
| Split Completion (Target Only) | All                                                                              | Read data may be returned to the BIU using a Split completion |  |  |
| Memory Write                   | All                                                                              | For all writes                                                |  |  |



# 5.5 Features

The BIU supports the following additional features.

#### **5.5.1** Multi-Transaction Timer

The BIU has an associated Multi-Transaction Timer (MTT1) in the Internal Bus Arbiter. When programmed properly, the MTT allows for a guaranteed quantum of time for the BIU. See Chapter 12, "Intel® 80331 I/O Processor Arbitration Unit" for more details.

#### 5.5.2 ATU Accesses

All read accesses from the BIU to the Address Translation Units (ATU) are processed as Split Transactions.

All writes from the BIU to the Address Translation Unit (ATU) are posted.

Instruction fetches from the BIU to the ATU are supported.

Atomic accesses from the BIU to the ATU are not supported.

336 October, 2003 **Document Number: 273942-002** 



# 5.6 Interrupts and Error Conditions

The BIU records error conditions that result from accesses initiated by the BIU on behalf of the Intel<sup>®</sup> XScale core on the Internal Bus or MCU port. The errors are recorded in the BIU Status Register (BIUSR).

#### 5.6.1 Internal Bus Errors

There are two ways that the BIU can receive an error from transactions issued on the Internal Bus:

- IB Master-Abort: No target on receives a Target-Abort when accessing the Configuration Outbound Data Register of the ATU when the ATU configuration space is incorrectly configured as cacheable. In this case the BIU would issue a burst read request (cacheline fill), and the ATU responds with a Target-Abort.
- PCI Master-Abort: The ATU, as a PCI master on behalf of the BIU, receives a Master-Abort on the PCI bus and returns the Master-Abort to the BIU with a Split Completion Error Message (Message Class = 1H, Message Index = 00H).
- PCI Target-Abort: The ATU, as a PCI master on behalf of the BIU, receives a Target-Abort on the PCI bus and returns the Target-Abort to the BIU via a Split Completion Error Message (Message Class = 1H, Message Index = 01H).

There are also two ways that the BIU can detect an error from transactions issued on the Internal Bus:

- Split completion Target Abort: On a read completion, the remaining byte count is out of range from the original request.
- Split completion Target Abort: The lower 7-bits of the address from the original request are corrupted on the first Split Completion Transaction.

#### 5.6.1.1 Internal Bus Master-Abort

When an Internal Bus access initiated by the BIU receives a Master-Abort, the BIU records the Master-Abort condition in the BIU Status Register (BIUSR), the address in BIU Error Address Register (BEAR) and signals a Data Abort to the Intel<sup>®</sup> XScale TM core.

When a Master Abort is received on the Internal Bus, the BIU signals an Imprecise Data Abort to the Intel<sup>®</sup> XScale<sup>TM</sup> core. This results in a Data Access Memory Abort exception by the Intel<sup>®</sup> XScale<sup>TM</sup> core; for more details on exceptions, please refer to Section 15.3, "The Intel<sup>®</sup> XScale<sup>TM</sup> Core Exceptions Architecture" on page 677.

#### 5.6.1.2 Internal Bus Target-Abort

When an Internal Bus access initiated by the BIU receives a Target-Abort, the BIU records the Target-Abort condition in the BIUSR, the address in BEAR and signals a Data Abort to the Intel<sup>®</sup>  $XScale^{TM}$  core.



#### 5.6.1.3 PCI Master-Abort

The PCI Master Abort is recorded in the ATUISR. The ATU generates an interrupt to the Intel<sup>®</sup> XScale  $^{^{TM}}$  core.

For PCI read accesses, the ATU returns a Split Completion Error Message to the BIU. This causes the BIU to signal an imprecise data abort to the Intel<sup>®</sup> XScale  $^{^{TM}}$  core.

The software is able to diagnose that the error occurred via an outbound BIU transaction by examining the BIU Error Address Register (BEAR) and the BIU Control Register.

Because writes are posted, the ATU is responsible for signalling an interrupt to the Intel<sup>®</sup> XScale<sup>TM</sup> core when a PCI Master-Abort is received during a write access to the ATU.

#### 5.6.1.4 PCI Target-Abort

The PCI Target Abort is recorded in the ATUISR. The ATU generates an interrupt to the Intel<sup>®</sup> XScale <sup>™</sup> core. When the ATU detects a Target-Abort on the PCI bus for a read access, the ATU returns a Split Completion Error Message to the BIU indicating the Target-Abort.

For PCI read accesses, the ATU returns a Split Completion Error Message to the BIU. This causes the BIU to signal an imprecise data abort to the Intel<sup>®</sup>  $XScale^{TM}$  core.

The software is able to diagnose that the error occurred via an outbound BIU transaction by examining the BIU Error Address Register (BEAR) and the BIU Control Register.

Because writes are posted, the ATU is responsible for signalling an interrupt to the Intel<sup>®</sup> XScale<sup>TM</sup> core when a PCI Target-Abort is received during a write access to the ATU.

#### **5.6.1.5 Split Transaction Errors**

As a requester on the internal bus, the BIU may detect the following error conditions due to a corrupted split completion:

- On a read completion, the remaining byte count is out of range from the original request.
- The lower 7-bits of the address from the original request are corrupted on the first Split Completion Transaction.

Upon detecting either of these errors, the BIU signals an Imprecise Data Abort to the Intel<sup>®</sup> XScale TM core and records the error in the BIUSR.

The BIU never acts as a Completer on internal bus for split transactions, and therefore no errors as a completer are possible.



#### 5.6.2 Core MCU Errors

There are two ways that the BIU can receive an error from transactions issued to the MCU port:

- DDR SDRAM Multi-bit ECC Error
- Invalid Address Region Error

#### 5.6.2.1 Multi-bit ECC Error

When a multi-bit ECC error is detected by the MCU, the error is also reported by the BIU. A multi-bit ECC error reported by the BIU can only occur on a read transaction by the Intel<sup>®</sup> XScale TM core.

For write accesses, the core processor transaction is posted to the MCU. Therefore to the BIU, the transaction appears as when it has completed before the transaction completes to the DDR SDRAM. In this case, the MCU is the only unit that notifies the core processor of any error condition.

For read accesses, the BIU signals an Imprecise Data Abort to the Intel<sup>®</sup> XScale<sup>TM</sup> core. The MCU also records the error in the ELOGx registers and generates an interrupt to the Intel<sup>®</sup> XScale<sup>TM</sup> core

### 5.6.2.2 Invalid Address Region Error

When a 32-bit region is defined with a 64-bit wide memory, an invalid address region exists. The region is illustrated in Figure 25 and is equal size to the 32-bit region as defined by Section 8.7.7, "SDRAM 32-bit Region Size Register - S32SR" on page 504, and at a contiguous address to the 32-bit region.

Intel<sup>®</sup> XScale<sup>™</sup> core transactions which address the invalid address region are sent to the MCU via the Core MCU port. The MCU detects and reports this error in the Section 8.7.12, "Memory Controller Interrupt Status Register - MCISR" on page 509.

#### Figure 25. DDR SDRAM 64-bit Memory Address Map





# 5.7 Reset and Initialization Conditions

#### **5.7.1** Reset

The BIU is reset:

- when **P\_RST**# is asserted.
- when the Intel<sup>®</sup> XScale<sup>TM</sup> core is reset.

When reset, all Core IB transaction buffers are marked as invalid, and BIU registers return to the reset values.

#### 5.7.2 Initialization

For proper operation of 80331, the configuration of the MCU must be complete prior to enabling the MCU port of the BIU. Once the MCU is fully configured (specifically the SDCR[1:0], SDIR, SDBR, SBR[1:0], and S32SR), the BIU control register can be programmed to enable the MCU port of the BIU.

340 October, 2003 **Document Number: 273942-002** 



# 5.8 Register Definitions

There are two Registers for the BIU. These registers are mapped into  $Intel^{\mathbb{B}}$  XScale  $^{TM}$  core memory space.

Table 182 lists the PMMR registers for the BIU.

#### **Table 182.** Bus Interface Unit Register Tables

| Section, Register Name - Acronym (Page)                        |
|----------------------------------------------------------------|
| Section 5.8.1, "BIU Status Register - BIUSR" on page 342       |
| Section 5.8.2, "BIU Error Address Register - BEAR" on page 344 |
| Section 5.8.3, "BIU Control Register - BIUCR" on page 345      |



# 5.8.1 BIU Status Register - BIUSR

The BIU Status Register (BIUSR) allows software to determine the cause of any BIU error. When an error is logged and this register is updated, an imprecise data abort is signaled to the Intel<sup>®</sup> XScale Tore.

Table 183. BIU Status Register - BIUSR (Sheet 1 of 2)

342





#### Table 183. BIU Status Register - BIUSR (Sheet 2 of 2)





# 5.8.2 BIU Error Address Register - BEAR

This register is responsible for logging the addresses where the errors were detected on the Internal Bus. One error can be detected and logged. For error details, see Section 5.6, "Interrupts and Error Conditions" on page 337).

Table 184. BIU Error Address Register - BEAR





# 5.8.3 BIU Control Register - BIUCR

The BIU Control Register (BIUCR) provides enable control of the Core MCU port interface of the BIU. Monitoring the Read and Write transactions queue depth status bits of the "BIU Status Register - BIUSR" on page 342 to determine when the pending Intel<sup>®</sup> XScale core processor transactions have completed and drained through the Core Memory Transaction Queue of the Memory Controller Unit.

Table 185. BIU Control Register - BIUCR





# This Page Intentionally Left Blank



# **DMA Controller Unit**

6

This chapter describes the integrated Direct Memory Access (DMA) Controller Unit. DMA Controller operation modes, setup, external interface, and implementation are detailed in this chapter.

# 6.1 Overview

The DMA Controller provides low-latency, high-throughput data transfer capability. The DMA Controller optimizes block transfers of data between the Secondary PCI bus and the local processor memory. The DMA is an initiator on the Internal bus with burst capabilities providing a maximum throughput of 1064 Mbytes/sec. when the Secondary PCI bus is operating in 64-bit/133 MHz PCI-X mode. When addressing host memory space, the PCI-to-PCI Bridge forwards the transaction to the Primary PCI bus . In addition, the DMA provides a hardware assist to the iSCSI\* application by calculating CRC-32C on the data during the block transfer.

The DMA Controller hardware is responsible for executing data transfers and for providing the programming interface. The DMA Controller features:

- Two Independent Channels
- Three 1-KByte queues in both Ch-0 and Ch-1
- Utilization of the Intel<sup>®</sup> 80331 I/O processor (80331) Memory Controller Interface
- 2<sup>32</sup> addressing range on the Internal Bus interface
- 2<sup>64</sup> addressing range on the PCI interface by using PCI Dual Address Cycle (DAC)
- Hardware support for unaligned data transfers for both the PCI bus and the Internal Bus
- Up to 1064 Mbytes/sec burst support for the PCI bus in the PCI-X mode
- Direct addressing to and from the PCI bus
- Memory to Memory DMA transfer mode
- Calculation of CRC-32C on the transferred data stream
- Fully programmable directly from the internal bus
- Support for automatic data chaining for gathering and scattering of data blocks
- 64-bit/266 MHz 80331 internal bus interface.

Figure 26 shows the connections of the DMA channels to the Internal Bus.

#### Figure 26. DMA Controller



**Document Number: 273942-002** October, 2003 347



# 6.2 Theory of Operation

The DMA Controller provides two channels of high throughput PCI-to-Memory or Memory-to-Memory transfers. Channels 0 and 1 transfer blocks of data between the PCI bus and I/O processor local memory.

The two DMA channels operate identically. Each channel has an internal bus interface. Figure 27 shows the block diagram for one channel of the DMA Controller.

Figure 27. DMA Channel Block Diagram



Each DMA channel uses direct addressing for both the PCI bus and the internal bus. It supports data transfers to and from the full 64-bit address range of the PCI bus. This includes 64-bit addressing using the PCI DAC command. The channel provides a special register which contains the upper 32 address bits for the 64-bit address. The DMA channels do not support data transfers that cross a 32-bit address (4 GByte) boundary.

When Memory-to-Memory transfer mode is enabled, the DMA can be programmed to transfer data across the entire 4 Gbyte memory space on the Internal Bus. This includes but is not limited to transferring data to and from the 80331 Memory Controller (MCU), and from the Peripheral Bus Interface (PBI) to the MCU.

Both the PCI interface and the internal bus interface support large burst lengths up to 4 KBytes.

The channel programming interface is accessible from the internal bus through a memory-mapped register interface. Each channel is programmed independently and has its own set of registers. A normal DMA transfer is configured by writing the source address, destination address, number of bytes to transfer, and various control information into a chain descriptor in 80331 local memory. Chain descriptors are described in detail in Section 6.3.



Each channel supports chaining. Chain descriptors that describe one DMA transfer each can be linked together in 80331 local memory to form a linked list. Each chain descriptor contains all the necessary information for transferring a block of data in addition to a pointer to the next chain descriptor. The end of the chain is indicated when the pointer is zero.

Each channel contains a hardware data alignment unit. This unit enables data transfers from or to unaligned addresses in either the PCI address space or the I/O processor local address space. All combinations of unaligned data are supported with the data alignment unit.

Each channel includes a CRC Engine to calculate the CRC-32C algorithm on the data stream being transferred. The CRC engine also initiates the read of a CRC seed and the subsequent write back of the 32-bit result to a CRC Address specified in the descriptor. In addition, a Transfer Complete status bit is updated to the descriptor in memory.



# 6.3 DMA Transfer

A DMA transfer is a block move of data from one memory address space to another. DMA transfers are configured and initiated through a set of memory-mapped registers and one or more chain descriptors located in local memory. A DMA transfer is defined by the source address, destination address, number of bytes to transfer, and control values. These values are loaded into the chain descriptor before a DMA transfer begins. On the 80331 internal bus, the DMA controller attempts all transactions as 64-bit transfers.

#### Table 186. DMA Registers

| Register                           | Abbreviation | Description                                    |  |  |
|------------------------------------|--------------|------------------------------------------------|--|--|
| Channel Control Register x         | CCRx         | Channel Control Word                           |  |  |
| Channel Status Register x          | CSRx         | Channel Status Word                            |  |  |
| Descriptor Address Register x      | DARx         | Address of Current Chain Descriptor            |  |  |
| Next Descriptor Address Register x | NDARx        | Address of Next Chain Descriptor               |  |  |
| PCI Address Register x             | PADRx        | Lower 32-bit PCI Address of Source/Destination |  |  |
| PCI Upper Address Register x       | PUADRx       | Upper 32-bit PCI Address of Source/Destination |  |  |
| Local Address Register x           | LADRx        | Local Address of Source/Destination            |  |  |
| Byte Count Register x              | BCRx         | Number of Bytes to transfer                    |  |  |
| Descriptor Control Register x      | DCRx         | Chain Descriptor Control Word                  |  |  |



# 6.3.1 Chain Descriptors

All DMA transfers are controlled by chain descriptors located in local memory. A chain descriptor contains necessary information to complete one data transfer. A single DMA transfer has only one chain descriptor in memory. Chain descriptors can be linked together to form more complex DMA operations. To perform a DMA transfer, one or more chain descriptors must first be written to local memory. Every descriptor requires seven contiguous words in local memory and is required to be aligned on an 8-word boundary. When CRC is not enabled, this word is ignored. It is still read, but does not have any effect. Each word in the chain descriptor is analogous to control register values. Bit definitions for words in the chain descriptor are the same as for the DMA control registers.

#### Warning:

Chain descriptors can only be located in DDR SDRAM memory in order for the DMA to function properly. Location of the chain descriptors anywhere else (e.g., either on the Peripheral Bus or on PCI) is not supported and the results would be unpredictable.

Figure 28 shows the format of an individual chain descriptor.

- First word is 80331 memory address of the next chain descriptor. A value of "0" specifies the end
  of chain. This value is loaded into the Next Descriptor Address Register. Because chain descriptors
  are aligned on an 8-word boundary, the channel may ignore bits 04:00 of this address.
- Second word is lower 32-bit PCI source/destination address. This address is generated on the PCI bus. This value is loaded into the PCI Address Register.
- Third word is upper 32-bit PCI source/destination address, when needed. When non-zero, this
  address is used during Dual Address Cycles for driving 64-bit PCI addresses. When zero, Single
  Address Cycles are used for driving 32-bit PCI addresses. This value is loaded into the PCI Upper
  Address Register.
- Fourth word is internal bus source/destination address. This address is driven on the internal bus. This value is loaded into the Intel<sup>®</sup> XScale<sup>™</sup>(ARM\* architecture compliant) Local Address Register.
- Fifth word is Byte Count value. This value determines the number of bytes to transfer. This value is loaded into the Byte Count Register.
- Sixth word is Descriptor Control word. This word configures the DMA channel for one DMA transfer. It contains the PCI transaction type, which determines the direction of the data transfer. This value is loaded into the Descriptor Control Register.
- Seventh word is CRC Address word. This address is used to load a 32-bit value to seed the CRC calculation (when enabled). Also, this address is used as the destination for the write back of the CRC result.

There are no data alignment requirements for either the PCI address or the internal bus address.

Refer to Section 6.14 for additional descriptions about the DMA Controller registers



#### Figure 28. DMA Chain Descriptor

#### **Normal Chain Descriptor in Memory Description** Next Descriptor Address [NDA] Address of Next Chain Descriptor PCI Address (31:0) [PAD] Lower 32-bit PCI Source/Destination Address PCI Upper Address (63:32) [PUAD] Upper 32-bit PCI Source/Destination Address Local Address [LAD] Local Source/Destination Address Byte Count [BC] Number of Bytes to Transfer Descriptor Control [DC] **Descriptor Control** CRC Address [CAD] **CRC** Address A9082-01

352 October, 2003 **Document Number: 273942-002** 



# 6.3.2 Chaining DMA Descriptors

A series of chain descriptors can be built in local memory to transfer data between the PCI bus and the internal bus. For example, the application can build multiple chain descriptors to transfer many blocks of data which have different source addresses within the local memory. When multiple chain descriptors are built in 80331 local memory, the application can link each of these chain descriptors using the Next Descriptor Address in the chain descriptor. This address logically links chain descriptors together. This allows the application to build a list of DMA transfers which may not require the Intel<sup>®</sup> XScale<sup>™</sup> core until all DMA transfers are complete. Figure 29 shows a list of DMA transfers built in local memory and how they are linked.

Figure 29. DMA Chaining Operation





# **6.3.3** Initiating DMA Transfers

A DMA transfer is started by building one or more chain descriptors in 80331 local memory. Each chain descriptor takes the form shown in Figure 28. The chain descriptors are required to be aligned on an 8-word boundary in the 80331 local memory.

The following describes the steps for initiating a new DMA transfer:

- 1. In order to begin the processing of a new chain of DMA transfers, the channel must be inactive. This can be checked by software by reading the *Channel Active* bit in the Channel Status Register (CSR). When this bit is clear, the channel is inactive. When this bit is set, the channel is currently active with a DMA transfer.
- 2. The CSR must be cleared of all error conditions.
- 3. The software writes the address of the first chain descriptor to the Next Descriptor Address Register.
- 4. The software sets the *Channel Enable* bit in the Channel Control Register (CCR). Since this is the start of a new DMA transfer and not the resumption of a previous transfer, the *Chain Resume* bit in the CCR should be clear.
- 5. The channel starts the DMA transfer by reading the chain descriptor at the address contained in the Next Descriptor Address Register. The channel loads the chain descriptor values into the channel control registers and begins data transfer. The Descriptor Address Register now contains the address of the chain descriptor just read and the Next Descriptor Address Register now contains the Next Descriptor Address from the chain descriptor just read.

The last descriptor in the DMA chain list has zero in the next descriptor address field specifying the last chain descriptor. The NULL value notifies the DMA channel not to read additional chain descriptors from memory.

Once a DMA transfer is active, it may be temporarily suspended by clearing the *Channel Enable* bit in the CCR. Note that this does not abort the DMA transfer. The channel resumes the DMA transfer when the *Channel Enable* bit is set.

When descriptors are read from local memory, bus latency and memory speed affect chaining latency. Chaining latency is defined as the time required for the channel to access the next chain descriptor plus the time required to set up for the next DMA transfer.

See Section 6.9 for a state diagram of the channel programming model.



#### 6.3.4 Scatter Gather DMA Transfers

The DMA Controller can be used to perform typical scatter gather data transfers. This consists of programming the chain descriptors to gather the data which may be located in non-contiguous blocks of memory. The chain descriptor specifies the destination location such that once all data has been transferred, the data is contiguous in memory. Figure 30 shows how the destination pointers can gather data.

#### Figure 30. Example of Gather Chaining





# 6.3.5 Synchronizing a Program to Chained Transfers

Chained DMA transfers can be synchronized to a program executing on the  $Intel^{\text{®}}$  XScale  $^{\text{TM}}$  Core through the use of processor interrupts. The channel generates an interrupt to the  $Intel^{\text{®}}$  XScale  $^{\text{TM}}$  Core under certain conditions. They are:

- 1. [Interrupt and Continue] The channel completes the data transfer for a chain descriptor and the Next Descriptor Address Register is non-zero. When the *Interrupt Enable* bit within the Descriptor Control Register is set, an interrupt is generated to the Intel<sup>®</sup> XScale<sup>™</sup> Core. This interrupt is for synchronization purposes only. The channel sets the *End Of Transfer Interrupt* flag in the Channel Status Register. Since it is not the last chain descriptor in the list, the DMA channel starts to process the next chain descriptor without requiring any processor interaction.
- 2. [End of Chain] The DMA channel completes the data transfer for a DMA chain descriptor and the Next Descriptor Address Register is zero, and the chain resume bit is clear, specifying the end of the chain. When the *Interrupt Enable* bit within the Descriptor Control Register is set, an interrupt is generated to the Intel<sup>®</sup> XScale<sup>™</sup> core. The channel sets the *End Of Chain Interrupt* flag in the Channel Status Register.
- 3. [Error] An error condition occurs (refer to Section 6.12 for DMA error conditions) during a DMA transfer. The DMA channel halts operation on the current chain descriptor and not proceed to the next chain descriptor.

Each chain descriptor can independently set the *Interrupt Enable* bit in the Descriptor Control word. This bit enables an independent channel interrupt upon completion of the data transfer for the chain descriptor. This bit can be set or clear within each chain descriptor. Control of interrupt generation within each descriptor aids in synchronization of the executing software with DMA transfers.

Figure 31 shows two examples of program synchronization. The left shows program synchronization based on individual chain descriptors. Descriptor 1A generated an interrupt to the processor, while descriptor 2A did not because the *Interrupt Enable* bit was clear. The last descriptor nA, generated an interrupt to signify the end of the chain has been reached. The right shows an example where the interrupt was generated only on the last descriptor signifying the end of chain.

Figure 31. Synchronizing to Chained Transfers





# 6.3.6 Appending to The End of a Chain

Once a channel has started processing a chain of DMA descriptors, the application software may need to append a chain descriptor to the current chain without interrupting the transfer in progress. This action is controlled by the Channel Control Register *Chain Resume* bit.

The channel reads the subsequent chain descriptor each time the channel completes the current chain descriptor and the Next Descriptor Address Register is non-zero. The Next Descriptor Address Register always contains the address of the next chain descriptor to be read and the Descriptor Address Register always contains the address of the current chain descriptor.

The procedure for appending chains requires the software to find the last chain descriptor in the current chain and change the Next Descriptor Address in that descriptor to the address of the new chain to be appended. The software then sets the *Chain Resume* bit in the Channel Control Register for the channel. It does not matter when the channel is active or not.

The channel examines the *Chain Resume* bit of the CCR when the channel is idle or upon completion of a chain of DMA transfers. When this bit is set, the channel re-reads the Next Descriptor Address of the current chain descriptor and load it into the Next Descriptor Address Register. The address of the current chain descriptor is contained in the Descriptor Address Register. The channel clears the *Chain Resume* bit and then examine the Next Descriptor Address Register. When the Next Descriptor Address Register is not zero, the channel reads the chain descriptor using this new address and begin a new DMA transfer. When the Next Descriptor Address Register is zero, the channel remains or return to idle and set the end of chain and generates an interrupt when enabled.

#### There are three cases to consider:

- 1. The channel completes a DMA transfer and it is not the last descriptor in the chain. In this case, the channel clears the *Chain Resume* bit and reads the next chain descriptor. The appended descriptor is read when the channel reaches the end of the original chain.
- 2. The channel completes a DMA transfer and it is the last descriptor in the chain. In this case, the channel examines the state of the *Chain Resume* bit. When the bit is set, the channel re-reads the current descriptor to get the address of the appended chain descriptor. When the bit is clear, the channel returns to idle.
- 3. The channel is idle. In this case, the channel examines the state of the *Chain Resume* bit when the CCR is written. When the bit is set, the channel re-reads the last descriptor from the most-recent chain to get the appended chain descriptor.



#### 6.4 Data Transfers

The 80331 DMA controller is optimized to perform data transfers between the PCI bus and local memory, and between the local memory and the local memory. These transfers are summarized in the following sections.

# 6.4.1 PCI-to-Local Memory Transfers

PCI-to-Local memory transfers perform read cycles on the PCI bus and place the data into the DMA channel queues. Once data is placed into the queue, the internal bus interface of the DMA channel requests the internal bus and drain the queue by writing the data to the local memory.

DMA Internal Bus transactions that are destined for the external PCI Bus are automatically forwarded through the Outbound ATU to the PCI bus. In this way, the PCI direct addressing programming model defined for the DMA descriptors is preserved.

The DMA controller attempts to perform a memory write on the internal bus once the DMA queue has 1K Bytes of data or the Internal Bus transaction has disconnected. The byte count is set to the full byte count of the DMA and the byte count modified bit is set to 0 for memory write transactions on the internal bus. The write transaction continues on the internal bus until the byte count is satisfied, latency timer expires and GNT# is deasserted, or the target initiates a disconnect at an ADB. When the transaction is not complete the DMA restarts a memory write using the modified byte count, the starting address, and the same sequence ID to complete the write sequence.

**Note:** The Maximum Read Burst size of the DMA on the PCI bus can be throttled in the ATU by bits 3:2 of the PCIXCMD register (see Section 3.10.60, "PCI-X Command Register - PX\_CMD" on page 278). The maximum burst length supported by the DMA is 1 Kbytes.

# 6.4.2 Local Memory to PCI Transfers

Local memory to PCI transfers perform read cycles on the internal bus and place the data into the DMA channel queues. The DMA queue size is 1 Kbyte, thus when the byte count of the descriptor is greater than 1 Kbyte then the DMA is completed in bursts with maximum burst size of 1 Kbyte. Otherwise, the full byte count is used for the byte count. Once data is placed into the queue, the DMA channel requests the internal bus and then drain the queue by writing the data to the PCI bus through the ATU.

DMA Internal Bus transactions that are destined for the external PCI Bus are automatically forwarded through the Outbound ATU to the PCI bus. In this way, the PCI direct addressing programming model defined for the DMA descriptors is preserved.

When operating in PCI mode depending on the Internal Bus transaction's byte count and starting address, the ATU selects between two PCI write command types: Memory Write and Memory Write and Invalidate.

In PCI-X mode, the ATU uses the Memory Write Block command, exclusively.

358 October, 2003 **Document Number: 273942-002** 



# 6.4.3 Local Memory to Local Memory DMA

When bit 6 of the DCR is set, the DMA functions as a Local Memory to Local Memory DMA engine. The transfer takes place from the range of 32 bit addresses defined by the PADR (PCI Address Register -- Lower 32 bits) and the byte count to the range of addresses defined by the LADR (Local Address Register) and the byte count.

Local Memory to Local Memory transfers perform read cycles on the internal bus using PADR based addresses and place the data into the DMA channel queues. The maximum byte count for a DMA transaction is 1 Kbyte, thus when the byte count of the descriptor is greater than 1 Kbyte then the byte count is set to 1 Kbyte. Otherwise, the full byte count is used for the byte count. Once data is placed into the queue, the DMA channel requests the internal bus and then drain the queue by writing the data to the Internal Bus using LADR based addresses.

Local Memory to Local Memory transfers utilizes the Memory Read Block (MRB) and Memory Write Block (MWB) commands on the Internal Bus.

**Note:** Since the Internal Bus only supports 32 bit addressing, the PCI Upper Address Register (PUADR) is ignored. Because data transfers only occur in one direction in this mode, the command field (bits 3 to 0) of the DCR are also ignored.

#### 6.4.4 Exclusive Access

The DMA Controller does not support exclusive access through the PCI LOCK# signal.

# 6.5 Data Queues

DMA Ch-0 and Ch-1 each contain three 1 Kbyte, data buffers. These queues temporarily hold data to increase performance of data transfers in both directions.



# 6.6 Data Alignment

Each channel contains a hardware data alignment unit to support unaligned data transfers between the source and destination busses. The data alignment unit optimizes data transfers to and from 32 and 64-bit memory. The channel reformats data words for the correct bus data width.

Aligned data transfers involve data accesses that fall on natural boundaries. For example; double words are aligned on 8-byte boundaries and words are aligned on 4-byte boundaries. DMA transfers can occur with both the source and destination addresses unaligned.

# 6.6.1 64-bit Unaligned Data Transfers

Figure 32 illustrates a DMA transfer between unaligned 64-bit source and destination addresses.

Figure 32. Optimization of an Unaligned DMA



361



# 6.6.2 64/32-bit Unaligned Data Transfers

Figure 33 illustrates a DMA transfer between an unaligned 32-bit source address and an unaligned 64-bit destination address.

Figure 33. Optimization of an Unaligned DMA





#### 6.7 CRC Generation

When enabled, the DMA generates a 32-bit CRC based on the programmed data stream and a 32-bit seed. The CRC engine uses the CRC-32C algorithm required by the iSCSI\* Specification.

### 6.7.1 CRC Mode Configuration and Operation

In addition to the normal DMA Descriptor configuration, the following additional steps are required to configure the CRC engine:

- 1. When writing out the descriptor, bit 8 of the DC is set to enable CRC generation.
- 2. Word 7 of the descriptor is written with the CRC Address.

When a descriptor is configured to generate CRC, the DMA performs the following steps in addition to the Data Transfer:

- Prior to the start of the Data Transfer, the DMA loads the 32-bit seed value from the CRC Address.
- 2. The DMA accumulates the 32-bit CRC as the Data Transfer is occurring. Specifically, the CRC Value is recirculated through the CRC-32C algorithm using the previous CRC Value and the most recent data transferring through the DMA.
  - a. CRC Value (n) = CRC-32C (CRC Value (n-1), Data(n)).
- 3. Following the completion of the Data Transfer, the DMA writes the CRC Value to the CRC Address.
- 4. Finally, the DMA writes the Descriptor Control Register back to the descriptor with the Transfer Complete bit set.

*Note:* DCR bit 7 may be used to disable the Data Transfer during a CRC calculation. This provides the ability to generate CRC on a source data block without writing a destination data block.

**Note:** DCR bit 9 is used to enable chaining of descriptors to calculate CRC across fragmented data source. Bit is clear for first descriptor of chain, then set for subsequent descriptors in the chain for the complete data.

# 6.7.2 CRC-32C Algorithm

The CRC Engine generates a 32-bit CRC of the programmed data stream using the CRC-32C generator polynomial required by the iSCSI\* Specification, (11EDC6F41).

#### Figure 34. CRC-32C Generator Polynomial

$${{1 + x^6 + x^8 + x^9 + x^{10} + x^{11} + x^{13} + x^{14} + x^{18} + x^{19} + x^{20} + x^{22} + x^{23} + x^{25} + x^{26} + x^{27} + x^{28} + x^{32}}$$

Document Number: 273942-002

**Note:** The seed value located at the CRC Address (CAD) must be all 1s (FFFF FFFFh) to generate an iSCSI\* compatible CRC-32C.



# 6.8 Channel Priority

The Intel<sup>®</sup> XScale<sup>™</sup> core internal bus arbitration logic determines which internal bus master has access to the internal bus. Each DMA channel has an independent bus Request/Grant signal pair to the internal bus arbitration. Chapter 12, "Intel<sup>®</sup> 80331 I/O Processor Arbitration Unit" further describes the priority scheme between all the bus masters on the internal bus. Also described is the priority mechanism used between the two DMA channels.

In addition, the internal bus arbitration unit has a Multi-Transaction timer (Section 12.4.3, "Multi-Transaction Timer Register 2 - MTTR2" on page 626) that affects the throughput of a DMA channel. The default value for MTT2 of 152 clocks was chosen to ensure that once an internal bus agent (in this case a DMA channel) is granted the internal bus that it is guaranteed an opportunity to burst data into DDR SDRAM memory. However, when the bus is busy the DMA channel loses grant before the burst is completed. This means that the DMA channel is able to complete only one burst for each arbitration cycle.

Alternatively, the user may wish to increase the value of MTT2 to guarantee that two or more bursts is able to complete within an arbitration cycle.

For example, assuming 1 Kbyte bursts and a 64-bit memory subsystem, an MTT2 setting of 192 clocks would be sufficient to support two 1 Kbyte bursts for a given DMA channel in a single arbitration cycle.

Warning:

Increasing the MTT2 value may also increase the latency to memory for the Intel<sup>®</sup> XScale<sup>™</sup> core on the average. Before changing the MTT2 value, it's imperative that the overall impact to the performance of the application is considered.



# 6.9 Programming Model State Diagram

The channel programming model diagram is shown in Figure 35. Error condition states are not shown.

Figure 35. DMA Programming Model State Diagram





# 6.10 DMA Channel Programming Examples

The software for the DMA channels falls into the following categories:

- · Channel initialization
- Start DMA transfer
- Suspend channel

Examples for each of the software is shown in the following sections as pseudo code flow.

#### 6.10.1 Software DMA Controller Initialization

The DMA Controller is designed to have independent control of the interrupts, enables, and control. The initialization consists of virtually no overhead as shown in Figure 36.

#### Figure 36. Software Example for Channel Initialization

```
CCR0 = 0x0000 0000 ; Disable channel
Call setup_channel
```

#### 6.10.2 Software Start DMA Transfer

The DMA channel control register provides independent control per channel. This provides the greatest flexibility to the applications programmer. The example shown in Figure 38 describes the pseudo code for starting a DMA transfer on channel 0.

#### Figure 37. Software Example for PCI-to-Local DMA Transfer

```
; Set up descriptor in local memory at address d
d.nad = 0
                 ; No chaining
d.pad = 0x0000F0000; Source address of 0000F000H
d.puad = 0
           ; DAC is not used
d.lad = 0xB0000000; Destination address B0000000H
d.bc = 64 ; byte count of 64
d.dc = 0x0000001E ; PCI Memory Read Block command
                  ; Interrupt processor after transfer
; Check for inactive channel & no interrupts pending
if (CSR0 != 0) exit; If channel is not ready, exit
; Start transfer
NDAR0 = &d
                  ; Set up descriptor address
CCR0 = 0x00000001 ; Set Channel Enable bit to start
```

#### Figure 38. Software Example for Local Memory-to-Local Memory DMA Transfer

```
; Set up descriptor in local memory at address d
d.nad = 0
                 ; No chaining
d.pad = 0x0000F000; Source address of 0000F000H
d.puad = 0 ; DAC is not used
d.lad = 0xB00000000; Destination address B0000000H
d.bc = 64
                 ; byte count of 64
d.dc = 0x0000005E ; Memory Read Block command, Memory-to-Memory DMA Enabled
                  ; Interrupt processor after transfer
; Check for inactive channel & no interrupts pending
if (CSR0 != 0) exit; If channel is not ready, exit
; Start transfer
NDAR0 = &d
                  ; Set up descriptor address
CCR0 = 0x00000001 ; Set Channel Enable bit to start
```



# 6.10.3 Software Suspend Channel

The channel may need to be suspended for various reasons. The channel provides the ability to suspend the state of the channel without losing the current status. The channel resumes DMA operation without requiring the software to save the channel configuration. The example shown in Figure 39 describes the pseudo code for suspending channel 0.

#### Figure 39. Software Example for Channel Suspend

```
CCR0 = 0x0000 0000 ; Suspend Channel 0
   Channel suspended....

CCR0 = 0x0000 0001 ; Resume Channel 0
```



# 6.11 Interrupts

Each channel can generate an interrupt to the Intel<sup>®</sup> XScale<sup>™</sup> core. The *Interrupt Enable* bit in the Descriptor Control Register (DCR) determines whether the channel generates an interrupt upon successful error-free completion of a DMA transfer. Error conditions described in Section 6.12 also generate an interrupt. Each channel has one interrupt output connected to the PCI and Peripheral Interrupt Controller described in Chapter 15, "Interrupt Controller Unit" summarizes the status flags and conditions when interrupts are generated in the Channel Status Register (CSRx).

Table 187. DMA Interrupt Summary

|                                                                              | Channel Status Register (CSR) Flags |                 |              |                  |                  |                           | Interrupt<br>Generated? |                   |                    |
|------------------------------------------------------------------------------|-------------------------------------|-----------------|--------------|------------------|------------------|---------------------------|-------------------------|-------------------|--------------------|
| Interrupt<br>Condition                                                       | Active                              | End of Transfer | End of Chain | PCI Master Abort | PCI Target Abort | Unknown Split Transaction | Internal Bus Error      | Interrupt Enabled | Interrupt Disabled |
| Byte count == 0 &&<br>(NDARx != NULL   <br>Resume == 1)<br>(End of Transfer) | 1                                   | 1               | 0            | 0                | 0                | 0                         | 0                       | Y                 | N                  |
| Byte Count == 0 && NDARx == NULL (End of Chain) & resume == 0                | 0                                   | 0               | 1            | 0                | 0                | 0                         | 0                       | Y                 | N                  |
| PCI Master-Abort                                                             | 0                                   | 0               | 0            | 1                | 0                | 0                         | 0                       | Υ                 | Y                  |
| PCI Target-Abort                                                             | 0                                   | 0               | 0            | 0                | 1                | 0                         | 0                       | Υ                 | Y                  |
| Unknown Split<br>Transaction Error                                           | 0                                   | 0               | 0            | 0                | 0                | 1                         | 0                       | Y                 | Y                  |
| Internal Bus Error                                                           | 0                                   | 0               | 0            | 0                | 0                | 0                         | 1                       | Υ                 | Y                  |

Note: End-of-Transfer and End-of-Chain flags is set only when interrupt is enabled. Otherwise, the above flags are always set to 0. End-of-Transfer Interrupt and End-of-Chain Interrupt can only be reported in the CSR when the DMA transfer completed without any reportable errors. The channel shall never report an End-of-Transfer interrupt or End-of-Chain interrupt along with any PCI error conditions. Multiple error conditions may occur and be reported together. Also, because the channel does not stop after reporting the End-of-Transfer Interrupt, internal bus errors may occur before the End-of-Transfer interrupt is acknowledged and cleared.



#### 6.12 Error Conditions

There are four error conditions that may occur during a DMA transfer that are recorded by the channel. All error conditions are reported by setting the appropriate bit in the Channel Status Register (CSR).

The possible error conditions are:

- PCI Master-Abort
- PCI Target-Abort
- Unknown PCI-X Split Transaction Error
- Internal Bus Errors

#### 6.12.1 PCI Errors

- When a PCI Master-Abort occurs during a PCI-to-Local DMA transfer, the channel sets bit 3 in the CSR. Refer to Section 3.7, "ATU Error Conditions" on page 174 for complete details on the ATU error response.
- When a PCI Target-Abort occurs during a PCI-to-Local DMA transfer, the channel sets bit 2 in the CSR. The ATU also records this PCI Bus error condition by setting the appropriate bit in its' status register. Refer to Section 3.7, "ATU Error Conditions" on page 174 for complete details on the ATU error response.
- When an Unknown PCI-X Split transaction error occurs during a PCI-to-Local DMA transfer, the channel sets bit 1 in the CSR. For PCI parity errors, data with incorrect parity is never transferred to the DMA. Refer to Section 3.7, "ATU Error Conditions" on page 174 for complete details on the ATU error response.

Note: Errors (including address/data parity errors) that occur on the PCI bus during Local-to-PCI or PCI-to-Local transfers is logged by the ATU. Refer to Chapter 3, "Address Translation Unit" for complete details.

368 October, 2003 **Document Number: 273942-002** 



#### 6.12.2 Internal Bus Errors

- When a Master-Abort occurs during a read of the Chain Descriptor or Next Descriptor Address, the channel sets the Internal Bus Master-abort error flag which is bit 5 in the CSR. Then, the channel loads the registers (when possible) and stop.
- When a Master-Abort occurs during a data transfer, the channel sets the Internal Bus Master-abort error flag which is bit 5 in the CSR. Then, the channel stops operation.
- When a Target-Abort occurs, the DMA stops operation, but the error is recorded by the MCU.

When an error condition occurs, the actions taken are detailed below:

- The channel shall cease data transfers for the current chain descriptor and clear the *Channel Active* flag in the CSR.
- The channel invalidates any data held in the queue and not read any new chain descriptors.
- The channel sets the appropriate error flag in the Channel Status Register. For example; when a PCI Master-Abort occurred during a DMA transfer, the channel sets bit 3 in the CSR.
- The channel also signals an interrupt to the  $Intel^{\mathbb{B}}$  XScale  $^{^{TM}}$  core.
- The channel does not restart a DMA transfer after any error condition. It is the responsibility of the application software to configure the channel to complete any remaining transfers.

**Note:** Internal Bus errors (**Target-abort only**) that occur while a DMA channel is the master on the Internal Bus are recorded by the MCU and interrupt the core. For correct operation of the DMA channel, user software has to disable the channel before clearing the error condition. Further, the channel needs to be re-enabled by writing a 1 to the CCR channel enable before initiating a new operation.



# 6.13 Power-up/Default Status

Upon power-up, an external hardware reset, the DMA Registers is initialized to their default values.

# 6.14 Register Definitions

The DMA controller contains registers for controlling each channel. Each channel has nine memory-mapped control registers for independent operation. In register titles, x is 0 or 1 for channel 0 or 1, respectively.

There is read/write access only to the Channel Control Register, Channel Status Register, and the Next Descriptor Address Register. The remaining registers are read-only and are loaded with new values from the chain descriptor whenever the channel reads a chain descriptor from memory.

#### Table 188. DMA Controller Unit Registers

| Section, Register Name, Acronym, Page                                    |
|--------------------------------------------------------------------------|
| Section 6.14.1, "Channel Control Register x - CCRx" on page 371          |
| Section 6.14.2, "Channel Status Register x - CSRx" on page 372           |
| Section 6.14.4, "Next Descriptor Address Register x - NDARs" on page 374 |
| Section 6.14.3, "Descriptor Address Register x - DARx" on page 373       |
| Section 6.14.8, "Byte Count Register x - BCRx" on page 378               |
| Section 6.14.5, "PCI Address Register x - PADRx" on page 375             |
| Section 6.14.6, "PCI Upper Address Register x - PUADRx" on page 376      |
| Section 6.14.7, "Local Address Register x - LADRx" on page 377           |
| Section 6.14.9, "Descriptor Control Register x - DCRx" on page 379       |



### 6.14.1 Channel Control Register x - CCRx

The Channel Control Register (CCRx) specifies parameters that dictate the overall channel operating environment. The CCRx should be initialized prior to any other DMA register following a system reset. Figure 29 shows the register format for the CCRx. This register can be read or written while the DMA channel is active.

Table 189. Channel Control Register x - CCRx





# 6.14.2 Channel Status Register x - CSRx

The Channel Status Register (CSRx) contains status flags that indicate the channel status. This register is typically read by software to examine the source of an interrupt. See Section 6.12 for a description of the error conditions that are reported in the CSRx. See Section 6.11 for a description of interrupts caused by the DMA channel.

When a DMA error occurs, application software must check the status of the Channel Active flag before processing the interrupt. It is possible that the channel may still be active completing outstanding PCI transactions.

Table 190. Channel Status Register x - CSRx





# 6.14.3 Descriptor Address Register x - DARx

The Descriptor Address Register (DARx) contains the address of the current chain descriptor in 80331 local memory for a DMA transfer. This register is read-only and is loaded when a new chain descriptor is read. Table 191 depicts the Descriptor Address Register.

All chain descriptors are aligned on an eight DWORD boundary.

Table 191. Descriptor Address Register x - DARx





# 6.14.4 Next Descriptor Address Register x - NDARs

The Next Descriptor Address Register (NDARx) contains the address of the next chain descriptor in 80331 local memory for a DMA transfer. When starting a DMA transfer, this register contains the address of the first chain descriptor. Table 192 depicts the Next Descriptor Address Register.

All chain descriptors are required to be aligned on an eight DWORD boundary. The channel may set bits 04:00 to zero when loading this register.

**Note:** The *Channel Enable* bit in the CCRx and the *Channel Active* bit in the CSRx must both be clear prior to writing the Next Descriptor Address Register. Writing a value to this register while the channel is active may result in undefined behavior.

Table 192. Next Descriptor Address Register x - NDARs





# 6.14.5 PCI Address Register x - PADRx

The PCI Address Register (PADRx) contains the 32-bit PCI address for SAC cycles or the lower 32-bit PCI address of a 64-bit PCI address for DAC cycles. This address represents the source or destination of the DMA transfer.

Table 193 shows the PCI Address Register.

The channel uses the full address bus to indicate the starting address. Refer to the *PCI-X Addendum* to the *PCI Local Bus Specification*, Revision 1.0a for additional information.

**Note:** The application programmer must not program the channel to transfer data across a 4 Gbyte boundary (i.e., the lower 32-bit address must not increment past the maximum address of FFFF.FFFFH). The channel does not notify the application of this condition.

Table 193. PCI Address Register x - PADRx





# 6.14.6 PCI Upper Address Register x - PUADRx

The PCI Upper Address Register (PUADRx) contains the upper 32-bits of a 64-bit PCI address. Table 194 shows the register. This register is read-only and is loaded when a chain descriptor is read from memory

Table 194. PCI Upper Address Register x - PU ADRx





# 6.14.7 Local Address Register x - LADRx

The 80331 Local Address Register (LADRx) contains the 32-bit 80331 local address. The 80331 address space is a 32-bit, byte addressable address space. Table 195 shows the Local Address Register. This read-only register is loaded when a chain descriptor is read from memory.

Table 195. Local Address Register x - LADRx





# 6.14.8 Byte Count Register x - BCRx

The Byte Count Register (BCRx) contains the number of bytes to transfer for a DMA transfer. This is a read-only register that is loaded from the Byte Count word in a chain descriptor. It allows for a maximum DMA transfer of 16 Mbytes. A value of zero is a valid byte count and results in no data words being transferred and no cycles generated on either the PCI bus or the internal bus. This register specifies the amount of data that is moved from the source to the destination.

Table 196 shows the Byte Count Register

*Note:* The byte count value is not required to be aligned to a DWORD boundary.

Table 196. Byte Count Register x - BCRx





### 6.14.9 Descriptor Control Register x - DCRx

The Descriptor Control Register (DCRx) contains control values for the DMA transfer on a per-chain descriptor basis. This read-only register is loaded whenever a chain descriptor is read from memory. These values may vary from chain descriptor to chain descriptor. Table 197 shows the definition of the Descriptor Control Register.

Table 197. Descriptor Control Register x - DCRx





#### **6.14.9.1 PCI Transactions Support**

The Memory Write Block Command on the bus in PCI-X mode performs similarly to the PCI Memory Write and Invalidate command and is fully supported by both channels of the DMA controller. Refer to Section 6.4.2, "Local Memory to PCI Transfers" on page 358 for a complete description of the behavior of the DMA channel during this PCI bus cycle.

DMA Internal Bus transactions that are destined for the external PCI Bus are automatically forwarded through the Outbound ATU to the PCI bus. In this way, the backward compatibility with the previous generation programming model defined for the DMA descriptors is preserved.

#### **Table 198.**

| DCR[3:0]         | PCI Conventional Mode                                            | PCI-X Mode                 |  |
|------------------|------------------------------------------------------------------|----------------------------|--|
| 6H, CH, or EH    | MR, MRL, and MRM as appropriate                                  | Memory Read Block is used  |  |
| 7H or FH         | Memory Write and Memory Write Invalidate Command as appropriate. | Memory Write Block is use. |  |
| all other values | Reserved                                                         |                            |  |



# **Application Accelerator Unit**

7

This chapter describes the integrated Application Accelerator (AA) Unit. The operation modes, setup, external interface, and implementation of the AA unit are detailed in this chapter.

### 7.1 Overview

The Application Accelerator provides low-latency, high-throughput data transfer capability between the AA unit and Intel® 80331 I/O processor (80331) local memory. It executes data transfers to and from 80331 local memory, check for all-zero result across local memory blocks, perform memory block fills, and provides the necessary programming interface. The Application Accelerator performs the following functions:

- Transfers data (read) from memory controller.
- Performs an optional boolean operation (XOR) on read data.
- Transfers data (write) to memory controller.
- Check for All-zero result across local memory blocks.
- Perform memory block fills.

#### The AA unit features:

- 1Kbyte/512-byte store queue.
- Utilization of the 80331 memory controller Interface.
- 2<sup>32</sup> addressing range on the 80331 local memory interface.
- Hardware support for unaligned data transfers for the internal bus.
- Fully programmable from the 80331.
- Support for automatic data chaining for gathering and scattering of data blocks.
- Support for writing a constant value to a memory block (block fill).
- Support for writing descriptor status to local memory.



# 7.2 Theory of Operation

The Application Accelerator is a master on the internal bus and performs data transfers to and from local memory. It does not interface to the PCI bus. AA uses direct addressing for memory controller.

The AA implements XOR algorithm in hardware. It performs XOR operation on multiple blocks of source (incoming) data and stores result back in 80331 local memory. The source and destination addresses are specified through chain descriptors resident in 80331 local memory. The AA can also check for all-zero result across local memory blocks or fill a memory block with arbitrary data. Figure 40 shows a block diagram of the AA unit. The AA can also perform memory-to-memory transfers of data blocks controlled by 80331 memory controller unit.

Figure 40. Application Accelerator Block Diagram



The Application Accelerator programming interface is accessible from the internal bus through a memory-mapped register interface. Data for the XOR operation is configured by writing the source addresses, destination address, number of bytes to transfer, and various control information into a chain descriptor in local memory. Chain descriptors are described in detail in Section 7.3.2, "Chain Descriptors" on page 384.

The Application Accelerator unit contains a hardware data packing and unpacking unit. This unit enables data transfers from and to unaligned addresses in 80331 local memory. All combinations of unaligned data are supported with the packing and unpacking unit. Data is held internally in the Application Accelerator until ready to be stored back to local memory. This is done using a 1KByte/512Byte holding queue. Data to be written back to 80331 local memory can either be aligned or unaligned.

Each chain descriptor contains the necessary information for initiating an XOR operation on blocks of data specified by the source addresses. The Application Accelerator unit supports chaining. Chain descriptors that specify the source data to be XORed can be linked together in 80331 local memory to form a linked list.

Similar to XOR operations, AA can be programed to compute parity across multiple memory blocks specified by chain descriptors. In addition, AA can also be used to perform memory block fills.



### 7.3 Hardware-Assist XOR Unit

The Application Accelerator Unit implements the XOR algorithm in hardware. It performs the XOR operation on multiple blocks of source (incoming) data and stores the result back in 80331 local memory.

- The process of reading source data, executing the XOR algorithm, and storing the XOR data hereafter is referred to as *XOR-transfer*.
- The process of reading or writing data hereafter is referred to as data transfer.

The source and destination addresses are specified through chain descriptors resident in 80331 local memory.

#### 7.3.1 Data Transfer

All transfers are configured and initiated through a set of memory-mapped registers and one or more chain descriptors located in local memory. A transfer is defined by the source address, destination address, number of bytes to transfer, and control values. These values are loaded in the chain descriptor before a transfer begins. Table 199 describes the registers that need to be configured for any operation.

#### Table 199. Register Description

| Register                                        | Abbreviation | Description                                                 |
|-------------------------------------------------|--------------|-------------------------------------------------------------|
| Accelerator Control Register                    | ACR          | Application Accelerator Control Word                        |
| Accelerator Status Register                     | ASR          | Application Accelerator Status Word                         |
| Accelerator Descriptor Address Register         | ADAR         | Address of Current Chain Descriptor                         |
| Accelerator Next Descriptor Address<br>Register | ANDAR        | Address of Next Chain Descriptor                            |
| Data / Source Address Register1                 | D/SAR1       | Data to be written or Local memory addresses of source data |
| Source Address Register 28                      | SAR2 SAR32   | Local memory addresses of source data                       |
| Destination Address Register                    | DAR          | Local memory address of destination data                    |
| Accelerator Byte Count Register                 | ABCR         | Number of Bytes to transfer                                 |
| Data Register                                   | DR           | Data to be written to the destination                       |
| Accelerator Descriptor Control Register         | ADCR         | Chain Descriptor Control Word                               |



### 7.3.2 Chain Descriptors

All transfers are controlled by chain descriptors located in local memory. A chain descriptor contains the necessary information to complete one transfer. A single transfer has only one chain descriptor in memory. Chain descriptors can be linked together to form more complex operations.

Warning:

Chain descriptors can only be located in DDR SDRAM memory in order for the AAU to function properly. Location of the chain descriptors anywhere else (e.g., either on the Peripheral Bus or on PCI) is not supported and the results would be unpredictable.

To perform a transfer, one or more chain descriptors must first be written to 80331 local memory. The words of a descriptor are contiguous in local memory. Descriptors can different sizes, each dependent on the number of sources being addressed by the operation. The sizes supported by the Application Accelerator support four, eight, sixteen and thirty-two sources. The alignment of the descriptor in local memory is dependent on the descriptor size and is defined for each in the following sections. Not all sources must be used in a given descriptor.



#### 7.3.2.1 Four-Source Descriptor Format

Figure 41 shows the format of an individual chain descriptor. This four-source descriptor is the smallest supported descriptor. The four-source descriptor requires eight contiguous words in 80331 local memory and is required to be aligned on an 8-word boundary. All eight words are required.

#### Figure 41. Chain Descriptor Format



Each word in the chain descriptor is analogous to control register values. Bit definitions for the words in the chain descriptor are the same as for the control registers.

- First word is local memory address of next chain descriptor. A value of zero specifies the end of the chain. This value is loaded into the Accelerator Next Descriptor Address Register. Because chain descriptors must be aligned on an 8-word boundary, the unit may ignore bits 04:00 of this address.
- Second word is address of the first block of data resident in local memory, or immediate data when
  performing a Memory Block Fill. This value is loaded into the Data / Source Address Register 1.
- Third word is the address of the second block of data resident in local memory. This address is driven on the internal bus. This value is loaded into the Source Address Register 2.
- Fourth word is the address of the third block of data resident in local memory. This address is driven on the internal bus. This value is loaded into the Source Address Register 3.
- Fifth word is the address of the fourth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into the Source Address Register 4.
- Sixth word is the destination address where data is stored in local memory. This address is driven
  on the internal bus. This value is loaded into the Destination Address Register.
- Seventh word is the Byte Count value. This value specifies the number of bytes of data in the current chain descriptor. This value is loaded into the Accelerator Byte Count Register.
- Eighth word is the Descriptor Control Word. This word configures the Application Accelerator for one operation. This value is loaded into the Accelerator Descriptor Control Register.

There are no data alignment requirements for any source addresses or destination address. However, maximum performance is obtained from aligned transfers, especially small transfers. See Section 7.4.

Refer to Section 7.13 for additional description on the control registers.



#### 7.3.2.2 Eight-Source Descriptor Format

To perform an XOR-transfer with up to eight source blocks of data, a special chain descriptor needs to be configured:

- The first part is the four-source descriptor (referred to as the *principal-descriptor*) containing the address of the first 4 source data blocks along with other information.
- The second part (*mini-descriptor*) contains 4, DWORDs containing the address of the additional four (SAR5 SAR8) source data blocks. The mini-descriptor is written to a contiguous address immediately following the principal descriptor.

To perform a transfer, both parts (principal and mini-descriptor) must be written to local memory. Figure 42 shows the format of this eight-source descriptor. The eight-source descriptor requires twelve contiguous words in local memory and is required to be aligned on an 16-word boundary. All twelve words are required.

Figure 42. Chain Descriptor Format for Eight Source Addresses (XOR Function)

| Next Descriptor Address (NDA) | Address of Next Chain Descriptor        |
|-------------------------------|-----------------------------------------|
| Source Address (D/SAR1)       | Source Address for first block of data  |
| Source Address (SAR2)         | Source Address for second block of data |
| Source Address (SAR3)         | Source Address for third block of data  |
| Source Address (SAR4)         | Source Address for fourth block of data |
| Destination Address (DAR)     | Destination Address of XOR-ed data      |
| Byte Count (BC)               | Number of bytes to XOR                  |
| Descriptor Control (DC)       | Descriptor Control                      |
| Source Address (SAR5)         | Source Address for fifth data block     |
| Source Address (SAR6)         | Source Address for sixth data block     |
| Source Address (SAR7)         | Source Address for seventh data block   |
| Source Address (SAR8)         | Source Address for eighth data block    |

- The first eight words are defined in the four-source descriptor definition. See Section 7.3.2.2, "Eight-Source Descriptor Format" for the principal descriptor definition.
- The ninth word (1st word of mini-descriptor) is the address of the fifth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR5.
- The tenth word (2nd word of mini-descriptor) is the address of the sixth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR6.
- The eleventh word (3rd word of mini-descriptor) is the address of the seventh block of data resident in local memory. This address is driven on the internal bus. This value is loaded SAR7.
- The twelfth word (4th word of mini-descriptor) is the address of the eighth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 8.



#### 7.3.2.3 Sixteen-Source Descriptor Format

To perform an XOR-transfer with up to sixteen source blocks of data, a special chain descriptor needs to be configured:

- The first part (*principal-descriptor*) contains the address of the first 4 source data blocks along with other information.
- The second part (*mini-descriptor*) contains four, DWORDs containing the address of the
  additional four (SAR5 SAR8) source data blocks. The mini-descriptor is written to a
  contiguous address immediately following the principal descriptor.
- The third part (*extended-descriptor 0*) contains nine, DWORDs containing the address of the additional eight (SAR9 SAR16) source data blocks and the command/control for these data blocks. The extended-descriptor 0 is written to a contiguous address immediately following the mini descriptor.

To perform a transfer, all three parts (principal descriptor, mini-descriptor and extended-descriptor 0) must be written to local memory. Figure 43 shows the format of this configuration. Every descriptor requires twenty one contiguous words in local memory and is required to be aligned on an 32-word boundary. All twenty one words are required.

Figure 43. Chain Descriptor Format for Sixteen Source Addresses (XOR Function)

| in Descriptor in Intel <sup>®</sup> XScale <sup>™</sup> Core Mem | nory Description                            |
|------------------------------------------------------------------|---------------------------------------------|
| Next Descriptor Address (NDA)                                    | Address of Next Chain Descriptor            |
| Source Address (D/SAR1)                                          | Source Address for first block of data      |
| Source Address (SAR2)                                            | Source Address for second block of data     |
| Source Address (SAR3)                                            | Source Address for third block of data      |
| Source Address (SAR4)                                            | Source Address for fourth block of data     |
| Destination Address (DAR)                                        | Destination Address of XOR-ed data          |
| Byte Count (BC)                                                  | Number of bytes to XOR                      |
| Descriptor Control (DC)                                          | Descriptor Control                          |
| Source Address (SAR5)                                            | Source Address for fifth data block         |
| Source Address (SAR6)                                            | Source Address for sixth data block         |
| Source Address (SAR7)                                            | Source Address for seventh data block       |
| Source Address (SAR8)                                            | Source Address for eighth data block        |
| Extended Descriptor Control 0 (EDC0)                             | Extended Descriptor 0 control               |
| Source Address (SAR9)                                            | Source Address for ninth block of data      |
| Source Address (SAR10)                                           | Source Address for tenth block of data      |
| Source Address (SAR11)                                           | Source Address for eleventh block of data   |
| Source Address (SAR12)                                           | Source Address for twelfth block of data    |
| Source Address (SAR13)                                           | Source Address for thirteenth block of data |
| Source Address (SAR14)                                           | Source Address for fourteenth block of data |
| Source Address (SAR15)                                           | Source Address for fifteenth block of data  |
| Source Address (SAR16)                                           | Source Address for sixteenth block of data  |

# Intel® 80331 I/O Processor Developer's Manual

#### **Application Accelerator Unit**



- The first eight words are defined in the four-source descriptor definition. See Section 7.3.2.1, "Four-Source Descriptor Format" for the principal descriptor definition.
- Words nine through twelve are defined in the eight-source descriptor definition. See Section 7.3.2.1, "Four-Source Descriptor Format" for the principal descriptor definition.
- The thirteenth word (1st word of extended-descriptor 0) is the Extended Descriptor Control Word 0. This word configures the Application Accelerator for one operation. The value is loaded into the Extended Descriptor Control Register 0.
- The fourteenth word (2nd word of extended-descriptor 0) is the address of the ninth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 9.
- The fifteenth word (3rd word of extended-descriptor 0) is the address of the tenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 10.
- The sixteenth word (4th word of extended-descriptor 0) is the address of the eleventh block of
  data resident in local memory. This address is driven on the internal bus. This value is loaded
  into SAR 11.
- The seventeenth word (5th word of extended-descriptor 0) is the address of the twelfth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 12.
- The eighteenth word (6th word of extended-descriptor 0) is the address of the thirteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 13.
- The nineteenth word (7th word of extended-descriptor 0) is the address of the fourteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 14.
- The twentieth word (8th word of extended-descriptor 0) is the address of the fifteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 15.
- The twenty first word (9th word of extended-descriptor 0) is the address of the sixteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 16.



#### 7.3.2.4 Thirty-two-Source Descriptor Format

To perform an XOR-transfer with up to thirty two source blocks of data, a special chain descriptor needs to be configured:

- The first part (*principal-descriptor*) contains the address of the first 4 source data blocks along with other information.
- The second part (*mini-descriptor*) contains four, DWORDs containing the address of the additional four (SAR5 SAR8) source data blocks. The mini-descriptor is written to a contiguous address immediately following the principal descriptor.
- The third part (*extended-descriptor 0*) contains nine, DWORDs containing the address of the additional eight (SAR9 SAR16) source data blocks and the command/control for these data blocks. The extended-descriptor 0 is written to a contiguous address immediately following the mini descriptor.
- The fourth part (*extended-descriptor 1*) contains nine, DWORDs containing the address of the additional eight (SAR17 SAR24) source data blocks and the command/control for these data blocks. The extended-descriptor 1 is written to a contiguous address immediately following extended-descriptor 0.
- The fifth part (*extended-descriptor 2*) contains nine, DWORDs containing the address of the additional eight (SAR25 SAR32) source data blocks and the command/control for these data blocks. The extended-descriptor 2 is written to a contiguous address immediately following extended-descriptor 1.

To perform a transfer, all five parts (principal descriptor, mini-descriptor, extended-descriptor 0, extended-descriptor 1, and extended-descriptor 2) must be written to local memory. Figure 44 shows the format of this configuration. The full descriptor requires thirty nine contiguous words in local memory and is required to be aligned on an 64-word boundary. All thirty nine words are required.



Figure 44. Chain Descriptor Format for Thirty Two Source Addresses (XOR Function)

| n Descriptor in I/O Processor Memory          | Description                                                                                  |
|-----------------------------------------------|----------------------------------------------------------------------------------------------|
| Next Descriptor Address (NDA)                 | Address of Next Chain Descriptor                                                             |
| Source Address (D/SAR1)                       | Source Address for first block of data                                                       |
| Source Address (SAR2)                         | Source Address for second block of data                                                      |
| Source Address (SAR3)                         | Source Address for third block of data                                                       |
| Source Address (SAR4)                         | Source Address for fourth block of data                                                      |
| Destination Address (DAR)                     | Destination Address of XOR-ed data                                                           |
| Byte Count (BC)                               | Number of bytes to XOR                                                                       |
| Descriptor Control (DC)                       | Descriptor Control                                                                           |
| Source Address (SAR5)                         | Source Address for fifth data block                                                          |
| Source Address (SAR6)                         | Source Address for sixth data block                                                          |
| Source Address (SAR7)                         | Source Address for seventh data block                                                        |
| Source Address (SAR8)                         | Source Address for eighth data block                                                         |
| xtended Descriptor Control 0 (EDC0)           | Extended Descriptor 0 control                                                                |
| Source Address (SAR9)                         | Source Address for ninth block of data                                                       |
| Source Address (SAR10)                        | Source Address for tenth block of data                                                       |
| Source Address (SAR11)                        | Source Address for eleventh block of data                                                    |
| Source Address (SAR12)                        | Source Address for twelfth block of data                                                     |
| Source Address (SAR13)                        | Source Address for thirteenth block of data                                                  |
| Source Address (SAR14)                        | Source Address for fourteenth block of data                                                  |
| Source Address (SAR15)                        | Source Address for fifteenth block of data                                                   |
| Source Address (SAR16)                        | Source Address for sixteenth block of data                                                   |
| Extended Descriptor Control 1 (EDC1)          | Extended Descriptor 1 control                                                                |
| Source Address (SAR17)                        | Source Address for seventeenth block of data                                                 |
| Source Address (SAR18)                        | Source Address for eighteenth block of data                                                  |
| Source Address (SAR19)                        | Source Address for nineteenth block of data                                                  |
| Source Address (SAR20)                        | Source Address for twentieth block of data                                                   |
| Source Address (SAR21)                        | Source Address for twenty first block of data                                                |
| Source Address (SAR22)                        | Source Address for twenty second block of data                                               |
| Source Address (SAR23)                        | Source Address for twenty third block of data                                                |
| Source Address (SAR24)                        | Source Address for twenty fourth block of data                                               |
| Extended Descriptor Control 2 (EDC2)          | Extended Descriptor 2 control                                                                |
| Source Address (SAR25)                        | Source Address for twenty fifth block of data                                                |
| Source Address (SAR26)                        | Source Address for twenty sixth block of data                                                |
| Source Address (SAR27)                        | Source Address for twenty seventh block of data                                              |
| Source Address (SAR28)                        | Source Address for twenty eighth block of data                                               |
| Source Address (SAR29)                        | Source Address for twenty ninth block of data                                                |
| Source Address (SAR30)                        | Source Address for thirtieth block of data                                                   |
| Source Address (SAR31) Source Address (SAR32) | Source Address for thirty first block of data Source Address for thirty second block of data |



- The first eight words are defined in the Four-source descriptor definition. See Section 7.3.2.1, "Four-Source Descriptor Format" for the principal descriptor definition.
- Words nine through twelve are defined in the Eight-source descriptor definition. See Section 7.3.2.1, "Four-Source Descriptor Format" for the principal descriptor definition.
- Words thirteen through twenty-one are defined in the Sixteen-source descriptor definition. See Section 7.3.2.3, "Sixteen-Source Descriptor Format" for the principal descriptor definition.
- The twenty second word (1st word of extended-descriptor 1) is the Extended Descriptor Control Word 1. This word configures the Application Accelerator for one operation. The value is loaded into the Extended Descriptor Control Register 1.
- The twenty third word (2nd word of extended-descriptor 1) is the address of the seventeenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR17.
- The twenty fourth word (3rd word of extended-descriptor 1) is the address of the eighteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 18.
- The twenty fifth word (4th word of extended-descriptor 1) is the address of the nineteenth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 19.
- The twenty sixth word (5th word of extended-descriptor 1) is the address of the twentieth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 20.
- The twenty seventh word (6th word of extended-descriptor 1) is the address of the twenty first block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 21.
- The twenty eighth word (7th word of extended-descriptor 1) is the address of the twenty second block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 22.
- The twenty ninth word (8th word of extended-descriptor 1) is the address of the twenty third block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 23.
- The thirtieth word (9th word of extended-descriptor 1) is the address of the twenty fourth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 24.
- The thirty first word (1st word of extended-descriptor 2) is the Extended Descriptor Control Word 2. This word configures the Application Accelerator for one operation. The value is loaded into the Extended Descriptor Control Register 2.
- The thirty second word (2nd word of extended-descriptor 2) is the address of the twenty fifth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 25.
- The thirty third word (3rd word of extended-descriptor 2) is the address of the twenty sixth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 26.
- The thirty fourth word (4th word of extended-descriptor 2) is the address of the twenty seventh block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 27.

#### Intel® 80331 I/O Processor Developer's Manual

#### Application Accelerator Unit



- The thirty fifth word (5th word of extended-descriptor 2) is the address of the twenty eighth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 28.
- The thirty sixth word (6th word of extended-descriptor 2) is the address of the twenty ninth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 29.
- The thirty seventh word (7th word of extended-descriptor 2) is the address of the thirtieth block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 30.
- The thirty eighth word (8th word of extended-descriptor 2) is the address of the thirty first block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 31.
- The thirty ninth word (9th word of extended-descriptor 2) is the address of the thirty second block of data resident in local memory. This address is driven on the internal bus. This value is loaded into SAR 32.

392 October, 2003 **Document Number: 273942-002** 



# 7.3.3 Descriptor Chaining

To perform an AA operation, a series of chain descriptors can be built in local memory to operate on multiple blocks of source data resident in local memory. The result can then be stored back in local memory. An application can build multiple chain descriptors to operate on many blocks of data which have different source addresses within the local memory.

When multiple chain descriptors are built in local memory, the application can link each of these chain descriptors using the Next Descriptor Address in the chain descriptor. This address logically links the chain descriptors together. This allows the application to build a list of transfers which may not require the processor until all transfers are complete. Figure 45 shows an example of a linked-list of transfers using only four-source descriptors specified in external memory.

Figure 45. XOR Chaining Operation





# 7.4 AA Descriptor Processing

An AA operation is initiated by building one or more chain descriptors in Intel<sup>®</sup> XScale<sup>™</sup> core local memory (ARM\* architecture compliant). Figure 46 shows the format of a principal descriptor.

Figure 46. Example of Gather Chaining for Four Source Blocks





The following describes the steps for initiating a new AA operation:

- 1. The AA must be inactive prior to starting an AA operation. This can be checked by software by reading the *Accelerator Active* bit in the Accelerator Status Register. When this bit is clear, the unit is inactive. When this bit is set, the unit is currently active.
- 2. The ASR must be cleared of all error conditions.
- 3. The software writes the address of the first chain descriptor to the Accelerator Next Descriptor Address Register (ANDAR).
- 4. The software sets the *Accelerator Enable* bit in the Accelerator Control Register (ACR). Because this is the start of a new AA operation and not the resumption of a previous operation, the *Chain Resume* bit in the ACR should be clear.
- 5. The AA starts the AA operation by reading the chain descriptor at the address contained in ANDAR. The AA loads the chain descriptor values into the ADAR and begins data transfer. The Accelerator Descriptor Address Register (ADAR) contains the address of the chain descriptor just read and ANDAR now contains the Next Descriptor Address from the chain descriptor just read.

The last descriptor in the AA chain list has zero in the next descriptor address field specifying the last chain descriptor. A NULL value notifies the AA not to read additional chain descriptors from memory.

Once an AA operation is active, it can be temporarily suspended by clearing the *Accelerator Enable* bit in the ACR. Note that this does not abort the AA operation. The unit resumes the process when the *Accelerator Enable* bit is set.

When descriptors are read from external memory, bus latency and memory speed affect chaining latency. Chaining latency is defined as the time required for the AA to access the next chain descriptor plus the time required to set up the next AA operation.



#### 7.4.1 Scatter Gather Transfers

The Application Accelerator can be used to perform typical scatter gather transfers. This consists of programming the chain descriptors to gather data which may be located in non-contiguous blocks of memory. The chain descriptor specifies the destination location such that once all data has been processed, the data is contiguous in memory. Figure 46 shows how the destination pointers can gather data.

### 7.4.2 Synchronizing a Program to Chained Operation

Any operation involving the AA can be synchronized to a program executing on the Intel<sup>®</sup> XScale TM core through the use of processor interrupts. The AA generates an interrupt to the Intel<sup>®</sup> XScale TM core under certain conditions. They are:

- 1. [Interrupt and Continue] The AA completes processing a chain descriptor and the Accelerator Next Descriptor Address Register (ANDAR) is non-zero. When the *Interrupt Enable* bit within the Accelerator Descriptor Control Register (ADCR) is set, an interrupt is generated to the Intel<sup>®</sup> XScale core. This interrupt is for synchronization purposes. The AA sets the *End Of Transfer Interrupt* flag in the Accelerator Status Register (ASR). Since it is not the last chain descriptor in the list, the AA starts to process the next chain descriptor without requiring any processor interaction.
- 2. [End of Chain] The AA completes processing a chain descriptor and the Accelerator Next Descriptor Address Register is zero specifying the end of the chain. When the *Interrupt Enable* bit within the ADCR is set, an interrupt is generated to the Intel<sup>®</sup> XScale <sup>™</sup> core. The AA sets the *End Of Chain Interrupt* flag in the ASR.
- 3. [Error] An error condition occurs (refer to Section 7.11, "Error Conditions" on page 413 for Application Accelerator error conditions) during a transfer. The AA halts operation on the current chain descriptor and not proceed to the next chain descriptor.

Each chain descriptor can independently set the *Interrupt Enable* bit in the Descriptor Control word. This bit enables an independent interrupt once a chain descriptor is processed. This bit can be set or clear within each chain descriptor. Control of interrupt generation within each descriptor aids in synchronization of the executing software with AA operation.

Figure 47 shows two examples of program synchronization. The left column shows program synchronization based on individual chain descriptors. Descriptor 1A generated an interrupt to the processor, while descriptor 2A did not because the *Interrupt Enable* bit was clear. The last



descriptor nA, generated an interrupt to signify the end of the chain has been reached. The right column in Figure 47 shows an example where the interrupt was generated only on the last descriptor signifying the end of chain.

Figure 47. Synchronizing to Chained AA Operation





### 7.4.3 Appending to The End of a Chain

Once the AA has started processing a chain of descriptors, application software may need to append a chain descriptor to the current chain without interrupting the transfer in progress. The mechanism used for performing this action is controlled by the *Chain Resume* bit in the Accelerator Control Register (ACR).

The AA reads the subsequent chain descriptor each time it completes the current chain descriptor and the Accelerator Next Descriptor Address Register (ANDAR) is non-zero. ANDAR always contains the address of the next chain descriptor to be read and the Accelerator Descriptor Address Register (ADAR) always contains the address of the current chain descriptor.

The procedure for appending chains requires the software to find the last chain descriptor in the current chain and change the Next Descriptor Address in that descriptor to the address of the new chain to be appended. The software then sets the *Chain Resume* bit in the ACR. It does not matter when the unit is active or not.

The AA examines the *Chain Resume* bit of the ACR when the unit is idle or upon completion of a chain of transfers. When this bit is set, the AA re-reads the Next Descriptor Address of the current chain descriptor and load it into ANDAR. The address of the current chain descriptor is contained in ADAR. The AA clears the *Chain Resume* bit and then examines ANDAR. When ANDAR is not zero, the AA reads the chain descriptor using this new address and begin a new operation. When ANDAR is zero, the AA remains or return to idle.

#### There are three cases to consider:

- 1. The AA completes an AA operation and it is not the last descriptor in the chain. In this case, the AA clears the *Chain Resume* bit and reads the next chain descriptor. The appended descriptor is read when the AA reaches the end of the original chain.
- 2. The channel completes an AA transfer and it is the last descriptor in the chain. In this case, the AA examines the state of the *Chain Resume* bit. When the bit is set, the AA re-reads the current descriptor to get the address of the appended chain descriptor. When the bit is clear, the AA returns to idle.
- 3. The AA is idle. In this case, the AA examines the state of the *Chain Resume* bit when the ACR is written. When the bit is set, the AA re-reads the last descriptor from the most-recent chain to get the appended chain descriptor.



# 7.5 AA Operations

The AA can be configured on a per descriptor basis through the Descriptor Control Word to perform three distinct operations:

- 1. In an **XOR operation**, the AA generates a parity data stream in local memory that is comprised of the XOR of up to 32 distinct data streams (i.e., SAR1..32) on a per byte basis. All of the source data streams and the parity data stream can be up to 16 MB long.
- 2. Perform a **Memory Block Fil**l of up to 16 MB of local memory with a 32-bit constant (DATA/SAR1).
- 3. With the **Zero Result Buffer Check**, the AA confirms that the XOR of all the bytes of source data results in 00H for the entire bytecount. All the source data streams can be up to 16 MB long. The results of the check is written back to the Descriptor Control Word in local memory.

The following sections describes the three AA operations in detail.

**Document Number: 273942-002** October, 2003 399



### 7.5.1 XOR Operation

Figure 48 describes the XOR algorithm implementation. In this illustrative example, there are four blocks of source data to be XOR-ed. The intermediate result is kept by the store queue in the AA before being written back to local memory. The source data is located at addresses A000 0400H, A000 0800H, A000 0C00H and A000 1000H respectively.

All data transfers needed for this operation are controlled by chain descriptors located in local memory. The Application Accelerator as a master on the internal bus initiates data transfer. The algorithm is implemented such that as data is read from local memory, the boolean unit executes the XOR operation on incoming data.

Figure 48. The Bit-wise XOR Algorithm





Figure 49. Hardware Assist XOR Unit



The XOR algorithm and methodology followed once a chain descriptor has been configured is detailed below:

- 1. The Application Accelerator as a master on the bus initiates data transfer from the address pointed at by the First Source Address Register (SAR1). The total number of bytes to *XOR-transfer* is specified by the Byte Count (BC) field in the chain descriptor.
  - a. When the Direct Fill command is selected for SAR1, this is designated as the first block of data in the current XOR operation, and the data is transferred directly to the store queue. The number of bytes transferred to the store queue is 1KByte/512Bytes.
  - b. When the XOR command is selected for SAR1, the boolean unit performs the XOR operation on the data currently existing in the store queue with the data being transferred from memory (see steps 3-7 for SAR2). This may be done to XOR more than 32 blocks of data together with a byte count of 1KByte or less.

Note: When the Byte Count Register contains a value greater than the buffer size, the AA completes the XOR-transfer operation on the first buffer of data obtained from each Source Register (D/SAR1, SAR2-SAR4), then proceeds with the next buffer of data. This process is repeated until the BCR contains a zero value.

- 2. The Application Accelerator transfers the first eight bytes of data from the address pointed at by the Second Source Address Register (SAR2).
- 3. The boolean unit performs the bit-wise XOR algorithm on the input operands. The input operands are the first eight bytes of data read from D/SAR1 (bytes 1-8) which are stored in the queue and the first eight bytes of data just read from SAR2 (bytes 1-8).
- 4. The XOR-ed result is transferred to the store queue and stored in the first eight bytes (bytes 1-8) overwriting previously stored data.

### Intel® 80331 I/O Processor Developer's Manual

#### **Application Accelerator Unit**



- 5. The Application Accelerator transfers the next eight bytes of data (bytes 9-16) from address pointed at by the Second Source Address Register (SAR2).
- 6. The boolean unit performs the bit-wise XOR algorithm on the input operands. The input operands are the next eight bytes of data read from D/SAR1 (bytes 9-16 stored in the queue) and the eight bytes of data read from SAR2 in Step-5.
- 7. Step-5 and Step-6 (Data transfer and XOR) are repeated until all data pointed at by SAR1 is XOR-ed with the corresponding data pointed at by SAR2. The store queue now contains a buffer full of XOR-ed data, the source addresses for which were specified in SAR1 and SAR2.
- 8. Steps 1-7 are repeated once again. The first input to the XOR unit is the data held in the store queue and the second input is the data pointed at by SAR3.
- 9. The above steps are repeated once more. The first input to the XOR unit is the data held in the store queue and the second input is the data pointed at by SAR4.
- 10. Once Steps 1-9 are completed, the XOR operation is complete for the first full buffer of the current chain descriptor. When the Destination Write Enable Bit in the Accelerator Descriptor Control Register (ADCR) is set, the data in the store queue is written to local memory at the address pointed to by the Destination Address Register (DAR). When the Destination Write Enable Bit in the ADCR is not set, the data is not written to local memory and is held in the queue. Steps 1-9 are repeated until all the bytes of data have undergone the *XOR-transfer* operation.

**Note:** When the ABCR register contains a value greater than the buffer size and the ADCR.dwe bit is cleared, the AAU only reads the first buffer of data and perform the specified function. It does not read the remaining bytes specified in the ABCR. Further, the AAU proceeds to process the next chain descriptor when it is specified.

402 October, 2003 **Document Number: 273942-002** 



#### 7.5.2 Zero Result Buffer Check

The AA can be used to verify parity across memory blocks specified by the SARx registers. As with XOR operations, descriptors are used to specify the memory blocks on which the AA performs the Zero Result Buffer Check. Figure 50 illustrates a Zero Result Buffer Check performed by the AA. After processing all source data, the AA updates the Result Buffer Not Zero bit of the eighth word of the descriptor (ADCR) pointed to by the ADAR in local memory.

Figure 50. An example of Zero Result Buffer Check





# 7.5.3 Memory Block Fill Operation

The AA can be used to write a constant value to a memory block in the 80331 local memory. As with XOR operations, descriptors are used to specify the memory blocks to which the AA writes the data contained in the Data / Source Address Register1. All memory block fill operations are controlled by chain descriptors located in the Intel<sup>®</sup> XScale Core local memory. Figure 51 illustrates a Block Fill Operation to an arbitrary destination address.

Figure 51. Example of a Memory Block Fill Operation





# 7.6 Programming Model State Diagram

The AA programming model diagram is shown in Figure 52. Error condition states are not shown.

Figure 52. Application Accelerator Programming Model State Diagram





# 7.7 Application Accelerator Priority

The internal bus arbitration logic determines which internal bus master has access to the 80331 internal bus. The Application Accelerator has an independent Bus Request/Grant signal pair to the internal bus arbitration logic. Chapter 12, "Intel<sup>®</sup> 80331 I/O Processor Arbitration Unit" describes in detail the priority scheme between all of the bus masters on the internal bus.

In addition, the internal bus arbitration unit has a Multi-Transaction timer (Section 12.4.3, "Multi-Transaction Timer Register 2 - MTTR2" on page 626) that affects the throughput of the AA. The default value for MTT2 of 152 clocks was chosen to ensure that once an internal bus agent (in this case the AA) is granted the internal bus that it is guaranteed an opportunity to burst data into DDR SDRAM memory. However, when the bus is busy the AA loses grant before the burst is completed. This means that the AA is able to complete only one burst for each arbitration cycle.

Alternatively, the user may wish to increase the value of MTT2 to guarantee that two or more bursts is able to complete within an arbitration cycle.

For example, assuming 1 Kbyte bursts and a 64-bit memory subsystem, an MTT2 setting of 192 clocks would be sufficient to support two 1 Kbyte bursts for the AA in a single arbitration cycle.

Warning:

Increasing the MTT2 value may also increase the latency to memory for the Intel<sup>®</sup> XScale<sup>TM</sup> core on the average. Before changing the MTT2 value, it's imperative that the overall impact to the performance of the application is considered.

406 October, 2003 **Document Number: 273942-002** 



# 7.8 Packing and Unpacking

The Application Accelerator contains a hardware data packing and unpacking unit to support data transfers between unaligned source and destination addresses. Source and destination addresses can either be unaligned or aligned on natural boundaries. The packing unit optimizes data transfers to and from 32 and 64-bit memory. It reformats data words for the correct bus data width. When the read data needs to be packed or unpacked, the data is held internally and does not need to be re-read.

Aligned data transfers fall on natural boundaries. For example; DWORDs are aligned on 8-byte boundaries and words are aligned on 4-byte boundaries. Data transfers take place in two instances:

- The source and destination addresses are both aligned.
- All or some source addresses are unaligned and the destination address is aligned or unaligned.

## 7.8.1 64-bit Unaligned Data Transfers

Figure 53 illustrates a data transfer between unaligned 64-bit, source and destination addresses.

Figure 53. Optimization of an Unaligned Data Transfer





# 7.9 Programming the Application Accelerator

The software for Application Accelerator falls into the following categories:

- AA initialization
- Suspend AA
- Appending Descriptors
- Resume AA Operation

An example for each category is shown in the following sections as pseudo code flow.

The AA control register provides independent control each time the AA is configured. This provides the greatest flexibility to the applications programmer.

The most efficient method for operating the AA is to use the *Chain Resume* capability described in Section 7.3.3, "Descriptor Chaining". To use of the *Chain Resume* capability for appending descriptors to chains in normal operation, an initial AA descriptor must be executed. This initialization step is described in Section 7.9.1, "Application Accelerator Initialization". The example AA operations provided later in this section use the *Chain Resume* capability as follows:

- Store Descriptor in Local Memory
- Append Descriptor to Chain
- Resume AA Operation



### 7.9.1 Application Accelerator Initialization

The AA is designed to have independent control of the interrupts, enables, and control. The initialization consists of virtually no overhead as shown in Figure 54.

#### Figure 54. Pseudo Code: Application Accelerator Initialization

```
ACR = 0x0000 0000; Disable the application accelerator Call setup_accelerator
```

The following example illustrates how AA initialization S/W prepares the AA for descriptor *Chain Resume* operation. Initializing the AA for chaining requires an initial descriptor be created and executed. This descriptor is then the start of the chain, and future descriptors are appended to this descriptor to create the chain. This descriptor is a NULL descriptor, requiring no source or destination data buffers be allocated. To start an operation, software simply sets the AA Enable bit in the "Accelerator Control Register - ACR" as shown in Figure 55.

#### Figure 55. Pseudo Code: Application Accelerator Chain Resume Initialization

```
; Set up descriptor in Intel® XScale™ core local memory at address d
d.nda = 0
                /* No chaining */
d.D/SAR1 = 0x0000 0000/* Source address of Data Block 1
d.SAR2 = 0x0000 0000/* Source address of Data Block 2
d.SAR3 = 0x0000 0000/* Source address of Data Block 3
                                                          * /
d.SAR4 = 0x0000 0000/* Source address of Data Block 4
                                                          * /
d.DAR = 0x0000 0000/* Destination address of XOR-ed data */
d.ABCR = 0x0
                  /* Byte Count of zero */
d.ADCR = 0x000 0000/* Null Descriptor, No Interrupt*/
; Start operation
ANDAR - &d ; Setup descriptor address
ACR = 0 \times 0000 \ 0001; Set AA Enable bit
```

# 7.9.2 Suspend Application Accelerator

The Application Accelerator unit provides the ability to suspend the current state without losing status information. The AA resumes without requiring application software to save the current configuration. The example shown in Figure 56 describes pseudo-code for suspending the ongoing operation and then restarting.

#### Figure 56. Pseudo Code: Suspend Application Accelerator

```
;Suspend Application Accelerator
ACR = 0x0000 0000 ; Suspend ongoing AA transfer
;Restart Application Accelerator
ACR = 0x0000 0001 ; Restart AA operation
```



### 7.9.3 Appending Descriptor for XOR Operations

The example shown in Figure 57 describes the pseudo code for initiating an XOR operation with the AA. The examples illustrates appending the XOR operation to an existing chain, and taking advantage of the Chain Resume capability as described

#### Figure 57. Pseudo Code: XOR Transfer Operation

```
; Set up descriptor in Intel® XScale™ core local memory at address d
d.nda = 0 /* No chaining */
d.D/SAR1 = 0xA000 0400/* Source address of Data Block 1
d.SAR2 = 0xA000 0800/* Source address of Data Block 2
                                                          * /
d.SAR3 = 0xA000 0C00/* Source address of Data Block 3
                                                          * /
                                                        * /
d.SAR4 = 0xA000 1000/* Source address of Data Block 4
d.DAR = 0xB000 0100/* Destination address of XOR-ed data */
d.ABCR = 1024 /* Byte Count of 1024 */
d.ADCR = 0x8000 049F/* Direct fill data from Block 1
                  /* XOR with data from Block 2,Block 3 and
                     Block 4
                  /\,{}^\star Store the result and interrupt processor ^\star/
; Append descriptor to end of last chain at address c
c.nda = d
; Resume AA operation
ACR = 0 \times 000000003 ; Set AA Enable and Resume bits
```

# 7.9.4 Appending Descriptor for Memory Block Fill Operations

The example shown in Figure 58 describes the pseudo code for initiating a Memory Block Fill operation with the AA.

#### Figure 58. Pseudo Code: Memory Block Fill Operation



## 7.9.5 Appending Descriptor for Zero Result Buffer Check

The example shown in Figure 59 describes the pseudo code for initiating an XOR operation with the AA.

#### Figure 59. Pseudo Code: Zero Result Buffer Check Operation<sup>a</sup>

```
; Set up descriptor in Intel<sup>®</sup> XScale<sup>™</sup> core local memory at address d
d.D/SAR1 = 0xA000 0400/* Source address of Data Block 1
d.SAR2 = 0xA000 0800/* Source address of Data Block 2
d.SAR3 = 0xA000 0C00/* Source address of Data Block 3
                                                           * /
d.SAR4 = 0xA000 1000/* Source address of Data Block 4
d.ABCR = 1024
                 /* Byte Count of 1024 */
d.ADCR = 0x4000 049F/* Direct fill data from Block 1
                  /* XOR with data from Block 2,Block 3 and
                   /* Check Result, Write Status (ADCR) and interrupt processor */
; Append descriptor to end of last chain at address \ensuremath{\mathtt{c}}
c.nda = d
; Resume AA operation
ACR = 0 \times 000000003 ; Set AA Enable and Resume bits
```

 Notice that ADCR.dwe is cleared and that the DAR is not programmed. The reasons is that for Zero Result Buffer Check operations, there is no need to write out a destination parity stripe.



# 7.10 Interrupts

The Application Accelerator can generate an interrupt to the 80331. The *Interrupt Enable* bit in the Accelerator Descriptor Control Register (ADCR.ie) determines whether the AA generates an interrupt upon successful, error-free completion. Error conditions described in Section 7.11 also generate an interrupt. The AA has one interrupt output connected to the PCI and Peripheral Interrupt Controller described in Chapter 15, "Interrupt Controller Unit".

Once the AA is enabled, the AA loads the chain descriptor fields into the respective registers. A special case exists when data write enable is clear, then an interrupt is generated (when enabled) after the descriptor is fetched and processed as defined by the block control fields in the ADCR. Table 200 summarizes the status flags and conditions when interrupts are generated in the Accelerator Status Register (ASR).

#### Table 200. AA Interrupts

| Interrupt Condition                                                                             | Accelerator Status Register (ASR) Flags |                 |              |                 | Interrupt<br>Generated? |                    |
|-------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------|--------------|-----------------|-------------------------|--------------------|
|                                                                                                 | Active                                  | End of Transfer | End of Chain | IB Master Abort | Interrupt Enabled       | Interrupt Disabled |
| (Data Write Enable == 0    byte count == 0) && (ANDAR != NULL    Resume == 1) (End of Transfer) | 1                                       | 1               | 0            | 0               | Y                       | N                  |
| (Data Write Enable == 0    byte count == 0)  && ANDAR == NULL && Resume == 0  (End of Chain)    | 0                                       | 0               | 1            | 0               | Y                       | N                  |
| IB Master Abort                                                                                 | 0                                       | 0               | 0            | 1               | Υ                       | Υ                  |
| IB Target Abort                                                                                 | 0                                       | 0               | 0            | 0               | N                       | N                  |

**Vote:** End-of-Transfer and End-of-Chain flags is set only when Interrupt Enable is set. When Interrupt Enable is clear, then the above flags are always set to 0. End-of-Transfer Interrupt and End of Chain Interrupt can only be reported in the ASR when the descriptor fetch and processing completed without any reportable errors. However, multiple error conditions may occur and be reported together. Also, because the AA does not stop after reporting the End-of-Transfer interrupt, an IB master-abort error may occur before the End-of-Transfer interrupt is serviced and cleared.



### 7.11 Error Conditions

Master Aborts that occur during a transfer are recorded by the Application Accelerator.

When an error occurs, the actions taken are detailed below:

- The AA shall cease the ongoing transfer for the current chain descriptor and clear the *Application Accelerator Active* flag in the ASR.
- The AA does not read any new chain descriptors.
- The AA sets the error flag in the Accelerator Status Register. For example; when an IB master-abort occurred during a transfer, the channel sets bit 5 in the ASR.
- The AA signals an interrupt to the  $Intel^{\textcircled{B}}$  XScale  $^{TM}$  core.
- The Application Accelerator does not restart the transfer after an error condition. It is the responsibility of the application software to reconfigure the AA to complete any remaining transfers.

Note: Target-aborts during AAU reads result from multi-bit ECC errors that are recorded by the MCU. Refer to Chapter 8, "Memory Controller" for details on error handling in this instance. For correct operation of the AAU, user software has to disable the AAU before clearing the error condition. Further, the AAU needs to be re-enabled by writing a 1 to the AA Enable bit before initiating a new operation.



# 7.12 Power-up/Default Status

Upon power-up, an external hardware reset, the Application Accelerator Registers is initialized to their default values.

# 7.13 Register Definitions

The Application Accelerator Unit contains forty two memory-mapped registers for controlling its operation. There is read/write access only to the Accelerator Control Register, Accelerator Status Register, the Accelerator Next Descriptor Address Register, and the three Extended Descriptor Control Registers. All other registers are read-only and are loaded with new values from the chain descriptor whenever the AA reads a chain descriptor from memory.

### Table 201. Application Accelerator Unit Registers

| Section, Register Name - Acronym (page)                                            |  |
|------------------------------------------------------------------------------------|--|
| Section 7.13.1, "Accelerator Control Register - ACR" on page 415                   |  |
| Section 7.13.2, "Accelerator Status Register - ASR" on page 416                    |  |
| Section 7.13.3, "Accelerator Descriptor Address Register - ADAR" on page 417       |  |
| Section 7.13.4, "Accelerator Next Descriptor Address Register - ANDAR" on page 418 |  |
| Section 7.13.5, "Data / Source Address Register1 - SAR1" on page 419               |  |
| Section 7.13.6, "Source Address Register232 - SAR232" on page 420                  |  |
| Section 7.13.7, "Destination Address Register - DAR" on page 421                   |  |
| Section 7.13.8, "Accelerator Byte Count Register - ABCR" on page 422               |  |
| Section 7.13.9, "Accelerator Descriptor Control Register - ADCR" on page 423       |  |
| Section 7.13.10, "Extended Descriptor Control Register 0 - EDCR0" on page 427      |  |
| Section 7.13.11, "Extended Descriptor Control Register 1 - EDCR1" on page 430      |  |
| Section 7.13.12, "Extended Descriptor Control Register 2 - EDCR2" on page 433      |  |



## 7.13.1 Accelerator Control Register - ACR

The Accelerator Control Register (ACR) specifies parameters that dictate the overall operating environment. The ACR should be initialized prior to all other AA registers following a system reset. Table 202 shows the register format. This register can be read or written while the AA is active.

Table 202. Accelerator Control Register - ACR





## 7.13.2 Accelerator Status Register - ASR

The Accelerator Status Register (ASR) contains status flags that indicate status. This register is typically read by software to examine the source of an interrupt. See Section 7.11 for a description of the error conditions that are reported in the ASR. See Section 7.10 for a description of interrupts caused by the Application Accelerator.

When an AA error occurs, application software should check the status of Accelerator Active flag before processing the interrupt.

Table 203. Accelerator Status Register - ASR





## 7.13.3 Accelerator Descriptor Address Register - ADAR

The Accelerator Descriptor Address Register (ADAR) contains the address of the current chain descriptor in local memory. This read-only register is loaded when a new chain descriptor is read. Table 204 depicts the Accelerator Descriptor Address Register. Depending on the number of sources, the chain descriptors are required to be aligned on different address boundaries. These include four sources on an eight word address boundary, eight sources on a 16 word address boundary, 16 sources on a 32 word address boundary, and 32 sources on a 64 word address boundary.

*Note:* In the above paragraph, the term "word" refers to a DWORD.

Table 204. Accelerator Descriptor Address Register - ADAR





### 7.13.4 Accelerator Next Descriptor Address Register - ANDAR

The Accelerator Next Descriptor Address Register (ANDAR) contains the address of the next chain descriptor in local memory. When starting a transfer, this register contains the address of the first chain descriptor. Table 205 depicts the Accelerator Next Descriptor Address Register.

All chain descriptors are aligned on an eight DWORD boundary. The AA may set bits 04:00 to zero when loading this register.

**Note:** The Accelerator Enable bit in the ACR and the Accelerator Active bit in the ASR must both be clear prior to writing the ANDAR. Writing a value to this register while the AA is active may result in undefined behavior.

Table 205. Accelerator Next Descriptor Address Register - ANDAR





### 7.13.5 Data / Source Address Register1 - SAR1

The Data / Source Address Register (D/SARx) contains a 32-bit, local memory address or immediate data to be written in case of Memory Block Fill operations. The ADCR register (Table 210) controls the operation performed on data block referenced by this register. The local memory address space is a 32-bit, byte addressable address space.

Reading the D/SAR1 register once the AA has started a chain descriptor returns the current source address or immediate data to be written in case of Memory Block Fill operations.

Once an operation is initiated, these registers contain the current source addresses. For example; when the Byte Count is initially 4096 bytes and the AA has completed the operation on the first three 1K-byte data blocks, the value in register SAR1 is the equal to the programmed descriptor value + 3072 (SAR1 + 3072).

During Memory Block Fills the register always contains the data to be written and does not change.

Table 206 shows the Data / Source Address Register1. This read-only register is loaded when a chain descriptor is read from memory.

Table 206. Data / Source Address Register - SAR1





### 7.13.6 Source Address Register2..32 - SAR2..32

The 80331 Source Address Register2..32 (SAR2..32) contains a 32-bit, local memory address. There are 31 Source Address Registers (SAR2 - SAR32). Each of these registers is loaded with address of blocks of data to be operated upon by the AA. The ADCR, EDCR0, EDCR1, and EDCR2 registers control the operation performed on each data block referenced by the registers (SAR2 - SAR32). The local memory address space is a 32-bit, byte addressable address space.

Reading SARx registers once AA has started a chain descriptor returns the current source addresses. Once an operation is initiated, these registers contain current source addresses. For example; when Byte Count is initially 4096 bytes and AA has completed operation on the first three 1K-byte data blocks, the value in register SARx is the equal to the programmed descriptor value + 3072 (SARx + 3072).

Table 206 shows the Source Address Register2..32. These read-only registers are loaded when a chain descriptor is read from memory.

Table 207. Source Address Register2..32 - SAR2..32





## 7.13.7 Destination Address Register - DAR

The Destination Address Register (DAR) contains a 32-bit, local memory address.

During operations, this address is the destination address in local memory where data is stored. The 80331 local memory address space is a 32-bit, byte addressable address space.

During Memory Block Fill operations, this address points to the memory block to be written with the constant value contained in the D/SAR1 register.

Reading the DAR once the AA has started a chain descriptor returns the current destination address. For example; during an XOR operation when the Byte Count is initially 4096 bytes and the AA has completed the *XOR-transfer* operation on the first three 1K-byte data blocks, the value in the Destination Address Register (DAR) is the equal to the programmed descriptor value + 3072 (DAR + 3072).

Table 208 shows the Destination Address Register. This read-only register is loaded when a chain descriptor is read from memory

Table 208. Destination Address Register - DAR





## 7.13.8 Accelerator Byte Count Register - ABCR

The Accelerator Byte Count Register (ABCR) contains the number of bytes to transfer for an operation. This is a read-only register that is loaded from the Byte Count word in a chain descriptor. It allows for a maximum transfer of 16 Mbytes. A value of zero is a valid byte count and results in no read or write cycles being generated to the Memory Controller Unit. No cycles are generated on the internal bus.

Table 209. Accelerator Byte Count Register - ABCR



Note: Anytime this register is read by the 80331, it contains the number of bytes left to transfer on the internal bus. Note that during an operation valid data may be present in the Application Accelerator store queue. This register is decremented by 1 through 8 for every successful transfer from the store queue to the destination location. During Memory Block Fills this register decremented by 1 through 8 for every successful write operation. Table 209 shows the Accelerator Byte Count Register. The byte count value is not required to be aligned to a DWORD boundary (i.e., the byte count value can be a DWORD aligned, short aligned, or byte aligned).



### 7.13.9 Accelerator Descriptor Control Register - ADCR

The Accelerator Descriptor Control Register contains control values for data transfer on a per-chain descriptor basis. This read-only register is loaded when a chain descriptor is read from memory. These values may vary from chain descriptor to chain descriptor. The AAU determines whether a mini-descriptor is appended to the end of the current chain descriptor by examining bits 26:25. Table 210 shows the definition of the Accelerator Descriptor Control Register.

Table 210. Accelerator Descriptor Control Register - ADCR (Sheet 1 of 4)





Table 210. Accelerator Descriptor Control Register - ADCR (Sheet 2 of 4)





Table 210. Accelerator Descriptor Control Register - ADCR (Sheet 3 of 4)





Table 210. Accelerator Descriptor Control Register - ADCR (Sheet 4 of 4)





### 7.13.10 Extended Descriptor Control Register 0 - EDCR0

The Extended Descriptor Control Register 0 contains control values for data transfer on a per-chain descriptor basis. This read-only register is loaded when a chain descriptor that requires a minimum of 16 Source Addresses is read from memory. The values in EDCR0 define the command/control value for SAR16 - SAR9. The AAU determines whether an extended descriptor requiring the use of EDCR0 is appended to the end of the current chain descriptor by examining bits 26:25 of the Accelerator Descriptor Control Register. Table 211 shows the definition of the Extended Descriptor Control Register 0.

Table 211. Extended Descriptor Control Register 0 - EDCR0 (Sheet 1 of 3)





Table 211. Extended Descriptor Control Register 0 - EDCR0 (Sheet 2 of 3)





Table 211. Extended Descriptor Control Register 0 - EDCR0 (Sheet 3 of 3)





# 7.13.11 Extended Descriptor Control Register 1 - EDCR1

The Extended Descriptor Control Register 1 contains control values for data transfer on a per-chain descriptor basis. This read-only register is loaded when a chain descriptor that requires 32 Source Addresses is read from memory. The values in EDCR1 define the command/control value for SAR24 - SAR17. The AAU determines whether an extended descriptor requiring the use of EDCR1 is appended to the end of the current chain descriptor by examining bits 26:25 of the Accelerator Descriptor Control Register. Table 212 shows the definition of the Extended Descriptor Control Register 1.

Table 212. Extended Descriptor Control Register 1 - EDCR1 (Sheet 1 of 3)





#### Table 212. Extended Descriptor Control Register 1 - EDCR1 (Sheet 2 of 3)





Table 212. Extended Descriptor Control Register 1 - EDCR1 (Sheet 3 of 3)





## 7.13.12 Extended Descriptor Control Register 2 - EDCR2

The Extended Descriptor Control Register 2 contains control values for data transfer on a per-chain descriptor basis. This read-only register is loaded when a chain descriptor that requires 32 Source Addresses is read from memory. The values in EDCR2 define the command/control value for SAR32 - SAR25. The AAU determines whether an extended descriptor requiring the use of EDCR2 is appended to the end of the current chain descriptor by examining bits 26:25 of the Accelerator Descriptor Control Register. Table 213 shows the definition of the Extended Descriptor Control Register 2.

Table 213. Extended Descriptor Control Register 2 - EDCR2 (Sheet 1 of 3)





Table 213. Extended Descriptor Control Register 2 - EDCR2 (Sheet 2 of 3)





Table 213. Extended Descriptor Control Register 2 - EDCR2 (Sheet 3 of 3)





## This Page Intentionally Left Blank



# Memory Controller

8

This chapter describes the integrated Memory Controller Unit (MCU). The operating modes, initialization, external interfaces, and implementation are detailed in this chapter.

## 8.1 Overview

The Intel<sup>®</sup> 80331 I/O processor (80331) integrates a high performance, multi-ported Memory Controller to provide a direct interface between the 80331 and its local memory subsystem. The Memory Controller supports:

- DDR 333 MHz SDRAM with 128/256/512 Mbit and 1Gbit density supported.
- DDR-II 400 MHz SDRAM with 256/512 Mbit density supported.
- Dedicated port for Intel<sup>®</sup> XScale<sup>TM</sup> core to DDR SDRAM.
- Between 64 MBytes and 2 GByte of 64-bit DDR SDRAM (1 GByte for DDR-II SDRAM).
- Between 32 MBytes and 1 GBytes of 32-bit DDR SDRAM for low cost solutions (512 MByte for DDR-II SDRAM).
- Optimized core processor data processing 32-bit region.
- Single-bit error correction, multi-bit detection support (ECC).
- 32-, 40- and 64-, 72-bit wide Memory Interfaces (non-ECC and ECC support).

The DDR SDRAM (DDR and DDR-II SDRAM) interface provides a direct connection to a high bandwidth and reliable memory subsystem. The DDR SDRAM interface consists of a 64-bit wide data path to support up to 3.2 GBytes/sec throughput. An 8-bit Error Correction Code (ECC) across each 64-bit word improves system reliability. The ECC is stored into the DDR SDRAM array along with the data and is checked when the data is read. If the code is incorrect, the MCU corrects the data (if possible) before reaching the initiator of the read. User-defined fault correction software is responsible for scrubbing the memory array.

The MCU supports two banks of DDR SDRAM in the form of one two-bank dual inline memory module (DIMM).

- The MCU has support for Registered and Unbuffered DDR333 and Registered DDR-II 400 DIMMs.
- The MCU supports a 32-bit SDRAM data interface. This mode enables lower-cost solutions at the cost of system performance.
- The MCU responds to internal bus and core processor memory accesses within its programmed address range and issues the memory request to the DDR SDRAM interface.
- The MCU contains transaction queues for each port enabling pipelining of transactions to the DDR SDRAM for maximum performance.
- For 64-bit ECC memory, a 32-bit memory region can be programmed to operate as 32-bit ECC memory for higher performance core write performance by avoiding Read-Modify-Write (RMW) operation of DDR SDRAM.
- The MCU provides two chip enables to the memory subsystem. These two chip enables service the DDR SDRAM subsystem (one per bank).



## 8.2 Glossary

This section lists commonly used terms throughout this chapter:

## Table 214. Commonly Used Terms

| Term      | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bank      | A bank is defined as a memory region defined with a base register and a bank size register. Physically, a bank of memory is controlled by a single chip select. A DIMM could be comprised of a single or dual banks.                                                                                                                                                                                                                                    |
| Column    | A column refers to a portion of memory within an DDR SDRAM device. An DDR SDRAM device can be thought of as a grid with rows and columns. Once a row is activated, any column within that row can be accessed multiple times without reactivating the row. Columns are activated with CAS#.                                                                                                                                                             |
| DIMM      | A DIMM is an acronym for Dual Inline Memory Module. A DIMM is a physical card comprising multiple DDR SDRAM devices. The card could be populated on one or both sides. A DIMM can be single or dual-bank.                                                                                                                                                                                                                                               |
| Leaf      | DDR SDRAM devices use multiple banks within the device operating in an interleaved mode. The MCU supports 128/256/512 Mbit, 1 Gbit DDR SDRAM and 256/512 Mbit DDR-II SDRAM devices containing four internal banks. An internal bank is defined as a leaf (to avoid confusion with a memory bank).                                                                                                                                                       |
| Page      | A page is a row of memory. Once a row is activated, any column within that row can be accessed multiple times without reactivating the row. This is referred to as "keeping the page open." Page size depends on the DDR SDRAM device configuration, and the MCU supports the maximum possible page size (16 Kbytes for 64-bit wide memory and 8 Kbytes for 32-bit wide memory). The MCU breaks up pages across physical memory due to address mapping. |
| Row       | A row refers to a portion of memory within an DDR SDRAM device. An DDR SDRAM device can be thought of as a grid with rows and columns. Once a row is activated, any column within that row can be accessed multiple times without reactivating the row. Rows are activated with RAS#.                                                                                                                                                                   |
| Scrubbing | Once an error is detected within the memory array, the MCU must correct the error (if possible) while delivering the data to the initiator. Correcting the memory location is referred to as "scrubbing the array." The MCU relies on software to scrub any errors.                                                                                                                                                                                     |
| Syndrome  | A syndrome is a value which indicates an error in the data read from the memory array. The MCU computes the syndrome with every memory read. Decoding the syndrome indicates: the bit in error for a single-bit error, or a multi-bit error. Table 231 defines the syndrome decoding.                                                                                                                                                                   |



## 8.3 Theory of Operation

The 80331 memory controller translates the internal bus and core processor transactions into the protocol supported by the DDR SDRAM memory subsystem.

## 8.3.1 Functional Blocks

*Note:* The memory controller and Intel<sup>®</sup> XScale<sup>™</sup> core processor bus interface unit (BIU) logically comprises the blocks illustrated in Figure 60. The memory controller is a multiported unit, supporting an inbound path for both the BIU and Internal Bus (IB) to the DDR SDRAM.

Figure 60. Memory Controller Block Diagram





#### 8.3.1.1 Transaction Ports

*Note:* The MCU provides two transaction ports for DDR SDRAM access. They are:

#### 8.3.1.1.1 Core Processor Port

The Core Processor Port provides a direct connection between the 80331 core processor's bus interface and the Memory Controller. This Core Processor Port allows core transactions targeting the DDR SDRAM to pass directly to the DDR SDRAM.

#### 8.3.1.1.2 Internal Bus Port

The Internal Bus Port provides the connection to the DDR SDRAM from the Internal Bus. All peripheral unit transactions targeting the DDR SDRAM are claimed by this port.



## 8.3.1.2 Address Decode Blocks

Address Decode is performed for transactions from input ports to determine if the MCU should claim the transaction. There are two address ranges the MCU ports can claim transactions: DDR SDRAM memory space and Peripheral Memory-Mapped Register (PMMR) space.

#### 8.3.1.2.1 DDR SDRAM Memory Space

The DDR SDRAM memory space is defined with the DDR SDRAM Base Address Register (SDBR) and the DDR SDRAM Boundary Registers (SBR0, SBR1, S32SR). The transaction is intended for a DDR SDRAM bank if the address is between the base register (SDBR) and between the boundaries programmed with SBR0, SBR1 and S32SR as defined in Section 8.3.3.2, "DDR SDRAM Addressing" on page 452.

te: For DDR SDRAM Bank 0 or Bank 1 overlapping PMMR space (FFFF E000H to FFFF FFFFH), DDR SDRAM is not accessible, and PMMRs are addressed. The read, write, and reserved characteristics of PMMR space is applicable as defined in Chapter 17, "Peripheral Registers".

#### 8.3.1.2.2 Memory-Mapped Register Space

The MCU PMMR memory space is FFFF E500H to FFFF E5FFH and FFFF F500H to FFFF F5FFH. The registers are detailed in Section 8.7, "Register Definitions" on page 496.Each port decodes inbound transactions for these address ranges. The Address Decode blocks determine how the Memory Controller responds to inbound transactions. The details of the address decode for each port is described below.

#### 8.3.1.2.3 Core Processor Port Address Decode

**Note:** The address decode block for the Core Processor transactions resides in the BIU. The Core MCU port therefore does not require any decode, and will process any transaction received from the BIU via the Core MCU Port.

#### 8.3.1.2.4 Internal Bus Port Address Decode

Internal Bus transactions are decoded to determine if they address the DDR SDRAM Memory Space or MCU MMR Space. If the transaction addresses either of these two spaces, the transaction is claimed by the Internal Bus Port. If the transaction addresses the DDR SDRAM Memory Space, the transaction is queued in the Internal Bus Port Transaction Queue. If the transaction addresses the MCU MMR Space, the transaction is serviced by accessing the Configuration Register block.



## 8.3.1.3 Memory Transaction Queues

There are two transaction queues for transactions which address the MCU DDR Memory Space. One transaction queue for Core Processor transactions and one transaction queue for Internal Bus transactions.

#### 8.3.1.3.1 Core Processor Memory Transaction Queue (CMTQ)

The CMTQ stores memory transactions from the core which have not been processed by the Memory Controller. The CMTQ supports 8 Core Processor read transactions up to 32-Bytes each, which equals the maximum number of outstanding transaction the Core Processor Bus Controller can support. The CMTQ also supports 8 Core Processor posted write transactions up to 16-Bytes each.

The number of CMTQ write transactions is selectable between 8 and 2, where the lower number may find benefit in some applications by throttling back on the core processor, and thereby 'encouraging' coalescing in the Core Processor Bus Controller.

#### 8.3.1.3.2 Internal Bus Memory Transaction Queue (IBMTQ)

Note: The IBMTQ stores memory transactions from the Internal Bus that address the DDR SDRAM Memory Space. The IBMTQ can hold 8 outstanding Internal Bus read transaction requests. Of the 8 read transactions in the IBMTQ, 4 can be processed at a time, each with up to 1KBytes of read data. The other 4 read transactions are simply stored in the IBMTQ. The IBMTQ also supports 4 posted write transactions up to 1KBytes each.

442 October, 2003 **Document Number: 273942-002** 



## 8.3.1.4 Configuration Registers

**Note:** The Configuration Registers block contains all of the memory-mapped registers listed in Section 8.7, "Register Definitions" on page 496. These registers define the memory subsystem connected to the 80331. The status registers indicate the current MCU status.

#### 8.3.1.5 Refresh Counter

The Refresh Counter block keeps track of when the DDR SDRAM devices need to be refreshed. The refresh interval is programmed in the "Frequency Register - RFR" on page 512. Once the 12-bit refresh counter reaches the programmed interval, the DDR SDRAM state machine issues a refresh command to the DDR SDRAM devices. If a transaction is currently in progress, the DDR SDRAM State Machine waits for the completion of the transaction to issue the refresh cycle. See Section 8.3.3.12, "DDR SDRAM Refresh Cycle" on page 474 for more details.

**Note:** If the memory controller is completing transactions from the core processor memory transaction queue (CMTQ) when the refresh counter expires, the MARB will complete the CMTQ tenure based on the "MCU Port Transaction Count Register - MPTCR" on page 510, before any refresh cycles are issued.

**Note:** If the memory interface is busy when the refresh counter expires, it is possible for the MCU to generate more than one refresh cycle when the memory interface becomes available.

#### 8.3.1.6 Memory Controller Arbiter (MARB)

The MARB determines what transaction to issue next to the DDR SDRAM Control Unit. The MARB is configurable to adjust the selection of transactions from the MCU ports and the refresh counter. The MARB selects transactions from all memory transaction queues based on a programmable arbitration scheme as described in Section 8.3.2, "MCU Arbitration and Configuration" on page 445.



#### 8.3.1.7 DDR SDRAM Control Block

The DDR SDRAM Control Block contains all functionality to process the DDR SDRAM data accesses per the transactions issued by the MARB. To process a transaction the DDR SDRAM Control Block employs several sub-blocks. The sub-blocks include the Page Control block, DDR SDRAM State Machine and Pipeline Queues, and Error Correction Logic.

#### 8.3.1.7.1 Page Control Block

The Page Control Block records and maintains the open DDR SDRAM pages. The MCU can keep a maximum of eight pages open simultaneously (4 per bank). This block keeps track of open pages and determines if the transactions hit an open page. For more details about the page hit/miss determination, see Section 8.3.3.5, "Page Hit/Miss Determination" on page 458.

#### 8.3.1.7.2 DDR SDRAM State Machine and Pipeline Queues

Since the MCU generates error correction codes based on the data, the MCU is a pipelined architecture. Pipelining also ensures acceptable AC timings to the memory interfaces. The DDR SDRAM state machine pipelines DDR SDRAM memory operations for several clocks.

#### 8.3.1.7.3 Error Correction Logic

The Error Correction Logic generates the ECC code for DDR SDRAM reads and writes. For reads, this logic compares the ECC codes read with the locally generated ECC code. If the codes mismatch then the Error Correction Logic determines the error type. For a single-bit error, this block determines which bit is in error and corrects the error. For a single-bit or multi-bit error, the Error Correction Logic logs the error in ELOG0 and ELOG1. See Section 8.3.4, "Error Correction and Detection" on page 476 for more details.



## **8.3.2** MCU Arbitration and Configuration

The order transactions are processed by the DDR SDRAM Control block is determined by the Memory Controller Arbiter (MARB). The MARB selects the next transaction from the memory transaction queues and refresh control based on the settings programmed in the MARB configuration registers ("MCU Port Transaction Count Register - MPTCR" on page 510, "MCU Preemption Control Register - MPCR" on page 511). These registers enable the MCU to be tuned for optimal performance for the design.

## 8.3.2.1 MCU Port Priority

*Note:* The Memory controller for the 80331 has only two inbound ports for memory transactions. Given this, there is no priority programming required, and the MARB will effectively toggle tenure between the two ports when both ports' memory transaction queues have pending transactions.



#### 8.3.2.2 MCU Port Transaction Count

The MCU Port Transaction Count Register (MPTCR) defines the number of transactions the MARB will select from a given port during the corresponding port's tenure. The intent is that ports with frequent small transactions (core processor port) be allowed to complete multiple transactions during a tenure, while ports with less frequent large transactions (IB port) be limited to a small number of transactions (possibly just 1).

## 8.3.2.3 Core Processor Port Preemption

In order to maximize core processor performance, the MARB can be programmed to interrupt active transactions from other memory transaction queues, in order to process transactions from the Core Processor. By preempting an active transaction, the MARB guarantees a maximum number of data cycles getting processed for the current transaction, therefore reducing the possible latency the Core Processor might see for memory accesses. Core processor preemption is enabled through the MARB Preemption Control Register (MPCR).

**Note:** Preemption control applies to all inbound MCU ports based on pending core transactions. Once the core processor transaction queue is 'activated' by the MARB, a standard tenure will take place. At the completion of the Core Processor transaction queue tenure, the MARB resumes the previously active transaction. The previously active transaction may be interrupted again, provided the conditions for preemption occur again prior to the completion of that transaction. No other effect on the MARB processing will occur.

446 October, 2003 **Document Number: 273942-002** 



## 8.3.2.4 Core Port Transaction Ordering

The Core port maintains order of Intel<sup>®</sup> XScale<sup>™</sup> core requests addressing the DDR SDRAM. Coherency between the core port and the IB port is maintained by the MCU as described in Section 8.3.2.6, "MCU Port Coherency" below.

## 8.3.2.5 IB Port Ordering

The IB port implements ordering of like transactions where reads do not pass reads, and writes do not pass writes. Write transactions are allowed to pass read transactions. Read transactions are processed by the MCU as described in Section 8.3.2.6, "MCU Port Coherency" below.

## 8.3.2.6 MCU Port Coherency

With the queueing of DDR SDRAM transactions in multiple ports, coherency of memory must be maintained. The MARB maintains memory coherency by ensuring all writes to a given memory address are completed before any read to the same address is processed. This address comparison is done with a 1 KByte granularity.

The highest priority Read transaction is compared to all pending write transactions from both memory transaction queues. If a write transaction is pending for the same memory location (1 KByte granularity), the write is allowed to complete first, before the read transaction is processed. Also, to maintain ordering rules, all write transactions preceding the 'incoherent write' are also processed.



## 8.3.3 DDR SDRAM Memory Support

The 80331 memory controller supports one or two banks of DDR SDRAM. DDR SDRAM allows zero data-to-data wait-state operation. DDR SDRAM offers an extremely wide range of configuration options emerging from the SDRAMs internal interleaving and bursting capabilities.

The MCU supports both 32-bit and 64-bit data bus width memory implementations (with and without ECC). The data bus width is controlled by the DDR SDRAM Control Register. In addition, a 64-bit data bus width DDR SDRAM implementation can be configured to operate as if a region is 32-bits wide, providing higher performance when the core processor is processing data by eliminating any RMW cycle required for 4-Byte store ECC generation.

The MCU supports DDR SDRAM burst length of four. A burst length of four enables seamless read/write bursting of long data streams as long as the memory transaction does not cross the page boundary. Page boundaries are at naturally aligned boundaries. The MCU ensures that the page boundary is not crossed within a single transaction by initiating a disconnect at next ADB (128 byte address boundary) on the internal bus prior to the page boundary.

#### 8.3.3.1 DDR SDRAM Interface

The DDR SDRAM interface signals generated by the memory controller unit are divided into two sections. The first section lists those signals for DDR SDRAM operation, and the second list those additional signals supporting DDR-II SDRAM.

The MCU SDRAM interface provides a flexible mix of combinations including:

#### **Table 215.** DDR SDRAM Memory Configuration Options

| Data Bus Width | ECC Enabled | Maximum Throughput(1) |
|----------------|-------------|-----------------------|
| 64 bit         | Yes         | 3200 Mbyte/s          |
| 64 bit         | No          | 3200 Mbyte/s          |
| 32 bit         | Yes         | 1600 Mbyte/s          |
| 32 bit         | No          | 1600 Mbyte/s          |

#### NOTE:

1. Based on DDR-II 400MHz SDRAM



Table 216 shows the DDR SDRAM interface signals.

## Table 216. DDR SDRAM Interface Signals

| Pin Name   | Description                                                                                                                                                                                                                                                                                                                                               |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M_CK[2:0]  | DDR SDRAM Clock Out - Three (positive lines) of the output clocks driven to the Unbuffered DIMMs supported by the 80331.Registered DIMMs will only use <b>M_CK[0]</b> which will drive the input to the on-DIMM PLL. Section 8.3.6, "DDR SDRAM Clocking" on page 487 describes the DDR SDRAM clocking strategy for both Unbuffered and Registered DIMMs.  |
| M_CK[2:0]# | DDR SDRAM Clock Out - Three (negative lines) of the output clocks driven to the Unbuffered DIMMs supported by the 80331.Registered DIMMs will only use <b>M_CK[0]#</b> which will drive the input to the on-DIMM PLL. Section 8.3.6, "DDR SDRAM Clocking" on page 487 describes the DDR SDRAM clocking strategy for both Unbuffered and Registered DIMMs. |
| M_RST#     | DDR Registered DIMM Reset - Used to re-initialize registered DIMM during a P_RST# assertion or whenever internal bus reset bit is asserted in the PCSR. PCI Configuration and Status Register - PCSR describes the internal bus reset sequence.                                                                                                           |
| CKE[1:0]   | Clock enables - One clock after CKE[1:0] is de-asserted, data is latched on DQ[63:0] and CB[7:0]. Burst counters within DDR SDRAM device are not incremented. De-asserting this signal places the DDR SDRAM in self-refresh mode. For normal operation, CKE[1:0] must be asserted.                                                                        |
| CS[1:0]#   | Chip Select - Must be asserted for all transactions to the DDR SDRAM device. One per bank.                                                                                                                                                                                                                                                                |
| BA[1:0]    | DDR SDRAM Bank Selects - Controls which of the internal DDR SDRAM banks to read or write. <b>BA[1:0]</b> are used for all technology types supported.                                                                                                                                                                                                     |
| MA[10]     | Address bit 10 - If high during a read or write command, auto-precharge occurs after the command. During a <b>row-activate</b> command, this bit is part of the address (Section 8.3.3.2). Auto-precharge is <b>not</b> supported by the 80331.                                                                                                           |
| MA[13:0]   | Address bits 12 through 0 - Indicates the row or column to access depending on the state of RAS# and CAS# (Section 8.3.3.2).                                                                                                                                                                                                                              |
| DQ[63:0]   | Data Bus - 64-bit wide data bus.                                                                                                                                                                                                                                                                                                                          |
| CB[7:0]    | ECC Bus - 8-bit error correction code which accompanies the data on DQ[63:0].                                                                                                                                                                                                                                                                             |
| DM[8:0]    | Data Bus Mask - Controls the DDR SDRAM data input buffers. Asserting <b>WE#</b> causes the data on <b>DQ[63:0]</b> and <b>CB[7:0]</b> to be written into the DDR SDRAM devices. <b>DM[8:0]</b> controls this operation on a per byte basis.                                                                                                               |
| DQS[8:0]   | Data Strobes - Strobes that accompany the data to be read or written from the DDR SDRAM devices. Data is sampled on the negative and positive edges of these strobes.                                                                                                                                                                                     |
| WE#        | Write Strobe - Defines whether or not the current operation by the DDR SDRAM is to be a read or a write.                                                                                                                                                                                                                                                  |
| RAS#       | Row Address Strobe - Indicates that the current address on MA[13:0] is the row.                                                                                                                                                                                                                                                                           |
| CAS#       | Column Address Strobe - Indicates that the current address on MA[13:0] is the column.                                                                                                                                                                                                                                                                     |
| VREF       | SDRAM Voltage Reference - is used to supply the reference voltage to the differential inputs of the memory controller pins.                                                                                                                                                                                                                               |



Table 217 shows the DDR-II SDRAM interface signals.

#### Table 217. DDR-II SDRAM Interface Signals

| Pin Name    | Description                                                                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DQS[8:0]#   | Data Strobes Differential- Strobes that accompany the data to be read or written from the DDR SDRAM devices. Data is sampled on the negative and positive edges of these strobes. |
| DDRRES[2:1] | COMPENSATION FOR DDR OCD (analog) DDR2 mode only                                                                                                                                  |
| ODT[1:0]    | On Die Termination signals control - turns on SDRAM termination during writes                                                                                                     |

Utilizing the DDR SDRAM chip selects **CS[1:0]**# and internal bank selects **BA[1:0]**, the MCU keeps a maximum of eight pages open simultaneously. The number of available pages depends on the memory subsystem population. A single bank allows four pages and two banks allow eight pages.

Open pages allow optimal performance when a read or write occurs to an open page. Multiple open pages allow multiple memory segments to be open simultaneously and is well-suited for the 80331 system environment. The MCUs paging algorithm is detailed in Section 8.3.3.5, "Page Hit/Miss Determination" on page 458. The waveforms illustrating the performance issues are in Section 8.3.3.10, "DDR SDRAM Read Cycle" on page 468 and Section 8.3.3.11, "DDR SDRAM Write Cycle" on page 471.

450 October, 2003 **Document Number: 273942-002** 



Figure 61 illustrates how two banks of DDR SDRAM would interface with the 80331 through the MCU.

Figure 61. Dual-Bank DDR SDRAM Memory Subsystem





## 8.3.3.2 DDR SDRAM Addressing

MCU supports memory subsystem ranging from 64 Mbytes-2 Gbyte. An ECC or non-ECC system may be implemented using x8, or x16 devices and 32-bit or 64-bit data bus widths. Required information to configure the MCU are: row address size, column address size and size of DIMM module which can be read via the DIMM Serial Presence Detect (SPD).

Table 218 illustrates supported DDR SDRAM configurations. This table reflects the bank size associated with the respective row and column address size. The Bank size reflects 64-bit data bus width. The table also specifies the Page Size corresponding to each column address size.

#### Table 218. Supported DDR SDRAM Bank and Page Sizes<sup>a</sup>

| Row Address Size (bits) | Column Address Size (bits) |       |       |  |  |  |  |  |
|-------------------------|----------------------------|-------|-------|--|--|--|--|--|
| Now Address Size (bits) | 9                          | 10    | 11    |  |  |  |  |  |
| 12                      | 64MB                       | 128MB | n/a   |  |  |  |  |  |
| 13                      | 128MB                      | 256MB | 512MB |  |  |  |  |  |
| 14                      | n/a                        | 512MB | 1GB   |  |  |  |  |  |
| Page Size               | 4KB                        | 8KB   | 16KB  |  |  |  |  |  |

Table indicates 64-bit wide memory subsystem sizes. For 32-bit wide memory, memory subsystem and page size are half
of the size indicated.

The supported SDRAM devices comprise four internal leaves. The MCU controls the leaf selects within the SDRAM by toggling **BA[0]** and **BA[1]**.

#### Table 219. Bank Address Decode

| Bank Size <sup>a</sup> | Leaf Select |          |  |  |  |  |
|------------------------|-------------|----------|--|--|--|--|
| Dalik Size             | BA[1]       | BA[0]    |  |  |  |  |
| 64M                    | I_AD[25]    | I_AD[24] |  |  |  |  |
| 128M                   | I_AD[26]    | I_AD[25] |  |  |  |  |
| 256M                   | I_AD[27]    | I_AD[26] |  |  |  |  |
| 512M                   | I_AD[28]    | I_AD[27] |  |  |  |  |
| 1G                     | I_AD[29]    | I_AD[28] |  |  |  |  |

a. Table indicates 64-bit wide memory bank sizes. For 32-bit wide memory, bank size is half of the size indicated.

Two DDR SDRAM chip enables (**CS**[1:0]#) support DDR SDRAM memory subsystem consisting of two banks. Base address for two contiguous banks are programmed in DDR SDRAM Base Register (SDBR) and must be aligned to a 32 Mbyte boundary. Size of each DDR SDRAM bank is programmed with DDR SDRAM boundary registers (SBR0 and SBR1). Bank 0 is configurable into multiple regions. By default bank 0 is a single 64-bit region. For higher core data processing performance, a 32-bit region can be defined within Bank 0 with the DDR SDRAM 32-bit Region Size Register (S32SR).

Table 220 is used to determine which DDR SDRAM address decode is used to program "SDRAM Boundary Register 0 - SBR0" and "SDRAM Boundary Register 1 - SBR1".

#### Table 220. DDR SDRAM Address Decode Summary

| Row Address Size (bits) | Column Address Size (bits) |    |     |  |  |  |  |
|-------------------------|----------------------------|----|-----|--|--|--|--|
| Now Address Size (bits) | 9                          | 10 | 11  |  |  |  |  |
| 12                      | 1                          | 1  | n/a |  |  |  |  |
| 13                      | 2                          | 1  | 1   |  |  |  |  |
| 14                      | n/a                        | 3  | 1   |  |  |  |  |



Table 221, Table 222 and Table 223 illustrate the address decodes listed in Table 220. These tables show how the internal address is mapped to the **MA[13:0]** lines for DDR SDRAM devices.

DDR SDRAM Address decode #1 is the normal translation used for most memory configurations. When the column and row address size is less than shown in Table 220, the unused address lines are still driven with the internal bus address shown.

#### Table 221. DDR SDRAM Address Decode #1

| MA[13:0] | 13       | 12       | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| Row      | I_AD[27] | I_AD[25] | I_AD[23] | I_AD[22] | I_AD[21] | I_AD[20] | I_AD[19] | I_AD[18] | I_AD[17] | I_AD[16] | I_AD[15] | I_AD[14] | I_AD[13] | I_AD[12] |
| Column   | -        | -        | I_AD[26] | $V^1$    | I_AD[24] | I_AD[11] | I_AD[10] | I_AD[9]  | I_AD[8]  | I_AD[7]  | I_AD[6]  | I_AD[5]  | I_AD[4]  | I_AD[3]  |

#### NOTES:

- 1. A10 is used for precharge variations on the read or write command. See Table 228 for more details.
- 2. For the Leaf Selects, see Section 8.3.3.2.

DDR SDRAM Address translation #2 presents **I\_AD[24]** as bit 12 of the row address instead of **I\_AD[25]** as in Address decode #1.

#### Table 222. DDR SDRAM Address Decode #2

| MA[12:0] | 13       | 12       | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| Row      | I_AD[27] | I_AD[24] | I_AD[23] | I_AD[22] | I_AD[21] | I_AD[20] | I_AD[19] | I_AD[18] | I_AD[17] | I_AD[16] | I_AD[15] | I_AD[14] | I_AD[13] | I_AD[12] |
| Column   | -        | -        | I_AD[26] | $V^1$    | I_AD[24] | I_AD[11] | I_AD[10] | I_AD[9]  | I_AD[8]  | I_AD[7]  | I_AD[6]  | I_AD[5]  | I_AD[4]  | I_AD[3]  |

#### NOTES:

- 1. A10 is used for precharge variations on the read or write command. See Table 228 for more details.
- 2. For the Leaf Selects, see Section 8.3.3.2.

DDR SDRAM Address decode #3 presents **I\_AD[26]** as bit 13 of the row address instead of **I\_AD[27]** as in Address decode #1.

#### Table 223. DDR SDRAM Address Decode #3

| MA[12:0] | 13       | 12       | 11       | 10       | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| Row      | I_AD[26] | I_AD[25] | I_AD[23] | I_AD[22] | I_AD[21] | I_AD[20] | I_AD[19] | I_AD[18] | I_AD[17] | I_AD[16] | I_AD[15] | I_AD[14] | I_AD[13] | I_AD[12] |
| Column   | -        | -        | I_AD[26] | $V^1$    | I_AD[24] | I_AD[11] | I_AD[10] | I_AD[9]  | I_AD[8]  | I_AD[7]  | I_AD[6]  | I_AD[5]  | I_AD[4]  | I_AD[3]  |

#### NOTES:

- 1. A10 is used for precharge variations on the read or write command. See Table 228 for more details.
- 2. For the Leaf Selects, see Section 8.3.3.2.

Since the MCU supports DDR SDRAM bursting, the MCU increments the column address based on the burst length of four for each DDR SDRAM read or write burst. The MCU supports a sequential and random burst types. Sequential bursting means that the address issued to the DDR SDRAM is incremented by the DDR SDRAM device in a linear fashion during the burst cycle. Random bursting means that the address issued to the DDR SDRAM is any address in a currently active page.



## 8.3.3.3 DDR SDRAM Configuration

#### Table 224. DDR SDRAM Address Register Summary

| DDR SDRAM Address Register                | Definition                                                                                                                                                         |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DDR SDRAM Base Register (SDBR)            | Lowest address for DDR SDRAM memory space aligned to a 32-Mbyte boundary.                                                                                          |
| DDR SDRAM Boundary Register 0 (SBR0)      | The upper address boundary for bank 0 of DDR SDRAM memory space. SBR0 must be greater than or equal to the value of SDBR[30:25].                                   |
| DDR SDRAM Boundary Register 1 (SBR1)      | The upper address boundary for bank 1 of DDR SDRAM memory space. SBR1 must be greater than or equal to SBR0.                                                       |
| DDR SDRAM 32-Bit Size<br>Register (S32SR) | The size for the memory space to operate as 32-bit memory (in MBs). S32SR must be less than, or equal to 1/2 of bank 0 size. Ignored with a 32-bit data bus width. |

**Note:** DDR SDRAM memory space must be aligned to a 32 Mbyte boundary and must **never** cross a 2 Gbyte boundary.

#### Figure 62. DDR SDRAM 64-bit Memory Address Map



#### Figure 63. FDDR SDRAM 64-bit Physical Map



Figure 62 illustrates the Intel<sup>®</sup> 80331 I/O processor DDR SDRAM 64-bit Memory Address Map, and Figure 63 illustrates the Physical map of the 64-bit DDR SDRAM. The size of each region is configured separately. The 32-bit region is only applicable when the 80331 is connected to 64-bit DDR SDRAM memory. With 32-bit DDR SDRAM attached to 80331, all DDR SDRAM memory space behaves as 32-bit DDR SDRAM and the value in S32SR is ignored.



When the 32-bit region defined by S32SR is greater than zero, bank 0's address space is split into three regions as illustrated in Figure 62. The lowest addressable region operates as a 32-bit region of size defined in the S32SR. A second region, contiguous with the 32-bit region, and equal in size, is defined as invalid for the DDR SDRAM memory space. This invalid region reflects the other half of the 64-bit DDR SDRAM which is not used in the 32-bit region. Transactions which address this region will result in an error and interrupt to the Intel<sup>®</sup> XScale<sup>TM</sup> core. The third region is contiguous with the second and is the remainder of bank 0 address space, and is a 64-bit region.

The base register defines the upper seven address bits of the DDR SDRAM memory space. The boundary registers define the address limits for each DDR SDRAM bank in 32 Mbyte granularity. Table 225 defines the conditions which must be satisfied to activate a DDR SDRAM memory bank.

#### Table 225. Address Decoding for DDR SDRAM Memory Banks

| Condition                                                                                                                        | DDR SDRAM Bank Selected |
|----------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| AD[31] is not equal to the SDBR[31]                                                                                              | None                    |
| AD[31] is equal to the SDBR[31] AD[30:25] is greater than or equal to the SDBR[30:25] AD[30:25] is less than the value in SBR0   | Bank 0                  |
| AD[31] is equal to the SDBR[31] AD[30:25] is greater than or equal to the value in SBR0 AD[30:25] is less than the value in SBR1 | Bank 1                  |
| AD[31] is equal to the SDBR[31] AD[30:25] is greater than or equal to the value in SBR1                                          | None                    |

Table 226 shows the correct programming values for the DDR SDRAM Bank Size encoding.

#### Table 226. Programming Codes for the DDR SDRAM Bank Size

| Bank Size | Code | Bank Size | Code |
|-----------|------|-----------|------|
| Empty     | 00H  | 256MB     | 08H  |
| 32MB      | 01H  | 512MB     | 10H  |
| 64MB      | 02H  | 1GB       | 20H  |
| 128MB     | 04H  |           |      |

These Bank Size Codes are used in the calculation of the DDR SDRAM boundary registers programming values. Equation 5 and Equation 6 show the required equations to calculate the programming values for the DDR SDRAM boundary registers.

#### Equation 5. Programming Value for DDR SDRAM Boundary Register 0 (SBR0[6:0])

SBR0[6:0] = Bank 0 Size Code + SDBR[30:25]

#### Equation 6. Programming Value for DDR SDRAM Boundary Register1 (SBR1[6:0])

SBR1[6:0] = Bank 1 Size Code + SBR0[6:0]



Table 227 shows the correct programming values for the 32-bit DDR SDRAM Size Register.

#### Table 227. Programming Values for the DDR SDRAM 32-bit Size Register (\$32\$R[29:20])

| 32-bit Region Size | S32SR[29:20] | 32-bit Region Size | S32SR[29:20]     |
|--------------------|--------------|--------------------|------------------|
| Empty              | 000H         | 32M                | 020H             |
| 1M                 | 1M 001H 64M  |                    | 040H             |
| 2M                 | 002H         | 128M               | 080H             |
| 4M                 | 004H         | 256M               | 100H             |
| 8M                 | 008H         | 512M               | 200H             |
| 16M                | 010H         | reserved           | all other values |

## **Example 2. Address Register Programming Example 1**

The user wants to program the DDR SDRAM memory space to begin at B000 0000H. Bank 0 is 64 Mbytes and Bank 1 is 128 Mbytes yielding in a total memory of 192 Mbytes. There is no 32-bit memory region. The memory space summary is:

| Memory Space Limit                       | Address    |  |  |
|------------------------------------------|------------|--|--|
| DDR SDRAM Base                           | B000 0000H |  |  |
| 32-Bit Region Top (end 32-bit region)    | n/a        |  |  |
| Invalid Region Top (start 64-bit region) | n/a        |  |  |
| Bank 0 Top                               | B3FF FFFFH |  |  |
| Bank 1 Top                               | BBFF FFFFH |  |  |

The registers would be programmed as follows:

Bank 0 Size = 64 MB, code = 000010<sub>2</sub> Bank 1 Size = 128 MB, code = 000100<sub>2</sub> SDBR = B000 0000H, SDBR[30:25] = 011000<sub>2</sub> SBR0[6:0] = 011010<sub>2</sub> = 1AH SBR1[6:0] = 011110<sub>2</sub> = 1EH S32SR[29:20] = 0H, S32SR = 0H

#### **Example 3. Address Register Programming Example 2**

The user wants to program the DDR SDRAM memory space to begin at A000 0000H. Bank 0 is 64 Mbytes and Bank 1 is un-populated. There is a 4 MB 32-bit region. The memory space summary is:

| Memory Space Limit                       | Address    |  |  |
|------------------------------------------|------------|--|--|
| DDR SDRAM Base                           | A000 0000H |  |  |
| 32-Bit Region Top (end 32-bit region)    | A03F FFFFH |  |  |
| Invalid Region Top (start 64-bit region) | A07F FFFFH |  |  |
| Bank 0 Top                               | A3FF FFFFH |  |  |
| Bank 1 Top                               | n/a        |  |  |

The registers would be programmed as follows:

Bank 0 Size = 64 MB, code = 000010<sub>2</sub> Bank 1 Size = empty, code = 000000<sub>2</sub>

SDBR = A000 0000H, SDBR[30:25] =  $000000_{2}$ 

 $SBR0[6:0] = 000010_2 = 02H$  $SBR1[6:0] = 000010_2 = 02H$ 

S32SR[29:20] = 004H,  $S32SR = 0040\ 0000H$ 



#### **Example 4. Address Register Programming Example 3**

The user wants to program the DDR SDRAM memory space to begin at C000 0000H. Bank 0 is 512 Mbytes and Bank 1 is 512 Mbytes yielding a total memory of 1 Gbyte. The 32-bit memory region is 256 Mbytes (Bank 0 is entirely 32-bit region). The memory space summary is:

| Memory Space Limit                       | Address     |  |  |
|------------------------------------------|-------------|--|--|
| DDR SDRAM Base                           | C000 0000H  |  |  |
| 32-Bit Region Top (end 32-bit region)    | CFFF FFFFH  |  |  |
| Invalid Region Top (start 64-bit region) | DFFF FFFFH  |  |  |
| Bank 0 Top                               | DFFF FFFFH  |  |  |
| Bank 1 Top                               | FFFF DFFFH* |  |  |

*Note:* Bank 1 Top is limited by PMMR space overlap at FFFF E000H in this example.

The registers would be programmed as follows:

Bank 0 Size = 512 MB, code = 010000<sub>2</sub> Bank 1 Size = 512 MB, code = 010000<sub>2</sub>

SDBR =  $C000\ 0000H$ , SDBR[30:25] =  $010000_2$ 

 $SBR0[6:0] = 100000_2 = 40H$ 

 $SBR1[6:0] = 110000_2 = 50H$ 

S32SR[29:20] = 100H, S32SR = 1000 0000H

#### Example 5. Address Register Programming Example 4

The user wants to program the DDR SDRAM memory space to begin at 0000 0000H. Bank 0 is 1 Gbyte and Bank 1 is 1 Gbyte yielding a total memory of 2 Gbytes. There is a 128MB 32-bit region. THis configuration also requires that the ATU Outbound Direct Addressing window be disabled before configuring the MCU for 2 Gbytes. The memory space summary is:

| Memory Space Limit                       | Address    |  |  |
|------------------------------------------|------------|--|--|
| DDR SDRAM Base                           | 0000 0000H |  |  |
| 32-Bit Region Top (end 32-bit region)    | 01FF FFFFH |  |  |
| Invalid Region Top (start 64-bit region) | 03FF FFFFH |  |  |
| Bank 0 Top                               | 3FFF FFFFH |  |  |
| Bank 1 Top                               | 7FFF FFFFH |  |  |

The registers would be programmed as follows:

Bank 0 Size = 1 GB, code =  $100000_2$ 

Bank 1 Size = 1 GB, code =  $100000_2$ 

SDBR =  $0000\ 0000$ H, SDBR[30:25] =  $000000_2$ 

 $SBR0[6:0] = 0100000_2 = 20H$ 

 $SBR1[6:0] = 10000000_2 = 40H$ 

S32SR[29:20] = 080H, S32SR = 0800 0000H



#### 8.3.3.4 32-bit Data Bus Width

Using 64 Mbit SDRAMs, a 64-bit data bus yields a minimum memory size of 64 Mbytes. To address cost-sensitive applications requiring less than 64 Mbytes of local memory, the MCU supports a 32-bit data bus. While 32-bit mode decreases the minimum memory size to 32 Mbytes, the bus throughput also reduces by half.

The MCU does not support switching between 32-bit data bus width and 64-bit data bus width. The data bus width is selected by bit 2 of the SDCR (see Section 8.7.2, "SDRAM Control Register 0 - SDCR0" on page 498). The default is 64-bit bus width.

Reducing the data bus width by half also reduces the page size by half. The page sizes listed in Section 8.3.3.2 are listed for a 64-bit data bus, and must therefore are one half for a 32-bit data bus. The MCU disconnects from the internal bus if the page is crossed during a burst read or write.

## 8.3.3.5 Page Hit/Miss Determination

The MCU keeps up to eight pages open simultaneously; one page each of Bank0/Leaf0, Bank0/Leaf1, Bank0/Leaf2, Bank0/Leaf3, Bank1/Leaf0, Bank1/Leaf1, Bank1/Leaf2, and Bank1/Leaf3. The page size is based on the DDR technology as specified in Section 8.3.3.2.

The MCU logic determines the hit/miss status for reads and writes. For a new DDR SDRAM transaction, the MCU compares the address of the current transaction with the address stored in the appropriate page address register. Given the supported DDR SDRAM devices and two banks, there are eight pages kept open simultaneously. The DDR SDRAM chip enables (CS[1:0]#) and leaf selects (BA[1:0]) determine which page address to compare.

If the current transaction misses the open page selected then the MCU closes the open page pointed to by CS[1:0]# and BA[1:0] by issuing a precharge command. The MCU opens the current page with a row-activate command and the transaction completes with a read or write command. When the MCU opens the current page, the row address from the corresponding memory transaction queue is stored in the page address register pointed to by CS[1:0]# and BA[1:0] so it may be compared for future transactions. See Table 221, Table 222and Table 223 for address mapping to row address.

Once the MARB issues a command to the MCU DDR Control Block, the paging logic makes a hit/miss comparison. The performance is best for page hits and therefore the MCUs behavior is different for the hit and miss scenario.

For a page hit, the MCU does not need to open the page (assert RAS#) and avoids the RAS-to-CAS delay achieving greater performance. The waveform for a write including the row activation in the case of a page miss is illustrated in Figure 74. For a page hit, the two cycles required for row activation are saved resulting in lower first word write latency.

If the current transaction hits the open page, then the page is already active and the **read** or **write** command may be issued without a **row-activate** command. When the next transaction is the same command type as the current transaction, and also a page hit, the MCU does not need to issue the command again, but simply drive column address for an open page.

If the refresh timer expires and the MCU issues an **auto-refresh** command, all pages are closedFigure 73 illustrates the performance benefit of a read hit versus a read miss in Figure 76. Figure 74 illustrates the performance benefit of a write hit versus a write miss in Figure 79.





Figure 64. Logical Memory Image of a DDR SDRAM Memory Subsystem

Figure 64 illustrates how the logical memory image is partitioned with respect to open and closed pages. If the above image represents a 128 Mbyte DDR SDRAM memory size, each bank is 64 Mbytes and each leaf is 16 Mbytes.

Only one page may be open within each of the leaf blocks. The page sizes depend on the memory size implemented in the DDR SDRAM memory subsystem as listed in Section 8.3.3.2. The programmer can optimize DDR SDRAM transactions by partitioning code and data across the leaf boundaries to maximize the number of page hits.



#### 8.3.3.6 On DIMM Termination

The memory controller supports On DIMM Termination (ODT) when controlling DDR-II SDRAM technology. ODT eliminates the need for on board termination resisters, thereby reducing the implementation cost and area. Control for enabling ODT is performed in Section 8.7.2, "SDRAM Control Register 0 - SDCRO" on page 498.

#### 8.3.3.7 DDR SDRAM Commands

The MCU issues specific commands to the DDR SDRAM devices by encoding them on the CS[1:0]#, RAS#, CAS#, and WE# inputs. Table 228 lists all of the DDR SDRAM commands understood by DDR SDRAM devices. The MCU supports a subset of these commands.

#### Table 228. DDR SDRAM Commands

| Command <sup>a,b</sup>     | Conditions |      |      |      | Comments                                            |                                                                  |  |
|----------------------------|------------|------|------|------|-----------------------------------------------------|------------------------------------------------------------------|--|
| Command                    | SCE#       | RAS# | CAS# | SWE# | Other                                               | Comments                                                         |  |
| NOP                        | 0          | 1    | 1    | 1    |                                                     | No Operation                                                     |  |
| Mode Register Set          | 0          | 0    | 0    | 0    | <b>BA[0]</b> = Sel <sup>c</sup><br><b>BA[1]</b> = 0 | Load the (Extended) Mode<br>Register from MA[13:0]               |  |
| Row Activate               | 0          | 0    | 1    | 1    | <b>BA[1:0]</b> = Leaf                               | Activate a row specified on MA[13:0]                             |  |
| Read                       | 0          | 1    | 0    | 1    | <b>BA[1:0]</b> = Leaf <b>MA[10]</b> = 0             | Column burst read Column address on MA[13:0]                     |  |
| Read w/<br>Auto-Precharge  | 0          | 1    | 0    | 1    | <b>BA[1:0]</b> = Leaf <b>MA[10]</b> = 1             | Column burst read with row precharge at the end of the transfer  |  |
| Write                      | 0          | 1    | 0    | 0    | <b>BA[1:0]</b> = Leaf <b>MA[10]</b> = 0             | Column burst write Column address on MA[13:0]                    |  |
| Write w/<br>Auto-Precharge | 0          | 1    | 0    | 0    | <b>BA[1:0]</b> = Leaf <b>MA[10]</b> = 1             | Column burst write with row precharge at the end of the transfer |  |
| Precharge                  | 0          | 0    | 1    | 0    | <b>BA[1:0]</b> = Leaf <b>MA[10]</b> = 0             | Precharge a single leaf                                          |  |
| Precharge All              | 0          | 0    | 1    | 0    | <b>MA[10]</b> = 1                                   | Precharge all leaves                                             |  |
| Auto-Refresh               | 0          | 0    | 0    | 1    |                                                     | Refresh both banks from on-chip refresh counter                  |  |
| Self-Refresh               | 0          | 0    | 0    | 1    | <b>CKE</b> = 0                                      | Refresh autonomously while CKE = 0                               |  |
| Power Down                 | Х          | Х    | Х    | Х    | <b>CKE</b> = 0                                      | Power down if both banks precharged when <b>CKE</b> = 0          |  |
| Stop                       | 0          | 1    | 1    | 0    |                                                     | Interrupt a read or write burst.                                 |  |

a. This table copied from New DRAM Technologies by Steven Przybylski.

DDR SDRAM commands are synchronous to the clock so the MCU sets up the above conditions prior to the M\_CK[2:0] rising edge.

b. Shaded boxes indicate commands not supported by 80331. They are included for completeness.

c. During a Mode Register Set command, BA[1:0] = 002 selects the Mode Register, BA[1:0] = 012 selects the Extended Mode Register, all others are served.



#### 8.3.3.8 DDR SDRAM Initialization

Since DDR SDRAM devices contain a controller within the device, the MCU must initialize them specifically. Upon the deassertion of **I\_RST#**, software initializes the DDR SDRAM devices with the sequence illustrated with Figure 68:

- The MCU applies the clock (M\_CK[2:0]) at power up along with system power (clock frequency unknown).
- 2. The MCU must stabilize M\_CK[2:0] within 100 µs after power stabilizes.
- 3. The MCU holds all the control inputs inactive (RAS#, CAS#, WE#, SCE[1:0]# = 1), places all data outputs and strobes in the High-Z state (DQS[8:0], DQ[71:0]), and deasserts CKE[1:0] for a minimum of 200 us after supply voltage reaches the desired level. Asserting P\_RST# achieves this state.
- 4. Software disables the refresh counter by setting the RFR to zero.
- 5. Software issues one **NOP** cycle after the 200 us device deselect. A **NOP** is accomplished by setting the SDIR to 0011<sub>2</sub>. The MCU asserts **CKE[1:0]** with the NOP.
- Software issues a precharge-all command to the DDR SDRAM interface by setting the SDIR to 0010<sub>2</sub>.
- 7. Software issues an extended-mode-register-set command to enable the DLL by writing 0100<sub>2</sub> to the SDIR. The MCU supports the following DDR and DDR-II SDRAM mode parameters:
  - a. DLL = Enable/Disable
  - b. Off-Chip Driver (OCD) Impedance Adjustment (set DCAL registers) applies to DDR-II SDRAM only.
  - c. Additive Latency (AL) is always zero for 80331.

#### Figure 65. Supported DDR SDRAM Extended Mode Register Settings





Figure 66. Supported DDR-II SDRAM Extended Mode Register Settings



- 8. After waiting T<sub>mrd</sub> cycles, software issues a **mode-register-set** command by writing 0001<sub>2</sub> to the SDIR to program the DDR SDRAM parameters and to **Reset** the DLL. The MCU supports the following DDR SDRAM mode parameters:
  - a. CAS Latency (tCAS) = two and one-half for DDR, or three or four for DDR-II based on the programmed setting in Section 8.7.2, "SDRAM Control Register 0 SDCR0"
  - b. Burst Type = Sequential
  - c. Burst Length (BL) = four

Figure 67. Supported DDR SDRAM Mode Register Settings



- 9. After waiting T<sub>mrd</sub> cycles, software issues a **precharge-all** command to the DDR SDRAM interface by setting the SDIR to 0010<sub>2</sub>.
- 10. After waiting  $T_{rp}$  cycles, software provides two **auto-refresh** cycles. An **auto-refresh** cycle is accomplished by setting the SDIR to  $0110_2$ . Software must ensure at least  $T_{rfc}$  cycles between each **auto-refresh** command.
- 11. Following the second auto-refresh cycle, software must wait T<sub>rfc</sub> cycles. Then, software issues a mode-register-set command by writing to the SDIR to program the DDR SDRAM parameters without resetting the DLL by writing 0000<sub>2</sub> to the SDIR.
- 12. The MCU may issue a **row-activate** command T<sub>mrd</sub> cycles after the **mode-register-set** command.
- 13. Software re-enables the refresh counter by setting the RFR to the required value.

CAS latency of 3 is not supported.



The waveform in Figure 68 illustrates the DDR SDRAM initialization sequence.

Figure 68. DDR SDRAM Initialization Sequence (controlled with software)



If the DDR SDRAM subsystem implements ECC (see Section 8.3.4, "Error Correction and Detection" on page 476), then initialization software should initialize the entire memory array with the 80331. It is important that every memory location has a valid ECC byte. The AAU includes a memory block fill mode which can be used to fill the memory array with a constant (Section 7.5.3, "Memory Block Fill Operation" on page 404), thereby initializing the associated ECC bytes in the process. A small portion of memory must be initialized by the Intel<sup>®</sup> XScale TM core processor software to store the AAU descriptor. If the memory array is not initialized, the BIU may attempt to read memory locations beyond the specified word(s). In this case, the MCU will report an ECC error even though software did not specifically request the un-initialized data.



## 8.3.3.9 DDR SDRAM Mode Programming

The MCU programs the DDR SDRAM devices through a **mode-register-set** command. During the initialization sequence this command sets the DDR SDRAM mode register (see Section 8.3.3.8, "DDR SDRAM Initialization" on page 461) by programming the SDIR and SDCR[1:0].

The DDR SDRAM state machine ensures that a **row-activate** command is issued no sooner than  $T_{mrd}$  cycles after the **mode-register-set** command.

The values to be programmed in the SDCR[1:0] registers are based on the SDRAM devices being interfaced to 80331. Because the parameters that define the time between allowed commands are programmable, this allows flexibility in the type of DDR device that is selected, in addition to de-coupling the hardware to any frequency dependencies.

*Note:* The MCU\_DDRSM will NOT interact properly with the DDR SDRAM until the SDCR[1:0] registers have been programmed.

The duration between valid commands must be programmed by the user before the DDRSM can interact properly with the DDR. These parameters programmed or used to in calculations are listed in Table 229, and are defined by either JEDEC and/or within this document in the timing diagrams and equations in this section. See Section 8.7.2, "SDRAM Control Register 0 - SDCR0" on page 498 and Section 8.7.3, "SDRAM Control Register 1 - SDCR1" on page 500 for exact format of these registers.

Table 229. SDCR[1:0] Timing Parameters Summary

| Parameter         | Source | Use                                                                                        | Parameter | Source                      | Use                                                    |
|-------------------|--------|--------------------------------------------------------------------------------------------|-----------|-----------------------------|--------------------------------------------------------|
| tBL               | JEDEC  | Equation 7,<br>Equation 8,<br>Equation 9                                                   | tRTCMD    | Equation 7                  | SDCR1[30:28]                                           |
| tCAS              | JEDEC  | Equation 7,<br>Equation 8,<br>Equation 9,<br>Equation 10<br>Figure 66<br>and<br>SDCR0[9:8] | tRTW      | Equation 7                  | SDCR1[22:20]                                           |
| tEDP <sup>a</sup> | 80331  | Equation 7<br>and<br>SDCR0[17:16]                                                          | tWL       | Equation 10<br>and<br>JEDEC | Equation 8,<br>Equation 9,<br>Equation 11<br>Figure 66 |
| tRAS              | JEDEC  | SDCR0[31:28]                                                                               | tWDL      | Equation 11                 | SDCR0[13:12]                                           |
| tRC               | JEDEC  | SDCR1[8:4]                                                                                 | tWR       | JEDEC                       | Equation 9 and<br>SDCR1[11:9]                          |
| tRCD              | JEDEC  | SDCR0[22:20]                                                                               | tWTR      | JEDEC                       | Equation 8                                             |
| tRFC              | JEDEC  | SDCR1[16:12]                                                                               | tWTRD     | Equation 8                  | SDCR1[2:0]                                             |
| tRP               | JEDEC  | SDCR0[26:24]                                                                               | tWTCMD    | Equation 9                  | SDCR1[26:24]                                           |

a. tEDP default value is 1 (01<sub>2</sub>) and must be programmed to a value of 2 (10<sub>2</sub>) in the SDCR0.



The timing parameters for all non-read and non-write commands are derived directly from the *JEDEC Standard Double Data Rate (DDR) SDRAM Specification JESD79*, June 200 and *JEDEC DDR - II SDRAM Specification*, September 2002. These parameters, and their relationship to each other, are outlined in Figure 69. Please see the JEDEC specification for the timing parameters specific to the DDR device that is to be implemented in the system.

Figure 69. MCU Active, Precharge, Refresh Command Timing Diagram



The timing parameters for DDR reads are defined in Figure 70. Both Read to Write (80331 *tRTW*) and Read to Command (80331 *tRTCMD*) are defined the same. Both parameters take into account CAS latency (**JEDEC**: *tCAS*) and Burst Length (**JEDEC**: *BL*).

*Note:* Burst Length is fixed at four for 80331

To program tRTW and tRTCMD, the user should use the following equation:

#### Equation 7. $tRTW = tRTCMD = tCAS + (BL/2) + tREG + (tEDP^1 - 1) = tCAS + 1 + tREG + tEDP^1$

Where tREG equals:

- 1 = Registered SDRAM
- 0 = Unbuffered SDRAM

The MCU allows for back-to-back reads, so long as they are to a currently open page.

**Document Number: 273942-002** October, 2003 465

<sup>1.</sup> tEDP default value is  $1 (01_2)$  and must be programmed to a value of  $2 (10_2)$  in the SDCR0.



Figure 70. MCU DDR Read Command to Next Command Timing Diagram



The timing parameters for DDR writes are defined in Figure 71. Both Write to Read (80331: *tWTRD*) and Write to Command (80331: *tWTCMD*) are defined in much the same manner, both accounting for Write Latency (**JEDEC**: *tWL*) and Burst Length (**JEDEC**: *BL*). The difference lies in the compensation for Write Recovery (**JEDEC**: *tWR*) and Write to Read (**JEDEC**: *tWTR*).

*Note:* Burst Length is fixed at four for 80331

To program tWTRD and tWTCMD, the user should use the following equations:

Equation 8. tWTRD = tWL + (BL/2) +tWTR + tREG = tCAS + 1 +tWTR + tREG

Equation 9. tWTCMD = tWL + (BL/2) + tWR + tREG = tCAS + 1 + tWR + tREG

Where the following is used for tWL:

#### Equation 10. tWL = AL + tCAS - 1 = 0 + tCAS - 1 = tCAS - 1

and where BL=4, AL=0 and tREG equals:

- 1 for Registered SDRAM
- 0 for Unbuffered SDRAM



To program tWDL, the user should use the following equation:

#### Equation 11. tWDL = tWL - 1 = tCAS - 1 - 1 = tCAS - 2

The MCU allows for back-to-back Writes, so long as they are to an open page.

Figure 71. MCU DDR Write Command to Next Command Timing Diagrams





## 8.3.3.10 DDR SDRAM Read Cycle

The MCU performance is optimized for page hits and the MCUs behavior is different for the hit and miss scenario.

The waveform for a read including the row activation in the case of a page miss is illustrated in Figure 73. For a page hit, the two cycles required for row activation are saved resulting in lower first word read latency.

The MCU supports optimized performance for random address transactions. This optimization eliminates the need of the DDR SDRAM Control Block to issue the transaction command to the DDR array if the previous transaction is the same type (read or write). In addition, the DDR SDRAM Control Block supports pipelining of transactions which allows the column address of the next transaction to be issued before the current transaction's data transfer is completed by the DDR SDRAM devices. These optimizations are illustrated in Figure 72 for random read memory transactions.

#### Figure 72. DDR SDRAM Pipelined Reads









- 1. Each of the MCU inbound memory transaction ports decodes the address to determine if the transaction should be claimed.
  - If the address falls in the DDR SDRAM address range indicated by the SDBR, SBR0, SBR1, and S32SR the MCU claims the transaction and latches the transaction in the respective memory transaction queue.
- 2. Once the MARB selects the highest priority transaction from the memory transaction queues, it forwards the transaction to the DDR SDRAM control block. The DDR SDRAM Control Block decodes the address to determine whether or not any of the open pages are hit.



A read that misses the open pages encounters a miss penalty because the currently open page needs to be closed before the read can be issued to the new page. Refer to Section 8.3.3.5, "Page Hit/Miss Determination" on page 458 for the paging algorithm details. If a page hit occurs, steps 3-4 are skipped by the MCU.

- 3. The DDR SDRAM Control Block closes the currently open page by issuing a **precharge** command to the currently open row. (Not depicted in Figure 68).
  - The DDR SDRAM Control Block waits  $T_{rp}$  cycles after the precharge before issuing the **row-activate** command for the new read transaction.
- 4. The **row-activate** command enables the appropriate row.
  - The DDR SDRAM Control Block asserts RAS#, de-asserts **WE**#, and drives the row address on **MA**[13:0].
- 5. In the following cycle in the case of a page hit or after T<sub>rcd</sub> cycles in the case of a page miss, the DDR SDRAM Control Block asserts CAS#, de-asserts **WE**#, and places the column address on **MA[13:0]**. This initiates the burst read cycle.
- 6. After the CAS latency expires, the DDR SDRAM device drives data to the MCU. A CAS latency of 2 is depicted in Figure 73.
- 7. Upon receipt of the data, the DDR SDRAM Control Block calculates the ECC code from the data and compares it with the ECC returned by the DDR SDRAM array. Section 8.3.4, "Error Correction and Detection" on page 476 explains the ECC algorithm in more detail.
- 8. Assuming the calculated ECC matches the read ECC, the DDR SDRAM Control Block drives the data back to the corresponding memory transaction queue.
- For each burst read issued, the memory controller increments the column address by four.

The MCU continues to return data to the corresponding memory transaction queue based on the byte count of the transaction.



## 8.3.3.11 DDR SDRAM Write Cycle

All write transactions to the DDR SDRAM are posted to the MCU in the memory transaction queues. This implies that the transaction completes between a given port and corresponding unit prior to data being written to the SDRAM array. Once the MARB issues a **write** command from a memory transaction queue to the MCU DDR Control Block, the paging logic makes a hit/miss comparison. The performance is best for page hits and therefore the MCUs behavior is different for the hit and miss scenario.

Write transactions require ECC codes to be generated and stored in the SDRAM array with the data being written. The behavior is different depending on the size of the data being written. Section 8.3.4, "Error Correction and Detection" on page 476 explains the ECC algorithm in more detail.

For a page hit, the MCU does not need to open the page (assert RAS#) and avoids the RAS-to-CAS delay achieving greater performance. The waveform for a write including the row activation in the case of a page miss is illustrated in Figure 74. For a page hit, the two cycles required for row activation are saved resulting in lower first word write latency.

Figure 74. DDR SDRAM Write, 36 Bytes, ECC Enabled, BL=4





- Each of the MCU inbound memory transaction ports decodes the address to determine if the transaction should be claimed.
  - If the address falls in the DDR SDRAM address range indicated by the SDBR, SBR0, SBR1, and S32SR the MCU claims the transaction and latches the transaction in the respective memory transaction queue.
- 2. Once the MARB selects the highest priority transaction from the memory transaction queues, it forwards the transaction to the DDR SDRAM control block. The DDR SDRAM Control Block decodes the address to determine whether or not any of the open pages are hit.
  - The ECC logic generates the ECC code for the data to be written.

A write that misses the open page encounters a miss penalty because the currently open page needs to be closed before the write can be issued to the new page. Refer to Section 8.3.3.5, "Page Hit/Miss Determination" on page 458 for the paging algorithm details. If a page hit occurs, steps 2-3 are skipped by the MCU.

- 3. The DDR SDRAM Control Block closes the currently open page by issuing a **precharge** command to the currently open row.
  - The DDR SDRAM Control Block waits T<sub>rp</sub>cycles after the precharge before issuing the row-activate command for the new write transaction.
- 4. The **row-activate** command enables the appropriate row.
  - The DDR SDRAM Control Block asserts RAS#, de-asserts **WE**#, and drives the row address on **MA[13:0]**.
- 5. After T<sub>rcd</sub> cycles in the case of a page miss, the DDR SDRAM Control Block asserts CAS#, asserts WE#, and places the column address on MA[13:0]. This initiates the burst write cycle. The DDR SDRAM Control Block drives the data to be written and its ECC code to the DDR SDRAM devices.
- The DDR SDRAM Control Block drives the new data to the corresponding memory transaction queue each cycle until the transaction is completed with the byte count expiring, or the transaction is interrupted if preemption conditions are met.
- For each burst issued, the DDR SDRAM Control Block increments the address by four.
- If ECC is enabled, when the data to write is not aligned on an 8 byte boundary (4 byte for 32-bit data bus width or 32-bit region), the DDR SDRAM Control Block will perform a read-modify-write of the entire 8 byte aligned quad-word (4 byte aligned double-word for 32-bit data bus width or 32-bit region) and incorporate the new data while regenerating ECC.

The MCU supports optimized performance for random address transactions. This optimization eliminates the need of the DDR SDRAM Control Block to issue the transaction command to the DDR array if the previous transaction is the same type (read or write). In addition, the DDR SDRAM Control Block supports pipelining of transactions which allows the column address of the next transaction to be issued before the current transaction's data transfer is completed by the DDR SDRAM devices. These optimizations are illustrated in (Figure 75) for random read memory transactions.



Figure 75. DDR SDRAM Pipelined Writes





## 8.3.3.12 DDR SDRAM Refresh Cycle

474

Since the DDR SDRAM is a dynamic memory, the MCU issues a refresh cycle periodically. The interval of these refresh cycles is programmable in the RFR register. The DDR SDRAM device generates the refresh address internally. The MCU initiates two sequential refresh cycles (one per bank) after the MCUs refresh timer expires and any current transaction is complete. The waveform in Figure 76 illustrates the case where the refresh timer expires while the memory bus is not busy.

Figure 76. Refresh While the Memory Bus is Not Busy





- Once the refresh timer expires, the MCU knows that a refresh cycle is necessary.
  - The refresh timer continues to count for the next refresh cycle.
- The MARB allows the current transaction to complete.
  - If the DDR SDRAM Control Block and the DDR SDRAM array are transferring data, or a CMTQ tenure is ongoing, the refresh cycle is queued until the transaction is complete or the CMTQ tenure expires.
- The DDR SDRAM Control Block closes all open pages with a **precharge-all** command to all the populated DDR SDRAM banks.
  - The DDR SDRAM Control Block resets the page register valid bits.
- The DDR SDRAM Control Block issues an auto-refresh command to DDR SDRAM bank 0.
  - This command affects all internal leaves.
- In the next cycle, the DDR SDRAM Control Block issues an auto-refresh command to DDR SDRAM bank 1.
- After T<sub>rfc</sub> cycles, the DDR SDRAM Control Block can service a new transaction or another refresh cycle.

It is recommended that the RFR ("Frequency Register - RFR" on page 512) is programmed with the value to achieve 7.8 us, though some DDR SDRAM devices may provide for the ability to refresh at a period of 15.6 us. The value is based on the frequency of the DDR SDRAM and Table 230 can provides for these two typical values.

#### Table 230. Typical Refresh Frequency Register Values

| DDR Speed | 7.8 μs Value | 15.6 μs Value |
|-----------|--------------|---------------|
| 333 MHz   | A00H         | 1400H         |
| 400 MHz   | C00H         | 1800H         |

The longest possible internal bus transaction is writing a 1 Kbyte burst where each data cycle results in a read-modify-write due to partial writes (see Section 8.3.4.2, "ECC Generation for Partial Writes" on page 478). The longest possible CMTQ tenure is 16 transactions where each of the transaction are page misses and partial writes. Such periods potentially require queueing two refresh cycles.



#### 8.3.4 Error Correction and Detection

The MCU is capable of correcting any single bit errors and detecting any double bit errors in the 80331 DDR SDRAM memory subsystem. ECC enhances the reliability of a memory subsystem by correcting single bit errors caused by electrical noise or occasional alpha particle hits on the DDR SDRAM devices.

Similar to parity, which simply detects single bit errors, error correction requires an additional 8-bit code word for the 64-bit (32-bit) datum. This means that a memory must have the additional 8-bit error correction code (**CB[7:0]**) per 64-bit (32-bit) datum (**DQ[63:0]**) resulting in a 72-bit (40-bit) wide memory subsystem. During DDR SDRAM read cycles, the DDR SDRAM Control Block detects single bit errors and corrects the data prior to returning the data to the respective memory transaction queue. DDR SDRAM write cycles generate the ECC and sends it with the data to the memories.

In the 32-bit region with 64-bit memory, or with 32-bit wide memory, the 80331 will zero extend the 32-bit datum to a 64-bit datum in order to generate, check and correct ECC. This means that a 32-bit datum memory with ECC will result in a 40-bit wide memory since an 8-bit error correction code is still required.

Scrubbing is the process of correcting an error in the memory array. The chance of an unrecoverable multi-bit error increases if the software does not correct a single-bit error in the array. For the 80331, scrubbing is handled by software. If error reporting is enabled, the MCU logs the error type in ELOG0 or ELOG1 and the address in ECAR0 or ECAR1 when an error occurs.



#### 8.3.4.1 ECC Generation

For write operations, the MCU generates the error correction code which is written along with the data. This section describes the operation of the DDR SDRAM Control Block for ECC generation in a 64-bit wide memory and 64-bit region. The same principles apply for 32-bit wide memory and in the 32-bit region in 64-bit wide memory, however the MCU will generate 8-bit wide ECC by zero extending the data to 64-bits The algorithm for a write transaction is:

```
if data to write is 64 bits wide

Generate the ECC_with the G-matrix

Write the new data and ECC

else {Partial Write}

Read entire 64-bit data word from memory

Merge the new data portion with the data from memory

Generate the new ECC with the G-matrix

Write new data and ECC
```

Figure 77 shows how the data logically flows through the ECC hardware for a write transaction.

#### Figure 77. ECC Write Flow



The G-Matrix in Figure 78 generates the ECC. The data to be written is input to the matrix and the output is the ECC code. Each row of the G-Matrix indicates which data bits of **AD[63:0]** needs to be XORed together to form the ECC bit. The resulting ECC bits are driven on **CB[7:0]**.



## 8.3.4.2 ECC Generation for Partial Writes

Figure 78. Intel® 80331 I/O Processor G-Matrix (generates the ECC)

|                    | 32 |     |     | ×   | ×   | ×   |     |     |     |                    | 0  | ×   |     |     |     |                 |     |     | ×   | ×   |
|--------------------|----|-----|-----|-----|-----|-----|-----|-----|-----|--------------------|----|-----|-----|-----|-----|-----------------|-----|-----|-----|-----|
|                    | 33 |     |     | ×   | ×   |     | ×   |     |     |                    | 1  |     | ×   |     |     |                 |     |     | ×   | ×   |
|                    | 34 |     |     | ×   | ×   |     |     | ×   |     |                    | 2  |     |     | ×   |     |                 |     |     | ×   | ×   |
|                    | 35 |     |     | ×   | ×   |     |     |     | ×   |                    | 3  |     |     |     | ×   |                 |     |     | ×   | ×   |
|                    | 36 |     | ×   |     | ×   | ×   |     |     |     |                    | 4  | ×   |     |     |     |                 |     | ×   |     | ×   |
|                    | 37 |     | ×   |     | ×   |     | ×   |     |     |                    | 2  |     | ×   |     |     |                 |     | ×   |     | ×   |
|                    | 38 |     | ×   |     | ×   |     |     | ×   |     |                    | 9  |     |     | ×   |     |                 |     | ×   |     | ×   |
|                    | 39 |     | ×   |     | ×   |     |     |     | ×   |                    | 7  |     |     |     | ×   |                 |     | ×   |     | ×   |
|                    | 40 | ×   |     |     | ×   | ×   |     |     |     |                    | 8  | ×   |     |     |     | >               | <   |     |     | ×   |
|                    | 41 | ×   |     |     | ×   |     | ×   |     |     |                    | 6  |     | ×   |     |     | >               | <   |     |     | ×   |
|                    | 42 | ×   |     |     | ×   |     |     | ×   |     |                    | 10 |     |     | ×   |     | >               | <   |     |     | ×   |
|                    | 43 | ×   |     |     | ×   |     |     |     | ×   |                    | 7  |     |     |     | ×   | >               | <   |     |     | ×   |
|                    | 44 |     | ×   | ×   |     | ×   |     |     |     |                    | 12 | ×   |     |     |     |                 |     | ×   | ×   |     |
|                    | 45 |     | ×   | ×   |     |     | ×   |     |     |                    | 13 |     | ×   |     |     |                 |     | ×   | ×   |     |
| SL                 | 46 |     | ×   | ×   |     |     |     | ×   |     | SL                 | 41 |     |     | ×   |     |                 |     | ×   | ×   |     |
| iŧio               | 47 |     | ×   | ×   |     |     |     |     | ×   | itio               | 15 |     |     |     | ×   |                 |     | ×   | ×   |     |
| Data Bit Positions | 48 | ×   |     | ×   |     | ×   |     |     |     | Data Bit Positions | 16 | ×   |     |     |     | >               | <   |     | ×   |     |
| Bịt                | 49 | ×   |     | ×   |     |     | X   |     |     | Bịt                | 17 |     | ×   |     |     | >               | <   |     | X   |     |
| )ata               | 20 | ×   |     | ×   |     |     |     | ×   |     | Jata               | 18 |     |     | ×   |     | >               | <   |     | ×   |     |
| _                  | 51 | ×   |     | ×   |     |     |     |     | ×   | _                  | 19 |     |     |     | ×   | >               | <   |     | ×   |     |
|                    | 52 | ×   | ×   |     |     | ×   |     |     |     |                    | 20 | ×   |     |     |     | >               | <   | ×   |     |     |
|                    | 53 | ×   | ×   |     |     |     | ×   |     |     |                    | 21 |     | ×   |     |     | >               | <   | ×   |     |     |
|                    | 54 | ×   | ×   |     |     |     |     | ×   |     |                    | 22 |     |     | ×   |     | >               | <   | ×   |     |     |
|                    | 22 | ×   | ×   |     |     |     |     |     | ×   |                    | 23 |     |     |     | ×   | >               | <   | ×   |     |     |
|                    | 99 | ×   | ×   | ×   | ×   |     |     |     | ×   |                    | 24 |     |     |     | ×   | >               | <   | ×   | ×   | ×   |
|                    | 22 |     |     | ×   |     | ×   | ×   | ×   | ×   |                    | 25 | ×   | ×   | ×   | ×   |                 |     |     | ×   |     |
|                    | 28 | ×   | ×   | ×   |     |     |     |     |     |                    | 26 |     |     |     |     | ^               | <   | ×   | ×   |     |
|                    | 29 | ×   |     | ×   | ×   |     |     |     |     |                    | 27 |     |     |     |     | >               | <   |     | ×   | ×   |
|                    | 09 |     |     |     |     |     | ×   | ×   | ×   |                    | 28 |     | ×   | ×   | ×   |                 |     |     |     |     |
|                    | 61 |     |     |     |     | ×   | ×   |     | ×   |                    | 29 | ×   | ×   |     | ×   |                 |     |     |     |     |
|                    | 62 | ×   | ×   | ×   | ×   | ×   |     |     |     |                    | 30 | ×   |     |     |     | >               | <   | ×   | ×   | ×   |
|                    | 63 |     | ×   |     |     | ×   | ×   | ×   | ×   |                    | 31 | ×   | ×   | ×   | ×   |                 |     | ×   |     |     |
|                    |    | CB0 | CB1 | CB2 | CB3 | CB4 | CB5 | CB6 | CB7 |                    |    | CB0 | CB1 | CB2 | СВЗ | Va <sub>2</sub> | 100 | CB5 | CB6 | CB7 |



If the memory transaction writes less than the data bus width programmed in the SDCR, then the DDR SDRAM Control Block translates the write transaction into a read-modify-write transaction. For a partial write, the DDR SDRAM Control Block calculates the ECC for the modified datum and writes it back. So, if an external unit issues a write cycle with partial data to an MCU port, the MCU:

- 1. Issues a 64-bit (32-bit) read.
- 2. Modifies the value with the new portion to be written.
- 3. Calculates the ECC on the modified value.
- 4. Writes the 64-bit (32-bit) value and ECC.

Note: If the MCU detects a single-bit error during the read, it is corrected BEFORE being merged with the write data so the corrected data is written back to the array. If a multi-bit error is detected, the MCU causes an interrupt to the core by writing to the MCISR. The memory location is overwritten by the MCU with the error data but valid ECC, making the contents of memory invalid. For more details on how the MCU handles error conditions, see Section 8.5, "Interrupts/Error Conditions" on page 493.

Figure 79 shows an example where the data of a write is less than 64-bits wide. The waveform illustrates how the DDR SDRAM Control Block issues a read-modify-write cycle for the data  $(D_1)$ .

*Note:* In 32-bit wide memory and in the 32-bit region in 64-bit wide memory, the DDR SDRAM Control Block will still generate 8-bit wide ECC by zero extending the data to 64-bits. A partial write is a write of less then 4-Bytes.



Figure 79. Sub 64-bit DDR SDRAM Write (D<sub>0</sub>)





## 8.3.4.3 ECC Checking

If enabled, the ECC logic uses the following ECC read algorithm. This algorithm corrects the data before it's driven onto the internal bus. The ECC algorithm for a read transaction is:

```
Read 64-bit data and 8-bit ECC
Compute the syndrome by passing the 64-bit data through the G-Matrix and XORing the
8-bit result with the 8-bit ECC
if the syndrome <> 0 {ECC Error}
   Look up in H-matrix to determine error type
   Register the address where the error occurred
   if error is correctable {single bit}
       if single-bit error correction is enabled
           Correct data
           Send corrected data to internal bus
       if single bit error reporting is enabled
           Interrupt core for software scrubbing
   else {uncorrectable}
       if the read cycle is not part of a RMW cycle {read}
           Target-Abort the Internal Bus read transaction.
       else {write requiring RMW}
           Merge the new data portion with the read data from memory
           Generate the new ECC with the G-matrix
           Write new data and ECC
       if multi-bit error reporting is enabled
               Interrupt the core for uncorrectable error
```

When the MCU reads the ECC code from the memory subsystem, it is compared (XORed) with an ECC that the MCU generates from the data read from the memory. The result is called the syndrome. Table 231 shows how the MCU decodes the syndrome for DDR SDRAM read cycles.

#### Table 231. Syndrome Decoding

| Error Type | Symptom                                                                                    |
|------------|--------------------------------------------------------------------------------------------|
| None       | The syndrome is 0000 0000.                                                                 |
| Single-Bit | Use the H-Matrix in Figure 81 to determine which bit the MCU will invert to fix the error. |
| Multi-Bit  | If the Syndrome does not match an 8-bit value in the H-matrix, the error is uncorrectable  |



Figure 80 shows how the data flows through the ECC hardware for a read transaction.

#### Figure 80. ECC Read Data Flow



Figure 81 illustrates the H-Matrix used for decoding the syndrome. For single-bit errors, the H-Matrix indicates the bit that contains the error and consequently, which bit to fix.



Figure 81. Intel® 80331 I/O Processor H-Matrix (indicates the single-bit error location)

|               | 36      |    | ~ |            | ~  | Ţ        | _              |    |    |    |               | 0  | -  |   |            |    |    |            | -  | _  |  |
|---------------|---------|----|---|------------|----|----------|----------------|----|----|----|---------------|----|----|---|------------|----|----|------------|----|----|--|
|               | 37      |    | - |            | -  |          |                | -  |    |    |               | -  |    | - |            |    |    |            | -  | _  |  |
|               | 38      |    | - |            | -  |          |                |    | _  |    |               | 2  |    |   | -          |    |    |            | _  | 1  |  |
|               | 39      |    | - |            | -  |          |                |    |    | _  |               | 3  |    |   |            | -  |    |            | -  | _  |  |
|               | 40      | -  |   |            | -  |          | _              |    |    |    |               | 4  | -  |   |            |    |    | _          |    | 1  |  |
|               | 41      | -  |   |            | -  |          |                | 1  |    |    |               | 2  |    | - |            |    |    | 1          |    | 1  |  |
|               | 42      | -  |   |            | -  |          |                |    | _  |    |               | 9  |    |   | -          |    |    | 1          |    | 1  |  |
|               | 43      | -  |   |            | -  |          |                |    |    | 1  |               | 7  |    |   |            | 1  |    | 1          |    | 1  |  |
|               | 44      |    | - | 1          |    | ,        | 1              |    |    |    |               | 8  | _  |   |            |    | 1  |            |    | 1  |  |
|               | 45      |    | - | -          |    |          |                | -  |    |    |               | 6  |    | - |            |    | -  |            |    | 1  |  |
|               | 46      |    | - | -          |    |          |                |    | -  |    |               | 10 |    |   | -          |    | -  |            |    | 1  |  |
|               | 47      |    | 1 | 1          |    |          |                |    |    | 1  |               | 11 |    |   |            | 1  | -  |            |    | 1  |  |
|               | 48      | 1  |   | 1          |    |          | -              |    |    |    |               | 12 | 1  |   |            |    |    | 1          | 1  |    |  |
|               | 49      | -  |   | -          |    |          |                | 1  |    |    |               | 13 |    | - |            |    |    | -          | -  |    |  |
|               | 20      | -  |   | -          |    |          |                |    | _  |    |               | 14 |    |   | -          |    |    | -          | -  |    |  |
|               | 51      | ~  |   | -          |    |          |                |    |    | -  |               | 15 |    |   |            | -  |    | -          | -  |    |  |
| ø             | 52      | -  | 1 |            |    |          | 1              |    |    |    | s             | 16 | 1  |   |            |    | -  |            | 1  |    |  |
| tion          | 53      | -  | 1 |            |    |          |                | -  |    |    | tion          | 17 |    | 7 |            |    | _  |            | 1  |    |  |
| Bit Positions | 54      | -  | - |            |    |          |                |    | _  |    | Bit Positions | 18 |    |   | -          |    | _  |            | -  |    |  |
| 3it F         | 52      | ~  | ~ |            |    |          |                |    |    | 1  | 3it F         | 19 |    |   |            | -  | -  |            | 1  |    |  |
|               | 26      | ~  | - | -          | -  | <u> </u> |                |    |    | -  |               | 20 | 1  |   |            |    | _  | -          |    |    |  |
|               | 57      |    |   | -          |    |          | _              | -  | _  | -  |               | 21 |    | - |            |    | _  | -          |    |    |  |
|               | 28      | -  | - | -          |    | -        |                |    |    |    |               | 22 |    |   | -          |    | _  | -          |    |    |  |
|               | 29      | ~  |   | -          | -  | _        |                |    |    |    |               | 23 |    |   |            | -  | _  | -          |    |    |  |
|               | 09      |    |   |            |    |          |                | _  | _  | -  |               | 24 |    |   |            | -  | _  | -          | -  | 1  |  |
|               | 61      |    |   |            |    |          | _              | 1  |    | 1  |               | 25 | -  | - | -          | 1  |    |            | 1  |    |  |
|               | 62      | -  | - | -          | -  | Ľ        | _              |    |    |    |               | 26 |    |   |            |    | _  | -          | -  |    |  |
|               | 63      |    | - |            |    |          | _              | -  | _  | -  |               | 27 |    |   |            |    | _  |            | -  | 1  |  |
|               | CB<br>7 |    |   |            |    |          |                |    |    | -  |               | 28 |    | - | -          | 1  |    |            |    |    |  |
|               | CB<br>6 |    |   |            |    |          |                |    | _  |    |               | 29 | -  | - |            | 1  |    |            |    |    |  |
|               | S CB    |    |   |            |    |          |                | 1  |    |    |               | 30 | -  |   |            |    | _  | -          | -  | 1  |  |
|               | CB<br>4 |    |   |            |    |          | _              |    |    |    |               | 31 | -  | - | -          | 1  |    | -          |    |    |  |
|               | cB<br>3 |    |   |            | -  |          |                |    |    |    |               | 32 |    |   | -          | -  | _  |            |    |    |  |
|               | CB<br>2 |    |   | -          |    |          |                |    |    |    |               | 33 |    |   | -          | -  |    | -          |    |    |  |
|               | 2<br>CB |    | - |            |    |          |                |    |    |    |               | 34 |    |   | -          | -  |    |            | -  |    |  |
|               | CB<br>0 | -  |   |            |    | _        |                |    |    |    |               | 35 |    |   | -          | -  |    |            |    | -  |  |
|               |         | So | S | <b>S</b> 2 | S3 |          | S <sub>4</sub> | SS | Se | S7 |               |    | So | S | <b>S</b> 2 | S3 | \$ | <b>S</b> 2 | 9S | S7 |  |
|               |         |    |   |            |    |          |                |    |    |    |               |    |    |   |            |    |    |            |    |    |  |



Referring to Figure 80, the syndrome bits are created by XORing the data bits as indicated by the appropriate row of the G-Matrix in Figure 78 with the corresponding ECC bit. For example, the MCU derives syndrome bit 0 by XORing data bits 0, 4, 8, 12, 16, 20, 25, 29..31, 40..43, 48..56, 58, 59, 62, and ECC bit 0 (physically read on **CB[0]**). The MCU performs eight such XOR operations (one per syndrome bit).

If decoding the syndrome indicates multi-bit error (see Table 231), the transaction results in a target-abort for Internal Bus transactions, or a multi-bit error in the BIU for Core transactions. If an internal bus master detects a target-abort, the master asserts an interrupt to the core. Write cycles are posted to the memory transaction queues, and already completed to the initiating master. For write cycles with a multi-bit error and ECC Error reporting is enabled, the MCU reports the interrupt in the MCISR and interrupts the core.

If the syndrome indicates a single-bit error and single-bit error correction is enabled, the H-Matrix is used to determine the bit in error (see Figure 81). For example, if the syndrome was 1100 0001, the error is with bit 0 of **DO[63:0]**. The MCU inverts bit 0 before driving the data on **AD[63:0]**.

If error reporting is enabled in the ECCR and the MCU detects a single-bit or multi-bit error, the MCU stores the address in ECARx and the syndrome in ELOGx. Then, the MCU signals an interrupt to the core. Software decides how to proceed through an interrupt handler. By registering the address in ECARx, software can identify the faulty DIMM.

For details about the MCU error conditions and how the MMR registers are affected, refer to Section 8.5, "Interrupts/Error Conditions" on page 493.

**Note:** In 32-bit wide memory and in the 32-bit region in 64-bit wide memory, the DDR SDRAM Control Block will still generate 8-bit wide ECC by zero extending the data to 64-bits. A partial write is a write of less then 4-Bytes.

484



### 8.3.4.4 Scrubbing

Fixing the data error in memory is called scrubbing. The 80331 relies on Intel<sup>®</sup> XScale<sup>™</sup> core software to perform the scrubbing. When the MCU detects an error during a read, the MCU logs the address where the error occurred and interrupts the core. The core decides how to fix the error through an interrupt handler. Software could decide to perform the scrubbing on:

- the data location that failed
- the entire row of the data that failed
- the entire memory

For single-bit errors reported on a write transaction scrubbing is not required, as the MCU will have scrubbed the data during the RMW operation. For single-bit errors, the error is fixed by reading the location that failed and writing back the data after the ECC hardware fixed it. The scrubbing routine should read either DWORD of the 64-bit memory space (QWORD aligned location) using a 1d instruction and write the data back with a st instruction. Software should isolate activity on the memory location to guarantee atomicity.

Note:

If the scrubbing routine reads the failed location in order to fix the single-bit error, a second error will be reported. Therefore, software should disable single-bit ECC reporting (ECCR[0]) during the scrubbing routine. Also, the scrubbing routine should be aware that partial writes will automatically scrub the QWORD aligned location if it contains a single-bit ECC error

Multi-bit errors cannot be fixed by the H-Matrix.

#### 8.3.4.4.1 ECC Example Using the H-Matrix

Assume the core writes 1234 5678 9ABC DEF0H to the SDRAM memory space. The Core Address Decoder decodes the address and determines the write should be sent to the Core Memory Transaction Queue. The CMTQ latches the transaction with data 1234 5678 9ABC DEF0H on **AD[63:0]**.

During the next CMTQ tenure, this transaction is processes and the DDR SDRAM Control Block receives the data and must calculate the ECC code.

Using the G-Matrix in Figure 78, the DDR SDRAM Control Block creates each check bit by XORing the appropriate bits in the row. Using 1234 5678 9ABC DEF0H, the ECC code generated is D2H. This code is written with the data to the SDRAM devices on **CB[7:0**].

Assume that bit 17 was corrupted in the array. Therefore, the bit has been inverted from 0 to 1.

At some later point in time, the core wishes to read from the same address. The core issues a read transaction which is latched by the CMTQ after the Core Address Decoder decodes the address and determines the read targets the DDR SDRAM address space. Upon the receipt of 1234 5678 9ABE DEF0H on **DQ[63:0]**, the DDR SDRAM Control Block calculates the syndrome with the G-Matrix in Figure 78. The DDR SDRAM Control Block calculates a syndrome of 52H.

Note:

During a memory write, ECC code is created by XORing the appropriate data bits indicated by the G-Matrix. The syndrome is created during a memory read by XORing the 8-bit value generated by XORing appropriate data bits (**DQ[63:0]**) indicated by the G-Matrix with the check bits (**CB[7:0]**).

Referring to Table 231, if the syndrome is non-zero and matches a value in the H-Matrix, there is a single-bit error that can be fixed. A syndrome of 52H matches a value in the H-Matrix (see Figure 81) which indicates that bit 17 has an error. The DDR SDRAM Control Block inverts bit 17 prior to returning the corrected data on **AD[63:0]**. The MCU returns 1234 5678 9ABC DEF0H on **AD[63:0]**.

Assuming this was the first error, the MCU records the address where the error occurred in ECAR0 and error type in ELOG0. If error reporting is enabled in the ECCR, the MCU writes a 1 to MCISR[0] which generates an interrupt to the core. A software interrupt handler scrubs the array and fixes the error in bit 17. Unless more errors occur, future reads from this location do not result in an error.



#### 8.3.4.5 ECC Disabled

If software disables ECC, the MCU does generate the ECC byte for writes, but does not check the ECC byte for reads. For writes, the MCU will not perform the Read and Modify steps normally performed for a sub 64-bit write as described in Section 8.3.4.2, "ECC Generation for Partial Writes" on page 478. When the Intel<sup>®</sup> XScale To core writes 0's to memory, with ECC disabled, the MCU will pad all sub 64-bit writes with zeros, calculate ECC, and store the ECC value along with the write data.

This mode can be used to initialize ECC and memory from the  $Intel^{®}$  XScale<sup>TM</sup> core. By writing the entire 64-bits of data (two stores by the core), all of the data will be zero, and the ECC value will be updated (twice) with a valid code for zero data.

**Note:** For faster initialization of large memory space, the Block Fill function of the Application Accelerator should be used.

## 8.3.4.6 ECC Testing

Section 8.3.4.4, "Scrubbing" on page 485 explains how the software is responsible for correcting an error in the memory array once it has been detected by the ECC logic. The MCU implements the ECTST register providing the programmer the ability to test error handling software. For write transactions, the ECTST register value is XORed with the generated ECC. This inverts the bits where the mask is set prior to writing the ECC to memory. When the MCU reads the address later, the ECC mismatches and the error condition occurs (see Section 8.5, "Interrupts/Error Conditions" on page 493).



# 8.3.5 Overlapping Memory Regions

The MCU supports two independent memory regions:

- Memory Mapped Register (MMR) Space
- DDR SDRAM Memory Space

The MMR memory space is fixed at FFFF E000H to FFFF FFFFH. Software programs the DDR SDRAM memory space by providing a base address in SDBR, each of the two bank boundaries in SBR0 and SBR1, and the size of the 32-bit region in S32SR if desired.

While it is not recommended, the two ranges could overlap. In the case of a memory space overlap, refer to Table 232 for the priority rules.

#### Table 232. Overlapping Address Priorities

| Priority | Address Region                       |
|----------|--------------------------------------|
| Highest  | Memory Mapped Register Address Space |
| Lowest   | DDR SDRAM Address Space              |

# 8.3.6 DDR SDRAM Clocking

The MCU provides 6 clocks, three positive (M\_CK[2:0]) and three negative (M\_CK[2:0]#), to the DDR SDRAM memory subsystem at the selected DDR SDRAM command rate. The 72-bit 2-bank unbuffered *JEDEC Standard Double Data Rate* (DDR) SDRAM Specification JESD79, June 2000 requires 6 clocks to distribute the loading across eighteen x8 DDR SDRAM components.

These metrics do not measure performance impact of preemption capability.



## 8.4 Power Failure Mode

The 80331 is an I/O processor used in server applications including networking and storage. Specifically, the storage applications supported utilize the 80331 as the IOP for a SCSI RAID disk subsystem and the local memory is used for disk caching. The local memory is used for the temporary storage of disk writes which greatly improves disk performance.

While the host assumes all written data is stored on the non-volatile disk subsystem, the IOP must ensure that eventually all the data in the disk cache is actually stored onto disk.

The power supply could fail to provide power to the I/O subsystem in the case of a power outage or a failed power supply. It is imperative that the cached data within the IOP's local memory is not lost. If power fails, the local memory subsystem must remain powered with a battery backup and some agent must continue to refresh at the appropriate interval specified by the memory component datasheet.

This section defines a mechanism with which the 80331 memory controller ensures that the data within local memory is not lost during a power failure.

# 8.4.1 Theory of Operation

DDR SDRAM technology provides a simple way of enabling data preservation through the **self-refresh** command. This command is issued by the memory controller and the DDR SDRAM will refresh itself autonomously with internal logic and timers. The **self-refresh** command is defined in Table 228.

The DDR SDRAM device will remain in self-refresh mode as long as:

- The device continues to be powered.
- CKE is held low until the memory controller is ready to control the DDR SDRAM once again.

Power to the DDR SDRAM subsystem is ensured with an adequate battery backup and a reliable method for switching between system power and battery power. The memory controller is responsible for deasserting CKE[1:0] when issuing the **self-refresh** command but while power gradually drops, CKE[1:0] must remain deasserted regardless of the state of  $V_{cc}$  powering the 80331.



# 8.4.2 Power Failure Sequence

Figure 82 illustrates the sequence of events during a power failure as defined by *PCI Local Bus Specification*, Revision 2.2.

Figure 82. Power Failure Sequence



# 8.4.2.1 Power Failure Impact on the System

Upon initial power-up a power supply provides the appropriate voltage to the system. The voltage level will increase at a rate that is dependent on the type of power supply used and the components in the system. These variables are not certain, so the power supply often provides a signal called **PWRGD** which indicates the time when the voltage has reached a reliable level. The power supply deasserts **PWRGD** if the voltage level drops below a certain minimum threshold.

*PCI Local Bus Specification*, Revision 2.2 indicates that once **PWRGD** is deasserted, the PCI reset pin (**P\_RST#**) is asserted in order to float the output buffers. In the specification  $T_{fail}$  is defined as the time when **P\_RST#** is asserted in response to the power rail going out of specification.  $T_{fail}$  is the minimum of:

- 500 ns from either power rail going out of specification (exceeding specified tolerances by more than 500mV)
- 100 ns from the 5V rail falling below the 3.3V rail by more than 300mV

## 8.4.2.2 System Assumptions

This proposal makes specific assumptions about the system's behavior during a power failure. If the below assumptions are not guaranteed, it is the vendor's responsibility to ensure them.

1. **P\_RST**# is asserted to the 80331 when there is at least 2 us of reliable power remaining. This is required so that the memory controller can execute it's power-failure state machine in response to the assertion of **P\_RST**#.



# 8.4.3 Memory Controller Response to P\_RST#

If **PWRDELAY** is asserted indicating that an initial power up sequence has completed, the memory controller assumes a power failure condition whenever **P\_RST#** is asserted. **P\_RST#** assertion following an initial power up sequence results in the following sequence of events:

- 1. The Clock/Reset Unit (CRU) will request that the MCU run the power fail sequence depicted in Figure 84 on page 491. The MCU will take the following steps to execute the power fail sequence:
  - a. Gracefully terminate the current transaction.
  - b. Deactivate all DDR SDRAM leaves with the **precharge-all** command.
  - c. After Trp, the MCU will issue a **self-refresh** command to the DDR SDRAM devices one bank at a time and continue to deassert **CKE**[1:0].
- 2. The MCU will notify the CRU that the power fail sequence has completed on the memory bus.
- 3. The CRU will then assert **I\_RST#** to reinitialize all internal bus agents including the MCU.

Note that **I\_RST**# is asserted in response to the assertion of **P\_RST**#. If **P\_RST**# indicates a true power failure (i.e., **PWRDELAY** is asserted), then battery-backup power is supplied to the DDR SDRAM array.

Refer to Figure 83 on page 490 for a high-level state machine representation illustrating the memory controller's behavior during a power failure condition.

Figure 83. Power Failure State Machine



**Note:** Following the request from the CRU to run the power fail sequence, any data that is in the MCUs 1024 byte posted write buffer will be discarded.



Figure 84 on page 491 illustrates the DDR SDRAM waveforms after the assertion of **P\_RST#** during a true power failure.





**CKE[1:0]** must be held low throughout the power-down period. The memory controller drives it low initially with the **self-refresh** command, but an external pull-down is required to continually drive it low when the 80331 loses power. External logic ensures that **CKE[1:0]** is held low after the memory controller initially deasserts it. Likewise, the external logic must stop driving **CKE[1:0]** low once **P\_RST#** is deasserted by the system. Figure 84 shows one example of the external logic required for power failure mode.

Due to the high loading on **CKE** and the requirement of PC200 DDR operation, the memory controller must drive two copies to the DDR SDRAM DIMM. The board layout will distribute the two **CKE[1:0]** signals between the two DDR SDRAM banks equally.

As long as the DDR SDRAM memory subsystem is powered with a battery source and **CKE[1:0]** is held low, the DDR SDRAM preserves its memory image.

When power is restored, the system asserts **P\_RST**# to the 80331. While the 80331 is reset, **CKE[1:0]** is held low by memory controller. After **P\_RST**# is deasserted (and subsequently, **I\_RST**# is deasserted), the 80331 must be re-initialized to reset the DDR SDRAM memory subsystem operating parameters. The first step of DDR SDRAM initialization sequence re-asserts **CKE[1:0]** to ones and the memory controller resumes refreshing. DDR SDRAM initialization sequence does not affect memory contents. For more details about the DDR SDRAM initialization sequence, refer to Section 8.3.3.8, "DDR SDRAM Initialization" on page 461.

491

**Note:** The power failure mechanism in the memory controller is not responsible for maintaining the 80331 state. The purpose of this mechanism is to maintain the memory so that any data cached in the local memory can be flushed once power is restored. Any data queued within the 80331 components (MCU, ATU, DMAs, etc.) will be lost.



## 8.4.3.1 External Logic Required for Power Failure

#### 8.4.3.1.1 Assertion of P\_RST# During Power Failure

The 80331 **P\_RST**# input signal must be asserted if system power goes below 3.0V.

# 8.4.3.1.2 Distinguishing Between a Power Up and a Power Failure P\_RST#Assertion

The 80331 provides a dedicated input pin, **PWRDELAY** that will be used to distinguish between and initial power up and a power failure assertion of **P\_RST#**. This signal should be driven by external circuitry that will assert **PWRDELAY** following the initial deassertion of **P\_RST#**. **PWRDELAY** will not be deasserted until power has truly failed.

This circuitry could consist of a capacitor that is charged up through a FET enabled via deassertion of **P\_RST#**. The only discharge path available to the capacitor would be through a Zener diode connected to VCC, thus **PWRDELAY** would be deasserted only when power has truly failed.

The Clock Reset Unit will **not** request the MCU to run the power failure sequence if **P\_RST#** is asserted while **PWRDELAY** is deasserted.

#### 8.4.3.2 P\_RST# Usage Versus I\_RST#

The memory controller logic is initialized with the assertion of the Internal Bus Reset signal **I\_RST#**. It is important to note that the external logic required for power failure mode uses **P\_RST#** since **I\_RST#** is not available. It is possible to assert **I\_RST#** with either **P\_RST#** or software using the PCI Configuration and Status Register (see Table 125, "PCI Configuration and Status Register - PCSR" on page 253 located in the ATUs MMR space. If software resets the internal bus, the external logic will not function (but it is not required to anyway).



# 8.5 Interrupts/Error Conditions

The MCU has two conditions which require intervention from the Intel<sup>®</sup> XScale<sup>TM</sup> core. If a single-bit error is detected during a read cycle, the MCU can correct the data returned but software needs to fix the error in the memory array. If a multi-bit error is detected, the core decides how to handle the condition. For all ECC errors, the MCU records the requester of the transaction resulting in the error in ELOGx[23:16] and interrupts the core.

If the MCU detects an ECC error during a read or write cycle<sup>1</sup>, MCISR[0] or MCISR[1] is set to 1. Whenever the MCU toggles one of the MCISR bits from 0 to 1, an interrupt is generated to the core.

Table 233 shows how the MCU responds to error conditions.

## Table 233. MCU Error Response

| Error Type                        | MCU Action <sup>a</sup>                                                                                        |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------|
| Single-Bit during a read or write | Fix Error (if ECC error correction enabled in the SDCR)                                                        |
| Multi-bit during a read           | Target Abort the Internal Bus transaction or Terminate the Core transaction, notify the BIU of multi-bit error |
| Multi-bit during a write          | New ECC is generated with bad data and written to DDR SDRAM array. Data location is no longer valid.           |

a. The ECC Enable bit in the SDCR needs to be set in order for these actions to occur.

**Note:** If ECC reporting is enabled with ECCR[1] or ECCR[0] and an ECC error occurs, MCISR[1] or MCISR[0] is set and ELOGx/ECARx logs the error in addition to Table 233 actions.

**Document Number: 273942-002** October, 2003 493

Any error condition during a write cycle actually occurs while performing the read portion of a read-modify-write on a partial write. See Section 8.3.4.1, "ECC Generation" on page 477 for details.



## 8.5.1 Single-Bit Error Detection

When enabled, the MCU interrupts the core when the ECC logic detects a single-bit error by setting the appropriate bit in the MCISR register. The core knows the interrupt was caused by a single-bit error by polling the ELOG0 or ELOG1 register. The DDR SDRAM Control Block ensures that correct data is returned but the interrupt handler is responsible for scrubbing the error in the array (refer to Section 8.3.4.4, "Scrubbing" on page 485).

An example flow for a single-bit error with error detection and reporting enabled is:

- A single-bit ECC error is detected on the data bus by the MCU.
- The MCU fixes the error prior to returning the data.
- The MCU clears ELOG0[8] indicating a single-bit error.
- The MCU records the requester of the transaction that resulted in an error in ELOG0[23:16]
- The MCU loads ELOG0[7:0] with the syndrome that indicated the error.
- The MCU loads ECAR0[31:2] with address where the error occurred.
- Since the core needs to scrub the error in the array, the MCU sets MCISR[0] to 1 (assuming it is not already set).
  - Setting any bit in the MCISR causes an interrupt to the core.
- Software polls the interrupt status register. Bit 0 set to 1 indicates that the first error has occurred.
- Software polls ELOG0 and ECAR0 and scrubs the error at the location specified by ECAR0.
- Software writes a 1 to MCISR[0] thereby clearing it.

If software does not perform error scrubbing, the probability of an unrecoverable multi-bit error increases for the memory location containing the single-bit error.

ECARx and ELOGx remain registered until software explicitly clears them.

If a second error occurs before software clears the first by resetting MCISR[0] or MCISR[1], the error is recorded in the remaining ELOGx/ECARx register. If none are available, the error is not logged but the MCU carries out the action described in Table 233.

494 October, 2003 **Document Number: 273942-002** 



#### 8.5.2 Multi-bit Error Detection

If a multi-bit error occurs during a read or write transaction and error reporting is enabled, the MCU sets MCISR[0] or MCISR[1] which asserts an interrupt to the core. Upon receiving an interrupt, the core knows the interrupt was caused by a multi-bit error by polling the ELOGx registers.

When MCU detects a multi-bit error during a read cycle and ECC calculation is enabled in the ECCR, the MCU target aborts the transaction in the IBMTQ, indicating to the internal bus masters that an unrecoverable error has been detected. For core transactions issued by the CMTQ, when a multi-bit error is detected during a read cycle, the MCU signals a multi-bit error to the BIU. The MCU records the error type in ELOGx and the address in ECARx.

When MCU detects a multi-bit error during a write<sup>1</sup> cycle and error reporting is enabled in the ECCR, the MCU records the first multi-bit error by programming ELOGx and ECARx. The MCU generates new ECC with the data before sending it on **DQ[63:0]** so the contents of memory after the read-modify-write cycle will be corrupted with correct ECC.

If a second error occurs before software clears the first by resetting MCISR[0] or MCISR[1], the error is recorded in the remaining ELOGx/ECARx register. If none are available, the error is not logged but the MCU carries out the action described in Table 233.

It is interrupt handler responsibility to decide how to handle this error condition and clear the MCISR.

## 8.6 Reset Conditions

Once **I\_RST**# is deasserted and 200 us have passed, software must issue the initialization sequence defined in Section 8.3.3.8, "DDR SDRAM Initialization" on page 461. After initialization, the DDR SDRAM devices are ready to be written to or read from. Reads issued prior to a write to the same address results in an ECC error and are not recommended if ECC is enabled.

While **I\_RST**# is asserted, the MCU initializes its MMR registers to the states defined in Section 8.7, "Register Definitions" on page 496.

**Note:** The operation of any memory transactions are not guaranteed when **P RST**# is asserted.

**Document Number: 273942-002** October, 2003 495

<sup>1.</sup> Any error condition during a write cycle actually occurs while performing the read portion of a read-modify-write on a partial write. See Section 8.3.4.1, "ECC Generation" on page 477 for details.



# 8.7 Register Definitions

A series of configuration registers control the MCU. Software can determine the status of the MCU by reading the status registers. Table 234 lists all of the MCU registers which are detailed further in proceeding sections.

**Note:** Constant polling of MCU MMRs can result in inducing long latencies in peripheral unit DDR SDRAM transactions, and therefore may negatively impact performance. Polling of MCU MMRs should be avoided.

#### Table 234. Memory Controller Register

| Section, Register Name - Acronym (Page)                                           |
|-----------------------------------------------------------------------------------|
| Section 8.7.1, "SDRAM Initialization Register - SDIR" on page 497                 |
| Section 8.7.2, "SDRAM Control Register 0 - SDCR0" on page 498                     |
| Section 8.7.3, "SDRAM Control Register 1 - SDCR1" on page 500                     |
| Section 8.7.4, "SDRAM Base Register - SDBR" on page 501                           |
| Section 8.7.5, "SDRAM Boundary Register 0 - SBR0" on page 502                     |
| Section 8.7.6, "SDRAM Boundary Register 1 - SBR1" on page 503                     |
| Section 8.7.7, "SDRAM 32-bit Region Size Register - S32SR" on page 504            |
| Section 8.7.8, "ECC Control Register - ECCR" on page 505                          |
| Section 8.7.9, "ECC Log Registers - ELOG0, ELOG1" on page 506                     |
| Section 8.7.10, "ECC Address Registers - ECAR0, ECAR1" on page 507                |
| Section 8.7.11, "ECC Test Register - ECTST" on page 508                           |
| Section 8.7.12, "Memory Controller Interrupt Status Register - MCISR" on page 509 |
| Section 8.7.13, "MCU Port Transaction Count Register - MPTCR" on page 510         |
| Section 8.7.14, "MCU Preemption Control Register - MPCR" on page 511              |
| Section 8.7.15, "Frequency Register - RFR" on page 512                            |
| Section 8.7.16, "DCAL Control and Status Register - DCALCSR" on page 513          |
| Section 8.7.17, "DCAL Address Register - DCALADDR" on page 515                    |
| Section 8.7.18, "DCAL Data Registers 17:0 - DCALDATA[17:0]" on page 516           |
| Section 8.7.19, "Receive Enable Delay Register - RCVDLY" on page 521              |
| Section 8.7.20, "Slave Low Mix 0 - SLVLMIX0" on page 522                          |
| Section 8.7.21, "Slave Low Mix 1 - SLVLMIX1" on page 523                          |
| Section 8.7.22, "Slave High Mix 0 - SLVHMIX0" on page 524                         |
| Section 8.7.23, "Slave High Mix 1 - SLVHMIX1" on page 525                         |
| Section 8.7.24, "Slave Length - SLVLEN" on page 526                               |
| Section 8.7.25, "Master Mix - MASTMIX" on page 527                                |
| Section 8.7.26, "Master Length - MASTLEN" on page 528                             |
| Section 8.7.27, "DDR Drive Strength Status Register - DDRDSSR" on page 529        |
| Section 8.7.28, "DDR Drive Strength Control Register - DDRDSCR" on page 530       |
| Section 8.7.29, "DDR Miscellaneous Pad Control Register - DDRMPCR" on page 531    |



# 8.7.1 SDRAM Initialization Register - SDIR

The DDR SDRAM Initialization Register (SDIR) is responsible for programming the operation of the DDR SDRAM device state machines. The SDIR provides a method for software to execute the DDR SDRAM initialization sequence (see Section 8.3.3.8, "DDR SDRAM Initialization" on page 461).

Table 235. DDR SDRAM Initialization Register - SDIR





# 8.7.2 SDRAM Control Register 0 - SDCR0

The SDRAM Control Registers (SDCR[1:0]) are responsible for programming the operation of the DDR SDRAM state machines. The SDCR0 specifies the DIMM type, data bus width, and some SDRAM timing parameters required by the DDR SDRAM state machine as defined in Section 8.3.3.8, "DDR SDRAM Initialization" on page 461 and Section 8.3.3.9, "DDR SDRAM Mode Programming" on page 464. The remaining SDRAM timing parameters required by the DDR SDRAM state machine are set in SDCR1.

Table 236. DDR SDRAM Control Register 0 - SDCR0 (Sheet 1 of 2)





#### Table 236. DDR SDRAM Control Register 0 - SDCR0 (Sheet 2 of 2)





# 8.7.3 SDRAM Control Register 1 - SDCR1

The SDRAM Control Registers (SDCR[1:0]) are responsible for programming the operation of the DDR SDRAM state machines as defined in Section 8.3.3.8, "DDR SDRAM Initialization" on page 461 and Section 8.3.3.9, "DDR SDRAM Mode Programming" on page 464. The SDCR1 specifies the remaining SDRAM timing parameters required by the DDR SDRAM state machine not specified in SDCR0.

Table 237. DDR SDRAM Control Register 1 - SDCR1





# 8.7.4 SDRAM Base Register - SDBR

This register indicates the beginning of SDRAM space. See Section 8.3.3.2, "DDR SDRAM Addressing" on page 452 for usage details. There can be two contiguous physical banks defined by SBR0 and SBR1 in the DDR SDRAM subsystem starting at this address.

Note: DDR SDRAM memory space must never cross a 2 Gbyte boundary.

*Note:* This register should be read back after being written, before the Intel<sup>®</sup> XScale <sup>™</sup> core performs

transactions which address the DDR SDRAM.

Table 238. SDRAM Base Register - SDBR





# 8.7.5 SDRAM Boundary Register 0 - SBR0

This register indicates the upper boundary of SDRAM bank 0 and its memory technology. If bank 0 is unpopulated, SBR0[6:0] is programmed either with all zeros or a number equal to the value in SDBR[30:25]. See Section 8.3.3.2, "DDR SDRAM Addressing" on page 452 for more details and programming examples.

Bank 0 may have multiple regions based on the value in "SDRAM 32-bit Region Size Register - S32SR" on page 504. See Section 8.3.3.2, "DDR SDRAM Addressing" on page 452 for more details

*Note:* DDR SDRAM memory space must *never* cross a 2 Gbyte boundary.

*Note:* This register should be read back after being written, before the Intel<sup>®</sup> XScale <sup>TM</sup> core performs transactions which address the DDR SDRAM.





# 8.7.6 SDRAM Boundary Register 1 - SBR1

This register indicates the upper boundary of SDRAM bank 1 and its memory technology. If bank 1 is unpopulated, SBR1[6:0] is programmed either with all zeroes or a value equal to SBR0[6:0]. If bank 1 is populated, SBR1[6:0] must be programmed greater than or equal to SBR0[6:0]. See Section 8.3.3.2, "DDR SDRAM Addressing" on page 452 for more details and programming examples.

*Note:* DDR SDRAM Memory Space must never cross a 2 Gbyte boundary.

*Note:* This register should be read back after being written, before the Intel<sup>®</sup> XScale<sup>TM</sup> core performs

transactions which address the DDR SDRAM.

Table 240. SDRAM Boundary Register - SBR1





# 8.7.7 SDRAM 32-bit Region Size Register - S32SR

.Defines the size of the 32-bit region located at the base of SDRAM Bank 0. This register must be programmed with a size that is less than or equal to one half of the size of DDR SDRAM Bank 0. Sizes are limited to binary sizes with a minimum size of 1MB. Also, the DDR SDRAM type must be 64-bit, as defined by "SDRAM Control Register 0 - SDCR0" on page 498. See also "SDRAM Boundary Register 0 - SBR0" on page 502 and Section 8.3.3.2, "DDR SDRAM Addressing" on page 452.

This register should be read back after being written, before the Intel<sup>®</sup> XScale<sup>TM</sup> core performs transactions which address the DDR SDRAM.

Table 241. DDR SDRAM 32-bit Region Size Register - S32SR





# 8.7.8 ECC Control Register - ECCR

This register programs the MCU error correction and detection capabilities. The configuration depends on the application's needs but a typical configuration is:

- ECC Mode Enabled
- Enable multi-bit error reporting
- Disable single-bit error reporting
- Enable single-bit error correcting

For more details, see Section 8.3.4, "Error Correction and Detection" on page 476 and Section 8.5, "Interrupts/Error Conditions" on page 493.

Table 242. ECC Control Register - ECCR





# 8.7.9 ECC Log Registers - ELOG0, ELOG1

The ECC Log Registers are responsible for logging the error types detected on the local memory bus. Two errors can be detected and logged. The error type is logged (single-bit or multi-bit) along with the syndrome that indicated the error. For a single-bit error, software can read this syndrome and determine which bit had the error in order to perform scrubbing. For a multi-bit error, the syndrome will not match an entry in the H-Matrix and thus, is uncorrectable (see Table 231, "Syndrome Decoding" on page 481).

The error recorded in ELOG0 corresponds to the address in ECAR0. ELOG1 corresponds to ECAR1.

The ELOGx registers comprise read-only bits and only have meaning if MCISR[0] or MCISR[1] is non-zero. For more details on error handling, see Section 8.3.4, "Error Correction and Detection" on page 476.

AR: MARK - close with Marc on need of syndrome

Table 243. ECC Log Registers - ELOG0, ELOG1

| Attributes 7 Na Ina ha |                      |                                                                                                                       |                                                                                                                                                                                          |  |  |
|------------------------------------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Error #                                                    | Intel <sup>®</sup> X | Scale <sup>™</sup> Core Local Bus Address                                                                             | Attribute Legend: RW = Read/Write                                                                                                                                                        |  |  |
| 0                                                          | FFFF E               | <del></del>                                                                                                           | RV = Reserved RC = Read Clear<br>PR = Preserved RO = Read Only                                                                                                                           |  |  |
| 1                                                          | FFFF E               | 524H                                                                                                                  | RS = Read/Set NA = Not Accessible                                                                                                                                                        |  |  |
| Bit                                                        | Default Description  |                                                                                                                       |                                                                                                                                                                                          |  |  |
| 31:19                                                      | 0                    | Reserved                                                                                                              |                                                                                                                                                                                          |  |  |
| 23:16                                                      | 00Н                  | 00010 000<br>01010 001<br>01101 000<br>01101 001<br>11010 000<br>All Other Codes Are Reserved                         | Bus Function (18:16) Internal Bus Requester  Intel® XScale™ core BIU  ATU  DMA Channel 0  DMA Channel 1  Application Accelerator  the ID and Internal Bus Function is used for both core |  |  |
| 15:13                                                      | 0002                 | Reserved                                                                                                              |                                                                                                                                                                                          |  |  |
| 12                                                         | 02                   | Read or Write: Indicates if the error occurred  0 = Read error  1 = Write Error                                       | d during a read or write transaction.                                                                                                                                                    |  |  |
| 11:09                                                      | 0002                 | Reserved                                                                                                              |                                                                                                                                                                                          |  |  |
| 0.0                                                        | 0                    | ECC Error Type: Indicates the type of error that occurred at this address.  0 = Single Bit Error  1 = Multi-Bit Error |                                                                                                                                                                                          |  |  |
| 80                                                         | 02                   |                                                                                                                       |                                                                                                                                                                                          |  |  |



# 8.7.10 ECC Address Registers - ECAR0, ECAR1

These registers are responsible for logging the addresses where the errors were detected on the local memory bus. Two errors can be detected and logged. The software knows which DDR SDRAM address had the error by reading these registers and decoding the syndrome in the log registers. For error details, see Section 8.3.4, "Error Correction and Detection" on page 476).

Table 244. ECC Address Registers - ECAR0, ECAR1





# 8.7.11 ECC Test Register - ECTST

This register allows testing between the ECC logic and the memory subsystem (Section 8.3.4.6, "ECC Testing" on page 486). To test error handling software, the programmer writes this register with a non-zero masking function. Any subsequent writes to memory stores a masked version of the computed ECC. Therefore, any subsequent reads to these locations result in an ECC error.

Table 245. ECC Test Register - ECTST





# 8.7.12 Memory Controller Interrupt Status Register - MCISR

Setting the MCISR asserts an interrupt to the core. Upon an interrupt, the Intel<sup>®</sup> XScale<sup>TM</sup> core polls the interrupt status register for each unit. The interrupt status register tells the core the reason for the interrupt. The MCU has three interrupt conditions: first ECC error (MCISR[0]), second ECC error (MCISR[1]), and more than two ECC errors (MCISR[2]).

If the MCU detects an ECC error and both MCISR[0] and MCISR[1] are cleared, the error is logged in ELOG0 and MCISR[0] is set to 1. If one of the MCISR bits are not clear and the MCU detects an error, the error is logged in the unused ELOGx register and the appropriate MCISR bit is set to 1. If both MCISR[0] and MCISR[1] are not clear, any additional ECC errors are not logged and MCISR[2] is set.

Bits 2:0 are read/clear bits which means that to clear them, software must write a one to these bits.

Table 246. Memory Controller Interrupt Status Register - MCISR





# 8.7.13 MCU Port Transaction Count Register - MPTCR

Sets the number of transactions a given port can have processed during a single tenure. The 4-bit fields for each port allow up to 16 transactions to be processed by a port before the MCU arbiter selects a different port for DDR SDRAM transactions. This register along with the "MCU Preemption Control Register - MPCR" on page 511 used to optimize the memory controller operation.

Table 247. MCU Port Transaction Count Register - MPTCR





# 8.7.14 MCU Preemption Control Register - MPCR

Enables Preemption of IB port transaction when a core processor transaction is pending.

Table 248. MCU Preemption Control Register - MPCR





# 8.7.15 Frequency Register - RFR

The Refresh Frequency Register is programmed for refreshing the DDR SDRAM subsystem at the specified interval. Writing to the RFR programs the refresh counter with the Refresh Interval. Reading from the RFR results in the value currently within the refresh counter. Refer to Section 230, "Typical Refresh Frequency Register Values" on page 475 for recommended programmed values.

Table 249. Refresh Frequency Register - RFR





## 8.7.16 DCAL Control and Status Register - DCALCSR

This 32 bit register controls and shows status for the DCAL operation.

Table 250. DCAL Control and Status Register - DCALCSR (Sheet 1 of 2)





Table 250. DCAL Control and Status Register - DCALCSR (Sheet 2 of 2)





# 8.7.17 DCAL Address Register - DCALADDR

This 32 bit register supplies address for the DCAL operation selected in Section 8.7.16, "DCAL Control and Status Register - DCALCSR" on page 513. The opcodes use this register to specify the row, column and bank address that should be driven to the DIMMs with the command.

Table 251. DCAL Address Register - DCALADDR





# 8.7.18 DCAL Data Registers 17:0 - DCALDATA[17:0]

These ten 32-bit registers are used to support the different opcodes. The definition of these bits as with the address register changes depending on the operation.

Table 252. DCAL Data Registers 17-0 - DCALDATA[17:0]



516 October, 2003 **Document Number: 273942-002** 



#### 8.7.18.1 Opcode: EMRS OCD Adjust/Drive Commands

The DCAL Data Registers consist of Adjust and Drive fields for each DQS line. The fields are identical for each DQS line and are defined in Table 253. The location of the fields within the DCAL Data Registers is provided in Table 254 following the field definitions.

**Adjust:** A 4-bit value stored as  $0000 \ D_{T3}D_{T2}D_{T1}D_{T0}$  within the byte (MSB to LSB), which is the 4-bit data burst for the OCD adjust command as documented in the latest version of the JEDEC DDR-II Component specification.

*Note:* The bits are reversed, bit 0 in left hand column.

### Table 253. OCD Adjust Field Encoding

| 4-bit burst codes inputs to all DQs |     |     | all DQs | Operation               |                           |
|-------------------------------------|-----|-----|---------|-------------------------|---------------------------|
| DT0                                 | DT1 | DT2 | DT3     | Pull-up driver strength | Pull-down driver strength |
| 0                                   | 0   | 0   | 0       | NOP                     | NOP                       |
| 0                                   | 0   | 0   | 1       | Increase by 1 step      | NOP                       |
| 0                                   | 0   | 1   | 0       | Decrease by 1 step      | NOP                       |
| 0                                   | 1   | 0   | 0       | NOP                     | Increase by 1 step        |
| 1                                   | 0   | 0   | 0       | NOP                     | Decrease by 1 step        |
| 0                                   | 1   | 0   | 1       | Increase by 1 step      | Increase by 1 step        |
| 0                                   | 1   | 1   | 0       | Decrease by 1 step      | Increase by 1 step        |
| 1                                   | 0   | 0   | 1       | Increase by 1 step      | Decrease by 1 step        |
| 1                                   | 0   | 1   | 0       | Decrease by 1 step      | Decrease by 1 step        |
| Other combinations                  |     |     |         | Reserved                |                           |

**Drive:** An 8-bit value stored as  $D_{1S1}D_{1S2}D_{1S3}D_{0S4}D_{0S1}D_{0S2}D_{0S3}D_{0S4}$  within the byte. The  $D_{1SX}$  values represent the 4 samples collected during the EMRS OCD Drive[1] operation and the  $D_{0SX}$  values represent the 4 samples collected during the EMRS OCD Drive[0] operation. After running the Drive[1] and Drive[0] commands, this 8-bit value should be 0xFF to guarantee that the drive strengths are sufficient. If Drive[1] samples do not equal 0xF, then the pull-up driver strength needs to be increased by (at least) one step with the OCD adjust command. If the Drive[0] samples do not equal 0xF, then the pull-down driver strength needs to be increased by (at lease) one step with the OCD adjust command.



Table 254 defines the usage of the DCAL Data Registers for the OCD Adjust/Drive fields.

**Note:** The Adjust fields must be duplicated per DQS as indicated. The Drive fields are also duplicated, and either field (odd or even byte) can be read for the corresponding DQS value.

#### Table 254. OCD Definition of DCALDATA[17:0] Registers

| DCALDATA<br>Register | Bits[31:24] - Byte3 | Bits[23:16] - Byte2 | Bits[15:8] - Byte1 | Bits[7:0] - Byte0 |
|----------------------|---------------------|---------------------|--------------------|-------------------|
| 17                   | Pos                 | ruod                | DQS8 - Adjust      | DQS8 - Adjust     |
| 16                   | Reserved            |                     | DQS8 - Drive       | DQS8 - Drive      |
| 15:12                | Reserved            |                     |                    |                   |
| 11                   | DQS7 - Adjust       | DQS7 - Adjust       | DQS5 - Adjust      | DQS5 - Adjust     |
| 10                   | DQS3 - Adjust       | DQS3 - Adjust       | DQS1 - Adjust      | DQS1 - Adjust     |
| 9                    | DQS6 - Adjust       | DQS6 - Adjust       | DQS4 - Adjust      | DQS4 - Adjust     |
| 8                    | DQS2 - Adjust       | DQS2 - Adjust       | DQS0 - Adjust      | DQS0 - Adjust     |
| 7:4                  | Reserved            |                     |                    |                   |
| 3                    | DQS7 - Drive        | DQS7 - Drive        | DQS5 - Drive       | DQS5 - Drive      |
| 2                    | DQS3 - Drive        | DQS3 - Drive        | DQS1 - Drive       | DQS1 - Drive      |
| 1                    | DQS6 - Drive        | DQS6 - Drive        | DQS4 - Drive       | DQS4 - Drive      |
| 0                    | DQS2 - Drive        | DQS2 - Drive        | DQS0 - Drive       | DQS0 - Drive      |

## 8.7.18.2 Opcode: Receive Enable Calibration

The DCAL Data Registers consist of Write pointer and Vector fields for each DQS line. The fields are identical for each DQS line and are defined below. The location of the fields within the DCAL Data Registers is provided following the field definitions.

Write Pointers (wrptr): A 5-bit value stored as 000x xxxx within the byte. The write pointers should be one-hot encoded value. The legal values are 0x01, 0x02, 0x04, 0x08, and 0x10.

**Sampled High/Low Vectors:** A 64-bit value stored in 2 consecutive registers that contain 1-bit per pass of the receive enable operation. Bit 0 represents the results from pass 0, bit 1 represents the results from pass 1, and so forth. By comparing the sampled high vector to the sampled low vector, the rising/falling edges of DQS can be located. In general, the pattern in each vector should repeat every 8 bits, except where the preamble is located. Legal values: bit x of one (or both) of the sampled high and low vectors should be equal to zero (both should never be equal to one). In other words, a bit-wise AND of the 2 vectors should result in all zeros.

Table 255. Receive Enable Calibration of DCALDATA[9] Register

| Bits  | Description                                                                                                                                                                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | Expected write Pointer when DQS is sampled high. This is when the 1 cycle wide rcvcal pulse ANDed with the DQS signal produces a two small pulses that causes the write pointers to advance twice. The initial value of the write pointer is 0x01, so this value should be programmed to 0x04. |
| 23:16 | Expected write Pointer when DQS is sampled low. This is when the 1 cycle wide rcvcal pulse ANDed with the DQS signal produces a single pulse that causes the write pointers to advance once. The initial value of the write pointer is 0x01, so this value should be programmed to 0x02.       |
| 15:8  | Reserved                                                                                                                                                                                                                                                                                       |
| 7:0   | DRAM I/F ORed wrptr: All of the channel A write pointers are logically ORed to produce this value, which is then compared to the expected sampled high/low write pointers to produce the sampled high/low vectors stored in DCALDATA[8:0]                                                      |



Table 256 defines the usage of the DCAL Data Registers for the Receive Enable fields.

## Table 256. Receive Enable Calibration Definition of DCALDATA[17:0] Registers

| DCALDATA<br>Register | Bits[31:24] - Byte3                                | Bits[23:16] - Byte2               | Bits[15:8] - Byte1 | Bits[7:0] - Byte0      |
|----------------------|----------------------------------------------------|-----------------------------------|--------------------|------------------------|
| 17                   | Expected Write Pointer High Sample                 | Expected Write Pointer Low Sample | Reserved           | DRAM I/F ORed<br>wrptr |
| 16                   | reserved                                           |                                   |                    | DQS8 - wrptr           |
| 15:12                | Reserved                                           |                                   |                    |                        |
| 11                   |                                                    | DQS7 - wrptr                      |                    | DQS6 - wrptr           |
| 10                   | reserved                                           | DQS5 - wrptr                      | reserved           | DQS4 - wrptr           |
| 9                    |                                                    | DQS3 - wrptr                      |                    | DQS2 - wrptr           |
| 8                    |                                                    | DQS1 - wrptr                      |                    | DQS0 - wrptr           |
| 7:4                  | Reserved                                           |                                   |                    |                        |
| 3                    | Cumulative "Sampled High" Vector for passes (63:32 |                                   |                    |                        |
| 2                    | Cumulative "Sampled High" Vector for passes (31:0) |                                   |                    |                        |
| 1                    | Cumulative "Sampled Low" Vector for passes (63:32) |                                   |                    |                        |
| 0                    | Cumulative "Sampled Low" Vector for passes (31:0)  |                                   |                    |                        |



## 8.7.18.3 Opcode: DQS Calibration

The DCAL Data Registers consist of 16-bit field for each DQS line in DQS Calibration mode. The fields are identical for each DQS line and are defined in Table 257. The location of the fields within the DCAL Data Registers is provided following the field definitions in Table 258.

*Note:* Each nibble may have a different left and right edge value, but the calibration will be done across the byte.

#### Table 257. DQS Calibration Field Encodings for DCALDATA[17:0] Registers

| Bits  | Description                                             |  |  |
|-------|---------------------------------------------------------|--|--|
| 15:14 | Right Edge Detection Indicator<br>11 - right edge found |  |  |
| 13:8  | Right edge slavelen[2:1] and slavemix[3:0] values       |  |  |
| 7:6   | Left Edge Detection Indicator 11 - left edge found      |  |  |
| 5:0   | Left edge slavelen[2:1] and slavemix[3:0] values        |  |  |

Table 258 defines the usage of the DCAL Data Registers for the Receive Enable fields.

#### Table 258. DQS Definition of DCALDATA[17:0] Registers

| DCALDATA<br>Register | Bits[31:24] - Byte3 | Bits[23:16] - Byte2 | Bits[15:8] - Byte1 | Bits[7:0] - Byte0 |
|----------------------|---------------------|---------------------|--------------------|-------------------|
| 17                   | rooo                | nuod                | DQS8 - High Nibble |                   |
| 16                   | reserved            |                     | DQS8 - Low Nibble  |                   |
| 15:12                |                     | Rese                | rved               |                   |
| 11                   | DQS7 - High Nibble  |                     | DQS5 - High Nibble |                   |
| 10                   | DQS3 - High Nibble  |                     | DQS1 - High Nibble |                   |
| 9                    | DQS6 - High Nibble  |                     | DQS4 - High Nibble |                   |
| 8                    | DQS2 - High Nibble  |                     | DQS0 - High Nibble |                   |
| 7-4                  | Reserved            |                     |                    |                   |
| 3                    | DQS7 - Low Nibble   |                     | DQS5 - Low Nibble  |                   |
| 2                    | DQS3 - Low Nibble   |                     | DQS1 - Low Nibble  |                   |
| 1                    | DQS6 - Low Nibble   |                     | DQS4 - Low Nibble  |                   |
| 0                    | DQS2 - Low Nibble   |                     | DQS0 - Low Nibble  |                   |

520 October, 2003 **Document Number: 273942-002** 



# 8.7.19 Receive Enable Delay Register - RCVDLY

This 32 bit register consists of a packed 3-bit field for DQS Receive Enable Calibration.

Table 259. Receive Enabled Delay Register - RCVDLY





### 8.7.20 Slave Low Mix 0 - SLVLMIX0

This 32 bit register consists of the first 8 of 9 packed 4-bit fields for dynamic DQS DLL delay for the low nibble.

Table 260. Slave Low Mix 0 - SLVLMIX0





# 8.7.21 Slave Low Mix 1 - SLVLMIX1

This 32 bit register consists of the last 4-bit field for dynamic DQS DLL delay for the low nibble.

Table 261. Slave Low Mix 1 - SLVLMIX1





# 8.7.22 Slave High Mix 0 - SLVHMIX0

This 32 bit register consists of the first 8 of 9 packed 4-bit fields for dynamic DQS DLL delay for the high nibble.

Table 262. Slave High Mix 0 - SLVHMIX0





# 8.7.23 Slave High Mix 1 - SLVHMIX1

This 32 bit register consists of the last 4-bit field for dynamic DQS DLL delay for the high nibble.

Table 263. Slave High Mix 1 - SLVHMIX1





# 8.7.24 Slave Length - SLVLEN

This 32 bit register consists of a packed 3-bit field for Static DQS Slave DLL length.

Table 264. Slave Length - SLVLEN





## 8.7.25 Master Mix - MASTMIX

This 32-bit register consists of a 4-bit field for master DQS DLL delay loop mixer control.

Table 265. Master Mix - MASTMIX





# 8.7.26 Master Length - MASTLEN

This 32 bit register consists of the nine 2-bit field for master DQS DLL length control.

Table 266. Master Length- MASTLEN





# 8.7.27 DDR Drive Strength Status Register - DDRDSSR

This 32-bit register consists of a 4-bit field for drive strength value.

Table 267. DDR Drive Strength Status Register - DDRDSSR





## 8.7.28 DDR Drive Strength Control Register - DDRDSCR

This 32-bit register consists of a 5-bit field to override the DDR pad automatic drive strength control mechanism.

Table 268. DDR Drive Strength Control Register - DDRDSCR





## 8.7.29 DDR Miscellaneous Pad Control Register - DDRMPCR

This 32-bit register contains miscellaneous control signals for the DDR pads

Table 269. DDR Miscellaneous Pad Control Register - DDRMPCR





Table 269. DDR Miscellaneous Pad Control Register - DDRMPCR





# Peripheral Bus Interface Unit

9

This chapter describes the Peripheral Bus Interface Unit (PBI) of the Intel® 80331 I/O processor (80331). It explains the following:

- Peripheral Bus signals, which consist of address/data, control/status.
- Peripheral Bus Read, and write transactions.
- Peripheral Bus configuration and Flash Memory Support.
- Support for Intel<sup>®</sup> XScale <sup>TM</sup> core (ARM\* architecture compliant) boot from the PCI Bus.
- Registers.

This chapter also serves as a starting point for the hardware designer when interfacing typical flash components to the 80331 Peripheral Bus.

Figure 85. The Peripheral Bus Interface Unit





## 9.1 Overview

The Peripheral Bus Interface Unit (PBI) is a data communication path to the flash memory components and peripherals of a 80331 hardware system. The PBI allows the processor to read and write data to these supported flash components and other peripherals. To perform these tasks at high bandwidth, the bus features a burst transfer capability which allows successive 8- or 16-bit data transfers.

The peripheral bus is controlled by the on-chip bus masters: the  $Intel^{\mathbb{B}}$  XScale  $^{TM}$  core, the ATU, AAU and DMA units.

The address/data path is multiplexed for economy, and the bus width is programmable to 8-, and 16-bit widths. The PBI performs the necessary packing and unpacking of bytes to communicate properly across the 80331 Internal Bus.

The PBI unit includes two chip enables. The PBI chip enables activate the appropriate peripheral device when the address falls within one of the PBI's two programmable address ranges. Both address ranges incorporate functionality that optimizes an interface for Flash Memory devices.

534 October, 2003 **Document Number: 273942-002** 



# 9.2 Peripheral Bus Signals

Bus signals consist of two groups: address/data, and control/status.

## 9.2.1 Address/Data Signal Definitions

The address/data signal group consists of 26 lines. 16 of these signals multiplex within the processor to serve a dual purpose. During and address cycle (T<sub>A</sub>), the processor drives A[22:16] and AD[15:0] with the address of the bus access. At all other times, the AD[15:0] lines are defined to contain data. A[2:0] are demultiplexed address pins providing incrementing byte addresses during burst cycles.

## 9.2.2 Control/Status Signal Definitions

The control/status signals control peripheral device enables and direction. All output control/status signals are three-state.

The PBI pulses **ALE** (address latch enable) active high for one clock during  $T_A$  to latch the multiplexed address on **AD[15:2]** in external address latches.

A peripheral read may be either non-burst or burst. A non-burst read ends after one data transfer to a single location.

When the data bus is configured for 16 bits, demultiplexed address bits **A[2:1]** are used to burst across up to four short-words. For an 8-bit data bus, demultiplexed address bits **A[1:0]** are used to burst across up to four bytes.

The Output Enable, **POE**#, is used for burst or non-burst read accesses to a peripheral device and is asserted during the  $T_A/T_W/T_D$  states.

The Write Enable, **PWE**#, is used for non-burst write accesses to a peripheral device and is asserted during the  $T_W/T_D$  states.

**Note:** Burst write accesses to Flash Devices are not supported.



#### 9.2.3 Bus Width

Each address range's attributes are programmed in the PBIs boundary registers. The PBI allows an 8-, or 16-bit data bus width for each range. The PBI places 8- and 16-bit data on low-order data signals, simplifying the interface to narrow bus external devices. As shown in Figure 86, 8-bit data is placed on lines **AD[7:0]**; 16-bit data is placed on lines **AD[15:0]**.

Figure 86. Data Width and Low Order Address Lines



The user needs to wire up the flash memories in a manner consistent with the programmed bus width:

- 8-bit region: **A[1:0]** provide the demultiplexed byte address for a read burst.
- 16-bit region: A[2:1] provide the demultiplexed short-word address for a read burst.

During initialization, bus width is selected for each of the two address ranges in the Peripheral Base Address Registers (PBBAR0 - PBBAR1). In addition, the PBBAR0-PBBAR5 can be used to configure these ranges as Peripheral Windows and to set a Wait state profile.

The PBI drives determinate values on all address/data signals during  $T_W/T_D$  write operation states. For an 8-bit bus, the PBI continues to drive address on unused data signals AD[15:8].



# 9.2.4 Detailed Signal Descriptions

Bus signal descriptions are detailed in Table 271.

### Table 270. Bus Signal Descriptions

| NAME      | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| A[22:16]  | <b>ADDRESS BUS 22:16</b> carries a demultiplexed version of address bits <b>A[22:16]</b> . During address $(T_a)$ , wait state $(T_w)$ and data cycles $(T_d)$ cycles, <b>A[22:16]</b> represents the upper 7 address bits for the current access. <b>A[22:16]</b> allows the PBI interface to address up to 8 MBytes per peripheral device.                                                                                                                                                                                                                      |  |  |
| AD[15:0]  | ADDRESS / DATA BUS carries 16-bit physical addresses and 8-, or 16-bit data to and from memory. During an address (T <sub>a</sub> ) cycle, bits 2-15 contain a physical word address (bits 0-1 indicate SIZE; see below). During a data (T <sub>d</sub> ) cycle, bits 0-7, or 0-15 contain read or write data, depending on the corresponding bus width.  During write operations to 8-bit wide memory regions, the PBI drives unused bus pins high or low.  SIZE, which comprises bits 0-1 of the AD lines during a T <sub>a</sub> cycle specifies the number of |  |  |
|           | data transfers during the bus transaction.  AD1 AD0  0 0 1 Transfer  0 1 2 Transfers  1 0 3 Transfers  1 1 4 Transfers                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| A[2:0]    | ADDRESS BUS 2:0 carries a demultiplexed version of bits 2:0 of the AD[15:0] bus. During a bursted read data (T <sub>d</sub> ) cycle, A[2:0] represents the current byte address in the bursted transaction.  A[2:1] are used for an 16-bit wide peripheral while A[1:0] are used for an 8-bit wide                                                                                                                                                                                                                                                                |  |  |
|           | peripheral.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| ALE       | <b>ADDRESS LATCH ENABLE</b> indicates the transfer of a physical address. ALE is asserted during a $T_a$ cycle and deasserted before the beginning of the $T_d$ state.                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| POE#      | <b>PERIPHERAL OUTPUT ENABLE</b> specifies, during a T <sub>a</sub> cycle, whether the operation is a write (1) or read (0). It is latched on-chip and remains valid during T <sub>d</sub> cycles.  This signal is used as an OUTPUT ENABLE signal (OE#) for Peripheral Devices.                                                                                                                                                                                                                                                                                   |  |  |
| PCE[1:0]# | <b>PERIPHERAL CHIP ENABLES 1:0</b> specify, during a T <sub>a</sub> cycle, which of the two Memory Address Ranges are associated with the current bus access. It remains valid during T <sub>d</sub> cycles                                                                                                                                                                                                                                                                                                                                                       |  |  |
| PWE#      | <b>PERIPHERAL WRITE ENABLE</b> indicates to a peripheral device whether or not to use the data on the AD15:0 bus to write the addressed space. It is low during $T_w$ cycles and deasserts during the $T_d$ cycle for a write; it is high during $T_a$ and $T_w/T_d$ cycles for a read.                                                                                                                                                                                                                                                                           |  |  |



## 9.2.5 Flash Memory Support

PBI peripheral bus interface supports 8-, or 16- bit Flash devices.

The PBI provides programmable wait state functionality for peripheral memory windows.

**Note:** Potentially, programmable wait state functionality could be connected to any peripheral device that has a deterministic wait state profile. However, data valid and turn-around times would need to fit within parameters provided by programmable wait state profiles to support Flash devices.

Any write transactions issued to a Flash address space window must always represent a single flash bus data cycle (**strb**, **strh**).

The peripheral chip enables, **PCE[1:0]**#, activate the appropriate Peripheral window when the address falls within one of the Peripheral address ranges.

**Note:** By default, bank 0 is enabled with the maximum number of Address-to-Data and Recovery Wait states. The width of the interface can be strapped for either 8-bit wide Flash or 16-bit wide flash. Thus, **PCE0**# is the Peripheral Bus chip enable to be used for booting purposes.

Figure 87 on page 538 illustrates how two 8-bit Flash devices would interface with the 80331 through the PBI Interface.

Figure 87. Four Mbyte Flash Memory System<sup>a</sup>



a. 16-bit wide flash devices would require two latches.



### 9.2.5.1 Flash Read Cycle

Reading a Flash device involves driving the address, output enable, and chip enable. Depending on the speed of the Flash device, the data returns several cycles later.

The definition of address-to-data wait states are the number of cycles between the assertion of **PCE[1:0]**#, and the arrival of data from the Flash device on **AD[7:0]** (8-bit Flash). The definition of recovery wait states are the number of cycles between the data arrival on **AD[7:0]** and the address for the next Peripheral transaction.

Address-to-data and recovery wait states are programmed in PBBAR0 and PBBAR1 and are identical for reads and writes. Since the read wait state requirement is typically greater, the write wait state requirement is guaranteed to be met.

Refer to Figure 88 illustrates a read cycle for a 120 ns Flash device.

Figure 88. 120 ns Flash Read Cycle



Refer to Table 271 for the programmable address-to data and recovery wait states. These numbers are based on a 66 MHz internal clock for the PBI interface.

Table 271. Flash Wait State Profile Programming<sup>a</sup>

| Flash Speed | Address-to-Data<br>Wait States | Recovery Wait<br>States |
|-------------|--------------------------------|-------------------------|
| <= 55 ns    | 4                              | 0                       |
| <= 115 ns   | 8                              | 2                       |
| <= 150 ns   | 10                             | 2                       |

a. Each Wait State Represents 15 ns.



### 9.2.5.2 Flash Write Cycle

Address-to-data and recovery wait states for reads and writes are identical and programmed in FBBAR0 and FBBAR1. Refer to Table 271 for the programmable address-to data wait states. However, Any write transactions issued to a Peripheral address space window must always represent a single peripheral bus data cycle (strb, strh) depending on the bus width selected in PBBAR0 - PBBAR1. Bursting is not supported to a Flash device since the Flash device has no write buffers to support bursting data.

Figure 89 illustrates a write cycle to a 120 ns Flash device.

Figure 89. 120 ns Flash Write Cycle





# 9.3 Intel<sup>®</sup> XScale<sup>™</sup> Core PCI Memory Boot Support

When PBI Window 0 is disabled (Section 9.4.4, "PBI Limit Register 0 - PBLR0" on page 546) and the Intel<sup>®</sup> XScale <sup>TM</sup> core PCI Bus Boot Enable in the PBCR (Section 9.4.1, "PBI Control Register - PBCR" on page 543) is set, the PBI provides the ability for the Intel<sup>®</sup> XScale <sup>TM</sup> core to boot (Section 15.3.3, "Exception Priorities and Vectors" on page 678) from PMMR register space. When the mode is enabled, three registers is available at the Internal Bus address 0000 0000H, 0000 0020H, and 0000 0024H, otherwise these registers are accessible only from their normal PMMR register addresses FFFF E6C0H, FFFF E6E0H, and FFFF E6E4H, respectively.

To boot from PCI memory, the user needs to configure the 80331 power-on-reset straps to hold the Intel<sup>®</sup> XScale<sup>TM</sup> core in reset (PCSR bit 1 is set) and to allow a host processor to configure the 80331 PCI interface (PCSR bit 2 is clear) (see Table 125, "PCI Configuration and Status Register-PCSR" on page 253 for details).

Following the host configuration of the 80331 PCI interface, the user can boot using code that resides on the PCI bus (typically host memory) through an Outbound Memory window. When the Intel<sup>®</sup> XScale<sup>TM</sup> core is released from reset (PCSR bit 1 is cleared), the PBI provides facilities for the core to execute a short jump or a long jump from the reset vector to any of the Outbound Memory windows including the direct addressing window.

#### Example 6. Memory-less Boot through by Primary ATU Outbound Memory Window 0

- 1. Disable or Remap PBI Memory Window 0 which is the default window used to boot from Flash. Write to PBLR0 to disable the PBI Memory Window 0. Remap PBI Memory Window 0 to an address above 0x3FH by writing to PBBAR0.
- 2. Set the Intel  $^{\mathbb{R}}$  XScale  $^{^{TM}}$  core PCI Bus Boot Enable bit (PBCR bit 3).
- 3. Write a short branch into PMBR0 (Intel<sup>®</sup> XScale<sup>™</sup> core Reset exception vector). Typically, PMBR0 is written with a short branch to 0000 0020H (PMBR1) (see Section 9.4.7, "PBI Memory-less Boot Registers 2:0 PMBR[2:0]" on page 549).
- 4. Write a long branch into the PMBR1/2 registers. PMBR1 holds the branch instruction while PMBR2 represents the 32-bit branch vector.
- 5. Write the 64 Mbyte aligned Host Memory Address where the Intel<sup>®</sup> XScale <sup>™</sup> core boot code resides into the OMWTVR0 register (Section 3.10.34, "Outbound Memory Window Translate Value Register 0 OMWTVR0" on page 247).
- 6. When the Host Memory Address resides above the 4 Gbyte address boundary, write the upper 32 bits of the Host Memory Address into the OUMWTVR0 register (Section 3.10.35, "Outbound Upper 32-bit Memory Window Translate Value Register 0 OUMWTVR0" on page 248).
- 7. Release the Intel<sup>®</sup> XScale<sup>™</sup> core to boot from host memory by clearing the core processor reset bit in the PCSR (PCSR bit 1).

Note: The Long Branch at 0000 0020H (PMBR1/2) should branch to the 64 Mbytes of address space that is claimed by the ATUs Primary Outbound Memory Window 0 (8000 0000H to 83FF FFFFH). With the MMU enabled following boot-up, the exception vector's physical addresses can be moved from the address range 0000 0000H to 0000 001CH to an address range contained in the 64 Mbytes of Primary Outbound Memory Window 0. Typically, the exception vectors is locked into the cache following boot-up.



# 9.4 Register Definitions

A series of configuration registers control the PBI. Software can determine the status of the PBI by reading the status register. Table 272 lists all of the PBI registers which are detailed further in proceeding sections.

#### Table 272. Peripheral Bus Interface Register

| · · · · · · · · · · · · · · · · · · ·                                       |  |
|-----------------------------------------------------------------------------|--|
| Section, Register Name - Acronym (Page)                                     |  |
| Section 9.4.1, "PBI Control Register - PBCR" on page 543                    |  |
| Section 9.4.3, "PBI Base Address Register 0 - PBBAR0" on page 545           |  |
| Section 9.4.4, "PBI Limit Register 0 - PBLR0" on page 546                   |  |
| Section 9.4.5, "PBI Base Address Register 1 - PBBAR1" on page 547           |  |
| Section 9.4.6, "PBI Limit Register 1 - PBLR1" on page 548                   |  |
| Section 9.4.7, "PBI Memory-less Boot Registers 2:0 - PMBR[2:0]" on page 549 |  |
| Section 9.4.8, "PBI Drive Strength Control Register - PBDSCR" on page 550   |  |



# 9.4.1 PBI Control Register - PBCR

The PBI Control Register (PBCR) is responsible for enabling the operation of the PBI state machines.

Table 273. PBI Control Register - PBCR





# 9.4.2 Determining Block Sizes for Memory Windows

The memory window size can be determined by writing ones to the appropriate upper bits of the limit register. The binary-weighted value of the first non-zero bit set in the limit register indicates the size of the memory window. Table 274 describes the relationship between limit register values and the byte sizes of the memory window.

#### Table 274. Memory Block Size Limit Register Value

| Limit Register Value <sup>a</sup> | Size<br>(in Bytes) | Limit Register Value | Size<br>(in Bytes) |
|-----------------------------------|--------------------|----------------------|--------------------|
| FFFFFF0H                          | 16                 | FFF00000H            | 1 M                |
| FFFFFE0H                          | 32                 | FFE00000H            | 2 M                |
| FFFFFC0H                          | 64                 | FFC00000H            | 4 M                |
| FFFFF80H                          | 128                | FF800000H            | 8 M                |
| FFFFF00H                          | 256                | FF000000H            |                    |
| FFFFE00H                          | 512                | FE000000H            |                    |
| FFFFC00H                          | 1K                 | FC000000H            |                    |
| FFFF800H                          | 2K                 | F8000000H            |                    |
| FFFF000H                          | 4K                 | F000000H             |                    |
| FFFE000H                          | 8K                 | E000000H             | Address<br>Window  |
| FFFFC000H                         | 16K                | С0000000Н            | Closed.            |
| FFFF8000H                         | 32K                | H00000008            | 1                  |
| FFFF0000H                         | 64K                |                      |                    |
| FFFE0000H                         | 128K               | ——— 00000000H        |                    |
| FFFC0000H                         | 256K               |                      |                    |
| FFF80000H                         | 512K               |                      |                    |

a. Shaded Limit Register Values and Memory Block Sizes are not supported by the PBI.

As an example, assume that FFF0 0004H is written to the PBI Limit Register 0 (FBLR0). Scanning upwards starting at bit 12, bit 20 is the first one bit found. The binary-weighted value of this bit is 1,048,576, indicating a 1 Mbyte of memory window.

When programming the Base and Limit Registers for a memory window, the Base Address always needs to be aligned the size of the memory window set in a limit register. For a 1 Mbyte memory window, only bit 20 through bit 31 of the base address from the PBI Base Address Register 0 (FBBAR0) is relevant to the PBI when decoding Memory Window 0.

#### Warning:

A given PBI Base (PBBAR0-PBBAR1) and Limit (PBLR0-PBLR1) register pair should not be modified during the time there is activity on the peripheral bus associated with that particular peripheral memory window. For instance, following boot-up, code executing from Peripheral Memory Window 0 may be used to modify the PBI Base and Limit registers for Peripheral Memory Window 1, but **not** for Peripheral Memory Window 0.



## 9.4.3 PBI Base Address Register 0 - PBBAR0

The PBI Base Address Register 0 (PBBAR0) defines the block of memory addresses where PBI Memory Window 0 begins. The PBBAR0 defines the base address and describes the required memory block size; see Section 9.4.2, "Determining Block Sizes for Memory Windows" on page 544. The selected base address needs to be naturally aligned to the granularity of the memory block size. For instance, when a 64 Kbyte memory window size is selected, the base address needs to be 64 Kbyte address aligned (i.e., bits 15:12 of the base address are required to be 000b).

Bits 1:0 define the PBI bus width for PBI Memory Window 0.

Table 275. PBI Base Address Register 0 - PBBAR0





# 9.4.4 PBI Limit Register 0 - PBLR0

The 80331 limit register's (PBLR0) programmed value must be naturally aligned with the base address register's (PBBAR0) programmed value. The limit register is used as a mask when the address decode for memory window 0 is performed.

Table 276. PBI Limit Register 0 - PBLR0





#### 9.4.5 PBI Base Address Register 1 - PBBAR1

The PBI Base Address Register 1 (PBBAR1) defines the block of memory addresses where PBI Memory Window 1 begins. The PBBAR1 defines the base address and describes the required memory block size; see Section 9.4.2, "Determining Block Sizes for Memory Windows" on page 544. The selected base address needs to be naturally aligned to the granularity of the memory block size. For instance, when a 64 Kbyte memory window size is selected, the base address needs to be 64 Kbyte address aligned (i.e., bits 15:12 of the base address are required to be 000b).

Bits 1:0 define the PBI bus width for PBI Memory Window 1.

Table 277. PBI Base Address Register 1- PBBAR1





# 9.4.6 PBI Limit Register 1 - PBLR1

The 80331 limit register's (PBLR1) programmed value must be naturally aligned with the base address register's (PBBAR1) programmed value. The limit register is used as a mask when the address decode for memory window 1 is performed.

Table 278. PBI Limit Register 1 - PBLR1





# 9.4.7 PBI Memory-less Boot Registers 2:0 - PMBR[2:0]

The three PBI Memory-less Boot Registers are used to hold the  $Intel^{\mathbb{R}}$  XScale<sup>TM</sup> core Reset exception vector and a long branch during a PCI Memory Boot sequence.

These three registers is made accessible at the addresses 0000 0000H, 0000 0020H, and 0000 0024H, when the 80331 performs a PCI Memory Boot sequence (see Section 9.3, "Intel® XScale<sup>TM</sup> Core PCI Memory Boot Support" on page 541 for more details).

Table 279 shows the PBI Memory-less Boot Registers 2:0.

Table 279. PBI Memory-less Boot Registers 2:0 - PMBR[2:0]





# 9.4.8 PBI Drive Strength Control Register - PBDSCR

The PBI drive strength control register is used to manually control the slew rate and drive strength of the peripheral bus interface, the **TDO** pin, and the **GPIO[7:0]** pins.

**Note:** By default, the user is **not** required to program this register. This register should not be programmed to a different value without consulting the *Intel*<sup>®</sup> 80331 I/O Processor Datasheet where the appropriate values are specified.

Table 280. PBI Drive Strength Control Register - PBDSCR





# intel® PC Bus Interface Units

This chapter describes the two I<sup>2</sup>C (Inter-Integrated Circuit) bus interface units, including the operation modes and setup. Throughout this manual, these peripherals are referred to as the I<sup>2</sup>C units.

#### 10.1 **Overview**

Both I<sup>2</sup>C Bus Interface Units allow the Intel<sup>®</sup> 80331 I/O processor (80331) to serve as a master and slave device residing on the I<sup>2</sup>C bus. The I<sup>2</sup>C bus is a serial bus developed by Philips Corporation consisting of a two-pin interface. SDA is the data pin for input and output functions and **SCL** is the clock pin for reference and control of the  $I^2C$  bus.

The I<sup>2</sup>C bus allows the 80331 to interface to other I<sup>2</sup>C peripherals and microcontrollers for system management functions. The serial bus requires a minimum of hardware for an economical system to relay status and reliability information on the 80331 subsystem to an external device.

The I<sup>2</sup>C Bus Interface Unit is a peripheral device that resides on a 80331 internal bus. Data is transmitted to and received from the I<sup>2</sup>C bus via a buffered interface. Control and status information is relayed through a set of memory-mapped registers. Refer to the I<sup>2</sup>C - Bus Specification, version 2.1 for complete details on  $I^2C$  bus operation.

#### 10.2 I<sub>2</sub>C Interface

#### **Table 281.** I<sub>2</sub>C Interface Pins

| Signal | Description                                                                                    |
|--------|------------------------------------------------------------------------------------------------|
| SCL0   | I <sup>2</sup> C Clock: Provides synchronous operation of I <sup>2</sup> C bus zero.           |
| SDA0   | I <sup>2</sup> C Data: Is used for data transfer and arbitration of I <sup>2</sup> C bus zero. |
| SCL1   | I <sup>2</sup> C Clock: Provides synchronous operation of I <sup>2</sup> C bus one.            |
| SDA1   | I <sup>2</sup> C Data: Is used for data transfer and arbitration of I <sup>2</sup> C bus one.  |
| Total  | 4                                                                                              |



# 10.3 Theory of Operation

The  $I^2C$  bus defines a serial protocol for passing information between agents on the  $I^2C$  bus using only a two pin interface. The interface consists of a Serial Data/Address (**SDA**) line and a Serial Clock Line (**SCL**). Each device on the  $I^2C$  bus is recognized by a unique 7-bit address and can operate as a transmitter or as a receiver. In addition to transmitter and receiver, the  $I^2C$  bus uses the concept of master and slave. Table 282 lists the  $I^2C$  device types.

#### Table 282. I<sup>2</sup>C Bus Definitions

| I <sup>2</sup> C Device | Definition                                                                                                                                                                |  |  |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Transmitter             | Sends data to the I <sup>2</sup> C bus.                                                                                                                                   |  |  |
| Receiver                | Receives data from the I <sup>2</sup> C bus.                                                                                                                              |  |  |
| Master                  | Initiates a transfer, generates the clock signal, and terminates the transactions.                                                                                        |  |  |
| Slave                   | The device addressed by a master.                                                                                                                                         |  |  |
| Multi-master            | More than one master can attempt to control the bus at the same time without corrupting the message.                                                                      |  |  |
| Arbitration             | Procedure to ensure that, when more than one master simultaneously tries to control the bus, only one is allowed. This procedure ensures that messages are not corrupted. |  |  |

As an example of I<sup>2</sup>C bus operation, consider the case of the 80331 acting as a master on the bus (see Figure 90). The 80331, as a master, addresses an EEPROM as a slave to receive data. The 80331 is a master-transmitter and the EEPROM is a slave-receiver. When the 80331 reads data, the 80331 is a master-receiver and the EEPROM is a slave-transmitter. In both cases, the master generates the clock, initiates the transaction and terminates it.

Figure 90. I<sup>2</sup>C Bus Configuration Example



The I<sup>2</sup>C bus allows for a multi-master system, which means more than one device can initiate data transfers at the same time. To support this feature, the I<sup>2</sup>C bus arbitration relies on the wired-AND connection of all I<sup>2</sup>C interfaces to the I<sup>2</sup>C bus. Two masters can drive the bus simultaneously provided they are driving identical data. The first master to drive **SDA** high while another master drives **SDA** low loses the arbitration. The **SCL** line consists of a synchronized combination of clocks generated by the masters using the wired-AND connection to the **SCL** line.

The I<sup>2</sup>C bus serial operation uses an open-drain wired-AND bus structure, which allows multiple devices to drive the bus lines and to communicate status about events such as arbitration, wait states, error conditions and so on. For example, when a master drives the clock (**SCL**) line during a data transfer, it transfers a bit on every instance that the clock is high. When the slave is unable to accept or drive data at the rate that the master is requesting, the slave can hold the clock line low between the high states to insert a wait interval. The master's clock can only be altered by a slow slave peripheral keeping the clock line low or by another master during arbitration.

I<sup>2</sup>C transactions are either initiated by the 80331 as a master or are received by the processor as a slave. Both conditions may result in the processor doing reads, writes, or both to the I<sup>2</sup>C bus.



# 10.3.1 Operational Blocks

The  $I^2C$  Bus Interface Unit is a slave peripheral device that is connected to the internal bus. The 80331 interrupt mechanism can be used for notifying the 80331 that there is activity on the  $I^2C$  bus. Polling can be also be used instead of interrupts, although it would be very cumbersome. Figure 91 shows a block diagram of the  $I^2C$  Bus Interface Unit and its interface to the internal bus.

The I<sup>2</sup>C Bus Interface Unit consists of the two wire interface to the I<sup>2</sup>C bus, an 8-bit buffer for passing data to and from the 80331, a set of control and status registers, and a shift register for parallel/serial conversions.

Figure 91. I<sup>2</sup>C Bus Interface Unit Block Diagram



# Intel® 80331 I/O Processor Developer's Manual P<sup>2</sup>C Bus Interface Units



The I<sup>2</sup>C interrupts are signalled through a single pin which provides a level sensitive interrupt to the 80331 interrupt control unit. The I<sup>2</sup>C Bus Interface Unit can cause and interrupt when a buffer is full, buffer empty, slave address detected, arbitration lost, or bus error condition occurs. All interrupt conditions must be cleared explicitly by software. See Section 10.9.2, "I<sup>2</sup>C Status Register x - ISRx" on page 578 for details.

The I<sup>2</sup>C Data Buffer Register (IDBR) is an 8-bit data buffer that receives a byte of data from the shift register interface of the I<sup>2</sup>C bus on one side and parallel data from the 80331 internal bus on the other side. The serial shift register is not user accessible.

The control and status registers are located in the I<sup>2</sup>C memory-mapped address space (FFFF F680H to FFFF F694H). The registers and their function are defined in Section 10.9.

The  $I^2C$  Bus Interface Unit supports fast mode operation of 400 Kbits/sec. Fast mode logic levels, formats, and capacitive loading, and protocols are exactly the same as the 100 Kbits/sec standard mode. Because the data setup and hold times differ between the fast and standard mode, the  $I^2C$  is designed to meet the slower, standard mode requirements for these two specifications. Refer to the  $I^2C$  Bus Specification for details.



# 10.3.2 I<sup>2</sup>C Bus Interface Modes

The I<sup>2</sup>C Bus Interface Unit can be in different modes of operation to accomplish a transfer. Table 283 summarizes the different modes.

#### Table 283. Modes of Operation

| Mode                      | Definition                                                                                                                                                                                                                                                                                        |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master - Transmit         | <ul> <li>I<sup>2</sup>C Bus Interface Unit acts as a master.</li> <li>Used for a write operation.</li> <li>I<sup>2</sup>C Bus Interface Unit sends the data.</li> <li>I<sup>2</sup>C Bus Interface Unit is responsible for clocking.</li> <li>Slave device is in slave-receive mode</li> </ul>    |
| Master - Receive          | <ul> <li>I<sup>2</sup>C Bus Interface Unit acts as a master.</li> <li>Used for a read operation.</li> <li>I<sup>2</sup>C Bus Interface Unit receives the data.</li> <li>I<sup>2</sup>C Bus Interface Unit is responsible for clocking.</li> <li>Slave device is in slave-transmit mode</li> </ul> |
| Slave - Transmit          | <ul> <li>I<sup>2</sup>C Bus Interface Unit acts as a slave.</li> <li>Used for a read (master) operation.</li> <li>I<sup>2</sup>C Bus Interface Unit sends the data.</li> <li>Master device is in master-receive mode.</li> </ul>                                                                  |
| Slave - Receive (default) | <ul> <li>I<sup>2</sup>C Bus Interface Unit acts as a slave.</li> <li>Used for a write (master) operation.</li> <li>I<sup>2</sup>C Bus Interface Unit receives the data.</li> <li>Master device is in master-transmit mode.</li> </ul>                                                             |

While the I<sup>2</sup>C Bus Interface Unit is in idle mode (neither receiving or transmitting serial data), the unit defaults to Slave-Receive mode. This allows the interface to monitor the bus and receive any slave addresses that might be intended for the 80331.

When the I<sup>2</sup>C Bus Interface Unit receives an address that matches the 7-bit address found in the I<sup>2</sup>C Slave Address Register (ISAR) or the General Call Address (00H), the interface either remains in Slave-Receive mode or transitions to Slave-Transmit mode. This is determined by the Read/Write (R/W#) bit (the least significant bit of the byte containing the slave address). When the R/W# bit is low, the master initiating the transaction intends to do a write and the I<sup>2</sup>C Bus Interface Unit remains in Slave-Receive mode. When the R/W# is high, the initiating master wants to read data and the slave transitions to Slave-Transmit mode. Slave operation is further defined in Section 10.4.6, "Slave Operations" on page 568.

When the 80331 wants to initiate a read or write on the I<sup>2</sup>C bus, the I<sup>2</sup>C Bus Interface Unit transitions from the default Slave-Receive mode to Master-Transmit mode. When the 80331 wants to write data, the interface remains in Master-Transmit mode after the address transfer has completed. (see Section 10.3.3.1, "START Condition" on page 557) for START information). When the 80331 wants to read data, the I<sup>2</sup>C Bus Interface Unit transmits the start address, then transition to Master-Receive mode. Master operation is further defined in Section 10.4.5, "Master Operations" on page 564.



# 10.3.3 Start and Stop Bus States

The I<sup>2</sup>C bus defines a transaction START and a transaction STOP bus state that are used at the beginning and end of the transfer of one to an unlimited number of bytes on the bus.

The 80331 uses the START and STOP bits in the I<sup>2</sup>C Control Register (ICR) to:

- initiate an additional byte transfer
- initiate a START condition on the I<sup>2</sup>C bus
- enable Data Chaining (repeated START)
- initiate a STOP condition on the I<sup>2</sup>C bus

Table 284 summarizes the definition of the START and STOP bits in the ICR.

#### Table 284. START and STOP Bit Definitions

| STOP<br>bit                                                                                                                                                                                                                       | STAR<br>T bit | Condition                 | Notes                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                                                                                                                                                                                                 | 0             | No START or<br>STOP       | <ul> <li>No START or STOP condition is sent by the I<sup>2</sup>C Bus Interface Unit.<br/>This is used when multiple data bytes need to be transferred.</li> </ul>                                                                                                                                                             |
| contents of the 8 bit IDBR after the START START Condition and  contents of the 8 bit IDBR after the START the 7-bit address and the R/W# bit before a repeated start, the IDBR contents  For a repeated start, the IDBR contents | 1             | Condition and<br>Repeated | <ul> <li>The I<sup>2</sup>C Bus Interface Unit sends a START condition and transmit the<br/>contents of the 8 bit IDBR after the START. The IDBR must contain<br/>the 7-bit address and the R/W# bit before a START is initiated.</li> </ul>                                                                                   |
|                                                                                                                                                                                                                                   |               |                           | <ul> <li>For a repeated start, the IDBR contents contains the target slave<br/>address and the R/W# bit. This enables multiple transfers to different<br/>slaves without giving up the bus.</li> </ul>                                                                                                                         |
|                                                                                                                                                                                                                                   |               |                           | <ul> <li>The interface stays in Master-Transmit mode when a write is used or<br/>transition to master-receive mode when a read is requested.</li> </ul>                                                                                                                                                                        |
|                                                                                                                                                                                                                                   |               |                           | <ul> <li>In Master-Transmit mode, the I<sup>2</sup>C Bus Interface Unit transmits the<br/>8-bit IDBR and then send a STOP on the I<sup>2</sup>C bus.</li> </ul>                                                                                                                                                                |
| 1                                                                                                                                                                                                                                 | Х             | STOP Condition            | <ul> <li>In Master-Receive mode, the Ack/Nack Control bit in the ICR must<br/>be changed to a negative Ack (see Section 10.4.3). The I<sup>2</sup>C Bus<br/>Interface Unit writes the Nack bit (Ack/Nack Control bit must be 1),<br/>receive the data byte in the IDBR, then send a STOP on the I<sup>2</sup>C bus.</li> </ul> |

Figure 92 shows the relationship between the **SDA** and **SCL** lines for a START and STOP condition.

#### Figure 92. Start and Stop Conditions



556 October, 2003 **Document Number: 273942-002** 



#### 10.3.3.1 START Condition

The START condition (bits 1:0 of the ICR set to 01<sub>2</sub>) initiates a master transaction or repeated START. Software must load the target slave address and the R/W# bit in the IDBR (see Section 10.9.4, "I<sup>2</sup>C Data Buffer Register x - IDBRx" on page 581) before setting the START ICR bit. The START and the IDBR contents are transmitted on the I<sup>2</sup>C bus when the ICR Transfer Byte bit is set. The I<sup>2</sup>C bus stays in master-transmit mode when a write is requested or enters master-receive mode when a read is requested. For a repeated start (a change in read or write or a change in the target slave address), the IDBR contains the updated target slave address and the R/W# bit. A repeated start enables multiple transfers to different slaves without giving up the bus.

The START condition is not cleared by the  $I^2C$  unit. When arbitration is lost while initiating a START, the  $I^2C$  unit may re-attempt the START when the bus becomes free. See Section 10.4.4, "Arbitration" on page 562 for details on how the  $I^2C$  unit functions under those circumstances.

#### 10.3.3.2 No START or STOP Condition

No START or STOP condition (bits 1:0 of the ICR set to  $00_2$ ) is used in master-transmit mode while the 80331 is transmitting multiple data bytes (see Figure 92). Software writes the data byte, sets the IDBR Transmit Empty bit in the ISR (and interrupt when enabled), and clears the Transfer Byte bit in the ICR. The software then writes a new byte to the IDBR and sets the Transfer Byte ICR bit, which initiates the new byte transmission. This continues until the software sets the START or STOP bit. The START and STOP bits in the ICR are not automatically cleared by the  $I^2$ C unit after the transmission of a START, STOP or repeated START.

After each byte transfer (including the Ack/Nack bit) the I<sup>2</sup>C unit holds the **SCL** line low (inserting wait states) until the Transfer Byte bit in the ICR is set. This action notifies the I<sup>2</sup>C unit to release the **SCL** line and allow the next information transfer to proceed.

#### 10.3.3.3 STOP Condition

The STOP condition (bits 1:0 of the ICR set to 10<sub>2</sub>) terminates a data transfer. In master-transmit mode, the STOP bit and the Transfer Byte bit in the ICR must be set to initiate the last byte transfer (see Figure 92). In master-receive mode, to initiate the last transfer the 80331 must set the Ack/Nack bit, the STOP bit, and the Transfer Byte bit in the ICR. Software must clear the STOP condition after it is transmitted.

#### Figure 93. START and STOP Conditions





# 10.4 I<sup>2</sup>C Bus Operation

The I<sup>2</sup>C Bus Interface Unit transfers in 1 byte increments. A data transfer on the I<sup>2</sup>C bus always follows the sequence:

- 1) START
- 2) 7-bit Slave Address
- 3) R/W# Bit
- 4) Acknowledge Pulse
- 5) 8 Bits of Data
- 6) Ack/Nack Pulse
- 7) Repeat of Step 5 and 6 for Required Number of Bytes
- 8) Repeated START (Repeat Step 1) or STOP

# 10.4.1 Serial Clock Line (SCL) Generation

The 80331 I<sup>2</sup>C unit is required to generate the I<sup>2</sup>C clock output when in master mode (either receive or transmit). **SCL** clock generation is accomplished through the use of the Fast Mode Enable bit, which is programmed at initialization. The following equation is used to determine the **SCL** transition period:

#### **Equation 12. SCL Transition Period**

SCL Transition Period = (30 ns) \* (167 - (Fast Mode Enable \* 125))

558 October, 2003 **Document Number: 273942-002** 



## 10.4.2 Data and Addressing Management

Data and slave addressing is managed via the I<sup>2</sup>C Data Buffer Register (IDBR) and the I<sup>2</sup>C Slave Address Register (ISAR). The IDBR (see Section 10.9.4, "I<sup>2</sup>C Data Buffer Register x - IDBRx" on page 581) contains data or a slave address and R/W# bit. The ISAR contains the 80331 programmable slave address. Data coming into the I<sup>2</sup>C unit is received into the IDBR after a full byte is received and acknowledged. To transmit data, the processor writes to the IDBR, and the I<sup>2</sup>C unit passes this onto the serial bus when the Transfer Byte bit in the ICR is set. See Section 10.9.1, "I<sup>2</sup>C Control Register x - ICRx" on page 576.

When the I<sup>2</sup>C unit is in transmit mode (master or slave):

- 1. Software writes data to the IDBR over the internal bus. This initiates a master transaction or sends the next data byte, after the IDBR Transmit Empty bit is sent.
- 2. The I<sup>2</sup>C unit transmits the data from the IDBR when the Transmit Empty bit in the ICR is set.
- 3. When enabled, an IDBR Transmit Empty interrupt is signalled when a byte is transferred on the I<sup>2</sup>C bus and the acknowledge cycle is complete.
- 4. When the I<sup>2</sup>C bus is ready to transfer the next byte before the processor has written the IDBR (and a STOP condition is not in place), the I<sup>2</sup>C unit inserts wait states until the processor writes a new value into the IDBR and sets the ICR Transfer Byte bit.

When the  $I^2C$  unit is in receive mode (master or slave):

- 1. The processor reads the IDBR data over the internal bus after the IDBR Receive Full interrupt is signalled.
- 2. The I<sup>2</sup>C unit transfers data from the shift register to the IDBR after the Ack cycle completes.
- 3. The I<sup>2</sup>C unit inserts wait states until the IDBR is read. Refer to Section 10.4.3, "I<sup>2</sup>C Acknowledge" on page 561 for acknowledge pulse information in receiver mode.
- 4. After the Intel<sup>®</sup> XScale<sup>™</sup> core (ARM\* architecture compliant) reads the IDBR, the I<sup>2</sup>C unit writes the ICR's Ack/Nack Control bit and the Transfer Byte bit, allowing the next byte transfer to proceed.



#### 10.4.2.1 Addressing a Slave Device

As a master device, the  $I^2C$  unit must compose and send the first byte of a transaction. This byte consists of the slave address for the intended device and a R/W# bit for transaction definition. The slave address and the R/W# bit are written to the IDBR (see Figure 94).

#### Figure 94. Data Format of First Byte in Master Transaction



The first byte transmission must be followed by an Ack pulse from the addressed slave. When the transaction is a write, the I<sup>2</sup>C unit remains in master-transmit mode and the addressed slave device stays in slave-receive mode. When the transaction is a read, the I<sup>2</sup>C unit transitions to master-receive mode immediately following the Ack and the addressed slave device transitions to slave-transmit mode. When a Nack is returned, the I<sup>2</sup>C unit aborts the transaction by automatically sending a STOP and setting the ISR bus error bit.

When the  $I^2C$  unit is enabled and idle (no bus activity), it stays in slave-receive mode and monitors the  $I^2C$  bus for a START signal. Upon detecting a START pulse, the  $I^2C$  unit reads the first seven bits and compares them to those in the  $I^2C$  Slave Address Register (ISAR) and the general call address (00H). When the bits match those of the ISAR register, the  $I^2C$  unit reads the eighth bit (R/W# bit) and transmits an Ack pulse. The  $I^2C$  unit either remains in slave-receive mode (R/W# = 0) or transitions to slave-transmit mode (R/W# = 1). See Section 10.4.7, "General Call Address" on page 570 for actions when a general call address is detected.



# 10.4.3 I<sup>2</sup>C Acknowledge

Every I<sup>2</sup>C byte transfer must be accompanied by an acknowledge pulse, which is always generated by the receiver (master or slave). The transmitter must release the **SDA** line for the receiver to transmit the acknowledge pulse (see Figure 95).

In master-transmit mode, when the target slave receiver device cannot generate the acknowledge pulse, the **SDA** line remains high. This lack of acknowledge (Nack) causes the I<sup>2</sup>C unit to set the bus error detected bit in the ISR and generate the associated interrupt (when enabled). The I<sup>2</sup>C unit aborts the transaction by generating a STOP automatically.

In master-receive mode, the I<sup>2</sup>C unit signals the slave-transmitter to stop sending data by using the negative acknowledge (Nack). The Ack/Nack bit value driven by the I<sup>2</sup>C bus is controlled by the Ack/Nack bit in the ICR. The bus error detected bit in the ISR is not set for a master-receive mode Nack (as required by the I<sup>2</sup>C bus protocol). The I<sup>2</sup>C unit automatically transmits the Ack pulse, based on the Ack/Nack ICR bit, after receiving each byte from the serial bus. Before receiving the last byte, software must set the Ack/Nack Control bit to Nack. Nack is then sent after the next byte is received to indicate the last byte.

In slave mode, the I<sup>2</sup>C unit automatically acknowledges its own slave address, independent of the Ack/Nack bit setting in the ICR. As a slave-receiver, an Ack response is automatically given to a data byte, independent of the Ack/Nack bit setting in the ICR. The I<sup>2</sup>C unit sends the Ack value after receiving the eighth data bit of the byte.

In slave-transmit mode, receiving a Nack from the master indicates the last byte is transferred. The master then sends either a STOP or repeated START. The ISR's unit busy bit (2) remains set until a STOP or repeated START is received.

Figure 95. Acknowledge on the I<sup>2</sup>C Bus





#### 10.4.4 Arbitration

Arbitration on the I<sup>2</sup>C bus is required due to the multi-master capabilities of the I<sup>2</sup>C bus. Arbitration is used when two or more masters simultaneously generate a START condition within the minimum I<sup>2</sup>C hold time of the START condition.

Arbitration can continue for a long period. When the address bit and the R/W# are the same, the arbitration moves to the data. Due to the wired-AND nature of the  $I^2C$  bus, no data is lost when both (or all) masters are outputting the same bus states. When the address, the R/W# bit, or the data are different, the master which outputted the high state (master's data is different from **SDA**) loses arbitration and shut its data drivers off. When losing arbitration, the  $I^2C$  Bus Interface Unit shuts off the **SDA** or **SCL** drivers for the remainder of the byte transfer, set the Arbitration Loss Detected bit, then return to idle (Slave-Receive) mode.

#### 10.4.4.1 SCL Arbitration

Each master on the I<sup>2</sup>C bus generates its own clock on the **SCL** line for data transfers. With masters generating their own clocks, clocks with different frequencies may be connected to the **SCL** line. Since data is valid when the clock is in the high period, a defined clock synchronization procedure is needed during bit-by-bit arbitration.

Clock synchronization is accomplished by using the wired-AND connection of the I<sup>2</sup>C interfaces to the **SCL** line. When a master's clock transitions from high to low, this causes the master to hold down the **SCL** line for its associated period (see Figure 96). The low to high transition of the clock may not change when another master has not completed its period. Therefore, the master with the longest low period holds down the **SCL** line. Masters with shorter periods are held in a high wait-state during this time. Once the master with the longest period completes, the **SCL** line transitions to the high state, masters with the shorter periods can continue the data cycle.

Figure 96. Clock Synchronization During the Arbitration Procedure





#### 10.4.4.2 SDA Arbitration

Arbitration on the **SDA** line can continue for a long period, starting with address and R/W# bits and continuing with data bits. Figure 97 shows the arbitration procedure for two masters (more than two may be involved depending on how many masters are connected to the bus). When the address and R/W# are the same, arbitration moves to the data. Due to the wired-AND nature of the I<sup>2</sup>C bus, no data is lost when both (or all) masters are outputting the same bus states. When address, R/W#, or data is different, the master that output the first low data bit loses arbitration and shuts its data drivers off. When the I<sup>2</sup>C unit loses arbitration, it shuts off the **SDA** or **SCL** drivers for remainder of byte transfer, sets arbitration loss detected ISR bit, then returns to idle (Slave-Receive) mode.

Figure 97. Arbitration Procedure of Two Masters



When the I<sup>2</sup>C unit loses arbitration during transmission of the seven address bits and the 80331 is not being addressed as a slave device, the I<sup>2</sup>C unit re-sends the address when the I<sup>2</sup>C bus becomes free. This is possible because the IDBR and ICR registers are not overwritten when arbitration is lost.

When the arbitration loss is to due to another bus master addressing the 80331 as a slave device, the  $I^2C$  unit switches to slave-receive mode and the original data in the  $I^2C$  data buffer register is overwritten. Software is responsible for clearing the start and re-initiating the master transaction at a later time.

**Note:** Software must not allow the I<sup>2</sup>C unit to write to its own slave address. This can cause the I<sup>2</sup>C bus to enter an indeterminate state.

Boundary conditions exist for arbitration when an arbitration process is in progress and a repeated START or STOP condition is transmitted on the I<sup>2</sup>C bus. To prevent errors, the I<sup>2</sup>C unit, acting as a master, provides for the following sequences:

- No arbitration takes place between a repeated START condition and a data bit
- No arbitration takes place between a data bit and a STOP condition
- No arbitration takes place between a repeated START condition and a STOP condition

These situations arise only when different masters write the same data to the same target slave simultaneously and arbitration is not resolved after the first data byte transfer.

**Note:** Typically, software is responsible for ensuring arbitration is lost soon after the transaction begins. For example, the protocol might insist that all masters transmit their I<sup>2</sup>C address as the first data byte of any transaction ensuring arbitration is ended. A restart is then sent to begin a valid data transfer (the slave can then discard the master's address).



# 10.4.5 Master Operations

When software initiates a read or write on the  $I^2C$  bus, the  $I^2C$  unit transitions from the default slave-receive mode to master-transmit mode. The start pulse is sent followed by the 7-bit slave address and the R/W# bit. After the master receives an acknowledge, the  $I^2C$  unit has the option of two master modes:

- Master-Transmit The 80331 writes data
- Master-Receive The 80331 reads data

The 80331 initiates a master transaction by writing to the ICR register. Data is read and written from the  $I^2C$  unit through the memory-mapped registers.

Table 285 describes the I<sup>2</sup>C Bus Interface Unit responsibilities as a master device.

#### Table 285. Master Transactions (Sheet 1 of 3)

| I <sup>2</sup> C Master<br>Action        | Mode of<br>Operation              | Definition                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generate clock output                    | Master-transmit<br>Master-receive | <ul> <li>The master always drives the SCL line.</li> <li>The SCL Enable bit must be set.</li> <li>The Unit Enable bit must be set.</li> </ul>                                                                                                                                                                                                                     |
| Write target<br>slave address to<br>IDBR | Master-transmit<br>Master-receive | <ul> <li>The Intel<sup>®</sup> XScale<sup>™</sup> core writes to IDBR bits 7-1 before a START condition is enabled.</li> <li>First 7 bits sent on bus after START.</li> <li>See Section 10.3.3.</li> </ul>                                                                                                                                                        |
| Write R/W# Bit to IDBR                   | Master-transmit<br>Master-receive | <ul> <li>The Intel® XScale™ core writes to the least significant IDBR bit with the target slave address.</li> <li>When low, the master remains a master-transmitter. When high, the master transitions to a master-receiver.</li> <li>See Section 10.4.2.</li> </ul>                                                                                              |
| Signal START<br>Condition                | Master-transmit<br>Master-receive | <ul> <li>See "Generate clock output" above.</li> <li>Performed after the target slave address and the R/W# bit are in the IDBR.</li> <li>Intel<sup>®</sup> XScale<sup>™</sup> core sets the START bit.</li> <li>Intel<sup>®</sup> XScale<sup>™</sup> core sets the Transfer Byte bit which initiates the start condition.</li> <li>See Section 10.3.3.</li> </ul> |
| Initiate first data<br>byte transfer     | Master-transmit<br>Master-receive | <ul> <li>Intel<sup>®</sup> XScale<sup>™</sup> core writes byte to IDBR</li> <li>I<sup>2</sup>C Bus Interface Unit transmits the byte when the Transfer Byte bit is set.</li> <li>I<sup>2</sup>C Bus Interface Unit clears the Transfer Byte bit and sets the IDBR Transmit Empty bit when the transfer is complete.</li> </ul>                                    |

564 October, 2003 **Document Number: 273942-002** 



# Table 285. Master Transactions (Sheet 2 of 3)

| I <sup>2</sup> C Master<br>Action           | Mode of<br>Operation              | Definition                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |                                   | When two or more masters signal a start within the same clock period, arbitration must occur.                                                                                                                                                                                                                                                                                                                                    |
|                                             |                                   | <ul> <li>The I<sup>2</sup>C Bus Interface Unit arbitrates for as long as necessary.<br/>Arbitration takes place during slave address, R/W# bit, and data<br/>transmission and continues until all but one master loses the bus. No<br/>data is lost during arbitration.</li> </ul>                                                                                                                                               |
| Arbitrate for I <sup>2</sup> C<br>Bus       | Master-transmit<br>Master-receive | <ul> <li>When the I<sup>2</sup>C Bus Interface Unit loses arbitration, it sets the<br/>Arbitration Loss Detect ISR bit after byte transfer is complete and<br/>transition to slave-receive (default) mode.</li> </ul>                                                                                                                                                                                                            |
|                                             |                                   | <ul> <li>When I<sup>2</sup>C Bus Interface Unit loses arbitration while attempting to<br/>send the target address byte, the I<sup>2</sup>C Bus Interface Unit attempts to<br/>resend it when the bus becomes free.</li> </ul>                                                                                                                                                                                                    |
|                                             |                                   | <ul> <li>The system designer must ensure the boundary conditions described<br/>in Section 10.4 do not occur.</li> </ul>                                                                                                                                                                                                                                                                                                          |
|                                             |                                   | Data transmit mode of I <sup>2</sup> C master operation.                                                                                                                                                                                                                                                                                                                                                                         |
| Write one data                              | a Master-transmit                 | <ul> <li>Occurs when the IDBR Transmit Empty ISR bit is set and the<br/>Transfer Byte bit is clear. When enabled, the IDBR Transmit Empty<br/>Interrupt is signalled to the Intel<sup>®</sup> XScale<sup>™</sup> core.</li> </ul>                                                                                                                                                                                                |
| byte to the IDBR                            | only                              | <ul> <li>Intel<sup>®</sup> XScale<sup>™</sup> core writes 1 data byte to the IDBR, set the<br/>appropriate START/STOP bit combination, and then set the Transfer<br/>Byte bit to send the data. Eight bits are written on the serial bus<br/>followed by a STOP when requested.</li> </ul>                                                                                                                                       |
| Wait for<br>Acknowledge<br>from             | Master-transmit only              | <ul> <li>As a master-transmitter, the I<sup>2</sup>C Bus Interface Unit generates the<br/>clock for the acknowledge pulse. The I<sup>2</sup>C Bus Interface Unit is<br/>responsible for releasing the SDA line to allow slave-receiver Ack<br/>transmission.</li> </ul>                                                                                                                                                          |
| slave-receiver                              |                                   | See Section 10.4.3.                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                             |                                   | Data receive mode of I <sup>2</sup> C master operation.                                                                                                                                                                                                                                                                                                                                                                          |
|                                             |                                   | Eight bits are read from the serial bus, collected in the shift register<br>then transferred to the IDBR after the Ack/Nack bit is read.                                                                                                                                                                                                                                                                                         |
|                                             | Master-receive only               | <ul> <li>The Intel<sup>®</sup> XScale<sup>™</sup> core reads the IDBR when the IDBR Receive<br/>Full bit is set and the Transfer Byte bit is clear. When enabled, a<br/>IDBR Receive Full Interrupt is signalled to the Intel<sup>®</sup> XScale<sup>™</sup> core<br/>processor.</li> </ul>                                                                                                                                      |
| Read one byte of I <sup>2</sup> C Data from |                                   | <ul> <li>When the IDBR is read, when the Ack/Nack Status is clear (indicating<br/>Ack), the Intel<sup>®</sup> XScale<sup>™</sup> core writes the Ack/Nack Control bit and set<br/>the Transfer Byte bit to initiate the next byte read.</li> </ul>                                                                                                                                                                               |
| the IDBR                                    |                                   | <ul> <li>When the Ack/Nack Status bit is set (indicating Nack), Transfer Byte<br/>bit is clear, STOP bit in the ICR is set, and Unit Busy bit in the ISR is<br/>set, then the last data byte has been read into the IDBR and the I<sup>2</sup>C<br/>Bus Interface Unit is sending the STOP.</li> </ul>                                                                                                                           |
|                                             |                                   | <ul> <li>When the Ack/Nack Status bit is set (indicating Nack), Transfer Byte bit is clear, but the STOP bit is clear, then the Intel<sup>®</sup> XScale<sup>™</sup> core has two options: 1. set the START bit, write a new target address to the IDBR, and set the Transfer Byte bit which sends a repeated start condition, 2. set the Master Abort bit and leave the Transfer Byte clear which sends a STOP only.</li> </ul> |



# Table 285. Master Transactions (Sheet 3 of 3)

| I <sup>2</sup> C Master<br>Action                                         | Mode of<br>Operation              | Definition                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmit<br>Acknowledge to<br>slave-transmitter                           | Master-receive only               | <ul> <li>As a master-receiver, the I<sup>2</sup>C Bus Interface Unit generates the clock for the acknowledge pulse. The I<sup>2</sup>C Bus Interface Unit is also responsible for driving the SDA line during the Ack cycle.</li> <li>When the next data byte is to be the last transaction, the Intel<sup>®</sup> XScale<sup>™</sup> core sets the Ack/Nack Control bit for Nack generation.</li> <li>See Section 10.4.3.</li> </ul> |
| Generate a<br>Repeated<br>START to chain<br>I <sup>2</sup> C transactions | Master-transmit<br>Master-receive | <ul> <li>When data chaining is desired, a repeated START condition is used instead of a STOP condition.</li> <li>This occurs after the last data byte of a transaction has been written to the bus.</li> <li>The Intel<sup>®</sup> XScale<sup>™</sup> core writes the next target slave address and the R/W# bit to the IDBR, set the START bit, and set the Transfer Byte bit.</li> <li>See Section 10.3.3₂</li> </ul>               |
| Generate a<br>STOP                                                        | Master-transmit<br>Master-receive | <ul> <li>Generated after the Intel<sup>®</sup> XScale<sup>™</sup> core writes the last data byte on the bus.</li> <li>Intel<sup>®</sup> XScale<sup>™</sup> core generates a STOP condition by setting the STOP bit in the ICR.</li> <li>See Section 10.3.3.</li> </ul>                                                                                                                                                                |

566 October, 2003 **Document Number: 273942-002** 



When the 80331 needs to read data, the I<sup>2</sup>C unit transitions from slave-receive mode to master-transmit mode to transmit the start address and immediately following the ACK pulse transitions to master-receive mode to wait for the reception of the read data from the slave device (see Figure 98). It is also possible to have multiple transactions during an I<sup>2</sup>C operation such as transitioning from master-receive to master-transmit through a repeated start or Data Chaining (see Figure 99). Figure 100 shows the wave forms of **SDA** and **SCL** for a complete data transfer.

#### Figure 98. Master-Receiver Read from Slave-Transmitter



Figure 99. Master-Receiver Read from Slave-Transmitter / Repeated Start / Master-Transmitter Write to Slave-Receiver



Figure 100. A Complete Data Transfer





# 10.4.6 Slave Operations

Table 286 describes the I<sup>2</sup>C Bus Interface Unit's responsibilities as a slave device.

#### **Table 286.** Slave Transactions

| I <sup>2</sup> C Slave Action                        | Mode of<br>Operation            | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slave-receive<br>(default mode)                      | Slave-receive only              | <ul> <li>I<sup>2</sup>C Bus Interface Unit monitors all slave address transactions.</li> <li>The I<sup>2</sup>C Bus Interface Unit Enable bit must be set.</li> <li>I<sup>2</sup>C Bus Interface Unit monitors bus for START conditions. When a START is detected, the interface reads the first 8 bits and compares the most significant 7 bits with the 7 bit I<sup>2</sup>C Slave Address Register and the General Call address (00H). When there is a match, the I<sup>2</sup>C Bus Interface Unit sends an Ack.</li> <li>When the first 8 bits are all zero's, this is a general call address. When the General Call Disable bit is clear, both the General Call Address Detected bit and the Slave Mode Operation bit in the ISR is set. See Section 10.4.7.</li> <li>When the 8th bit of the first byte (R/W# bit) is low, the I<sup>2</sup>C Bus Interface Unit stays in slave-receive mode and the Slave Mode Operation bit is cleared. When the R/W# bit is high, the I<sup>2</sup>C Bus Interface Unit transitions to slave-transmit mode and the Slave Mode Operation bit is set.</li> </ul> |
| Setting the Slave<br>Address Detected<br>bit         | Slave-receive<br>Slave-transmit | <ul> <li>Indicates the interface has detected an I<sup>2</sup>C operation that addresses the 80331 (this includes general call address). The Intel<sup>®</sup> XScale<sup>™</sup> core can distinguish an ISAR match from a General Call by reading the General Call Address Detected bit.</li> <li>An interrupt is signalled (when enabled) after the matching slave address is received and acknowledged.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Read one byte of I <sup>2</sup> C Data from the IDBR | Slave-receive<br>only           | <ul> <li>Data receive mode of I<sup>2</sup>C slave operation.</li> <li>Eight bits are read from the serial bus into the shift register. When a full byte has been received and the Ack/Nack bit has completed, the byte is transferred from the shift register to the IDBR.</li> <li>Occurs when the IDBR Receive Full bit in the ISR is set and the Transfer Byte bit is clear. When enabled, the IDBR Receive Full Interrupt is signalled to the Intel<sup>®</sup> XScale<sup>™</sup> core.</li> <li>Intel<sup>®</sup> XScale<sup>™</sup> core reads 1 data byte from the IDBR. When the IDBR is read, the Intel<sup>®</sup> XScale<sup>™</sup> core writes the desired Ack/Nack Control bit and set the Transfer Byte bit. This causes the I<sup>2</sup>C Bus Interface Unit to stop inserting wait states and let the master transmitter write the next piece of information.</li> </ul>                                                                                                                                                                                                             |
| Transmit<br>Acknowledge to<br>master-transmitter     | Slave-receive only              | <ul> <li>As a slave-receiver, the I<sup>2</sup>C Bus Interface Unit is responsible for pulling the SDA line low to generate the Ack pulse during the high SCL period.</li> <li>The Ack/Nack Control bit controls the Ack data the I<sup>2</sup>C Bus Interface Unit drives. See Section 10.4.3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Write one byte of I <sup>2</sup> C data to the IDBR  | Slave-transmit<br>only          | <ul> <li>Data transmit mode of I<sup>2</sup>C slave operation.</li> <li>Occurs when the IDBR Transmit Empty bit is set and the Transfer Byte bit is clear. When enabled, the IDBR Transmit Empty Interrupt is signalled to the Intel<sup>®</sup> XScale<sup>™</sup> core.</li> <li>Intel<sup>®</sup> XScale<sup>™</sup> core writes a data byte to the IDBR and set the Transfer Byte bit to initiate the transfer.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Wait for<br>Acknowledge<br>from<br>master-receiver   | Slave-transmit only             | <ul> <li>As a slave-transmitter, the I<sup>2</sup>C Bus Interface Unit is responsible for releasing the SDA line to allow the master-receiver to pull the line low for the Ack.</li> <li>See Section 10.4.3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



Figure 101 through Figure 103 are examples of I<sup>2</sup>C transactions. These show the relationships between master and slave devices.

#### Figure 101. Master-Transmitter Write to Slave-Receiver



Figure 102. Master-Receiver Read to Slave-Transmitter



Figure 103. Master-Receiver Read to Slave-Transmitter / Repeated START / Master-Transmitter Write to Slave-Receiver





#### 10.4.7 General Call Address

The I<sup>2</sup>C unit supports both sending and receiving general call address transfers on the I<sup>2</sup>C bus. When sending a general call message from the I<sup>2</sup>C unit, software must set the General Call Disable bit in the ICR to keep the I<sup>2</sup>C unit from responding as a slave. Failure to set this bit causes the I<sup>2</sup>C Bus to enter an indeterminate state.

A general call address is defined as a transaction with a slave address of 00H. When a device requires the data from a general call address, it acknowledges the transaction and stays in slave-receiver mode. Otherwise, the device can ignore the general call address. The second and following bytes of a general call transaction are acknowledged by every device using it on the bus. Any device not using these bytes must not Ack. The meaning of a general call address is defined in the second byte sent by the master-transmitter. Figure 104 shows a general call address transaction. The least significant bit (B) of the second byte defines the transaction. Table 287, "General Call Address Second Byte Definitions" on page 570 shows the valid values and definitions when B=0.

When the 80331 is acting as a slave, and the I<sup>2</sup>C unit receives a general call address and the ICR General Call Disable bit is clear the I<sup>2</sup>C unit:

- Sets the ISR general call address detected bit
- · Sets the ISR slave address detected bit
- Interrupts (when enabled) the 80331

When the I<sup>2</sup>C unit receives a general call address and the ICR General Call Disable bit is set, the I<sup>2</sup>C unit ignores the general call address.

#### Figure 104. General Call Address



#### Table 287. General Call Address Second Byte Definitions

| Least<br>Significant Bit of<br>Second Byte (B) | Second Byte<br>Value | Definition                                                                                                                                   |
|------------------------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                              | 06H                  | 2-byte transaction where the second byte tells the slave to reset and then store this value in the programmable part of their slave address. |
| 0                                              | 04H                  | 2-byte transaction where the second byte tells the slave to store this value in the programmable part of their slave address. No reset.      |
| 0                                              | 00H                  | Not allowed as a second byte                                                                                                                 |

When directed to reset, the I<sup>2</sup>C Bus Interface Unit returns to its default reset condition with the exception of the ISAR. The 80331 is responsible for ensuring this occurs, not the I<sup>2</sup>C Bus Interface Unit hardware.

When B=1, the sequence is used as a hardware general call by hardware masters only they cannot transmit a slave address, only their own address. The I<sup>2</sup>C Bus Interface Unit does not support this mode of operation.

I<sup>2</sup>C 10-bit addressing and CBUS compatibility are not supported.



# 10.5 Slave Mode Programming Examples

#### 10.5.1 Initialize Unit

1. Write ISAR: Set slave address

2. Write ICR: Enable all interrupts, set Unit Enable

# 10.5.2 Write 1 Byte as a Slave

Wait for Slave Address Detected interrupt.
 Read ISR: Slave Address Detected (set), Unit Busy (set), R/W# bit (1), Ack/Nack (Clear - Ack)

2. Write IDBR: Load data byte to transfer

3. Write ICR: Set Transfer Byte bit

4. Wait for IDBR Transmit Empty interrupt. Read ISR: IDBR Transmit Empty (set), Ack/Nack (set - indicates last byte write), R/W# bit (0)

5. Clear interrupt by clearing the IDBR Transmit Empty Interrupt bit.

6. Wait for interrupt. Read ISR: Unit Busy (clear), Slave STOP Detected (set)

7. Clear interrupt by clearing Slave STOP Detected Interrupt bit.

# 10.5.3 Read 2 Bytes as a Slave

1. Wait for Slave Address Detected interrupt. Read ISR: Slave Address Detected (set), Unit busy (set), R/W# bit (0)

2. Read byte 1 on I<sup>2</sup>C bus
Write ICR: Set Transfer Byte bit to initiate the transfer

3. Wait for interrupt.

Read ISR: IDBR Receive Full (set), Ack/Nack (clear), R/W# bit (0)

Clear interrupt by clearing IDBR Receive Full bit.

Read IDBR: To get the data.

4. Read byte 2 on I<sup>2</sup>C bus

Write ICR: Set Transfer Byte bit to initiate the transfer

5. Wait for interrupt.

Read ISR: IDBR Receive Full (set), Ack/Nack (clear), R/W# bit (0)

Clear interrupt by clearing IDBR Receive Full bit.

Read IDBR: To get the data.

Write ICR: Set Transfer Byte bit (to release I<sup>2</sup>C bus allowing next transfer)

6. Wait for interrupt.

Read ISR: Unit busy (clear), Slave STOP Detected (set) Clear interrupt by clearing Slave STOP Detected bit.



# 10.6 Master Programming Examples

#### 10.6.1 Initialize Unit

- 1. Write ISAR: Set slave address
- 2. Write ICR: Enable all interrupts (except Arb Loss), set SCL Enable, set Unit Enable

# 10.6.2 Write 1 Byte as a Master

- 1. Write IDBR: Target slave address and R/W# bit (0 for write)
- 2. Write ICR: Set START bit, Clear STOP bit, Set Transfer Byte bit to initiate the access
- 3. Wait for IDBR Transmit Empty interrupt. When interrupt arrives: Read status register: IDBR Transmit Empty (set), Unit Busy (set), R/W# bit (clear) Clear IDBR Transmit Empty Interrupt bit to clear the interrupt.

**Note:** Arbitration Loss Detected bit may be set. When arbitration was lost, because Arb Loss interrupt was disabled, an address retry occurs when bus becomes free. Clear Arbitration Loss Detected bit when set.

4. Send byte with STOP

Write IDBR: With data byte to send

Write ICR: Clear START bit, Set STOP bit, Enable Arb Loss interrupt, Set Transfer Byte bit to initiate the access

5. Wait for Buffer empty interrupt. When interrupt arrives (Note: Unit is sending STOP): Read status register: IDBR Transmit Empty (set), Unit busy (set - maybe), R/W# bit (clear) Clear IDBR Transmit Empty Interrupt bit to clear the interrupt. Clear ICR STOP bit (optional) Wait until Unit busy is clear before clearing the ICR SCL Enable bit.

## 10.6.3 Read 1 Byte as a Master

- 1. Write IDBR: Target slave address and R/W# bit (1 for read)
- 2. Write ICR: Set START bit, Clear STOP bit, Disable Arb loss interrupt, Set Transfer Byte bit to initiate the access
- 3. Wait for IDBR Transmit Empty interrupt. When interrupt arrives: Read status register: IDBR Transmit Empty (set), Unit busy (set), R/W# bit (set) Clear IDBR Transmit Empty bit to clear the interrupt.
- 4. Read byte with STOP

Write ICR: Clear START bit, Set STOP bit, Enable arb loss interrupt, Set Ack/Nack bit (Nack), Set Transfer Byte bit to initiate the access

5. Wait for Buffer full interrupt. When interrupt arrives (Note: Unit is sending STOP): Read status register: IDBR Receive Full (set), Unit Busy (set - maybe), R/W# bit (Set), Ack/Nack bit (Set)

Clear IDBR Receive Full bit to clear the interrupt.

Read IDBR data.

Clear ICR STOP bit (optional), Clear ICR Ack/Nack Control bit (optional)

Wait until Unit busy is clear before clearing the ICR SCL Enable bit. (optional)



## 10.6.4 Write 2 Bytes and Repeated Start Read 1 Byte as a Master

- 1. Write IDBR: Target slave address and R/W# bit (0 for write)
- 2. Write ICR: Set START bit, Clear STOP bit, Set Transfer Byte bit to initiate the access
- 3. Wait for IDBR Transmit Empty interrupt. When interrupt arrives: Read status register: IDBR Transmit Empty (set), Unit busy (set), R/W# bit (clear) Clear IDBR Transmit Empty bit to clear the interrupt.
- 4. Send byte 1

Write IDBR: With data byte to send

Write ICR: Clear START bit, Clear STOP bit, Enable Arb Loss interrupt, Set Transfer Byte bit to initiate the access

5. Wait for Buffer empty interrupt.

Read status register: IDBR Transmit Empty (set), Unit busy (set), R/W# bit (clear) Clear IDBR Transmit Empty bit to clear the interrupt.

6. Send byte 2

Write IDBR: With data byte to send

Write ICR: Clear START bit, Clear STOP bit, Set Transfer Byte bit to initiate the access

7. Wait for Buffer empty interrupt.

Read status register: IDBR Transmit Empty (set), Unit busy (set), R/W# bit (clear) Clear IDBR Transmit Empty bit to clear the interrupt.

8. Send repeated start as a master

Write IDBR: Target slave address and R/W# bit (1 for read)

Write ICR: Set START bit, Clear STOP bit, Disable Arb Loss interrupt, Set Transfer Byte bit the initiate the access

9. Wait for IDBR Transmit Empty interrupt. When interrupt comes.

Read status register: IDBR Transmit Empty (set), Unit busy (set), R/W# bit (set) Clear IDBR Transmit Empty bit to clear the interrupt.

10. Read byte with STOP

Write ICR: Clear START bit, Set STOP bit, Enable arb loss interrupt, Set Ack/Nack bit (Nack), Set Transfer Byte bit to initiate the access

11. Wait for Buffer full interrupt. When interrupt comes (Note: Unit is sending STOP).

Read status register: IDBR Receive Full (set), Unit busy (set - maybe), R/W# bit (Set), Ack/Nack bit (Set)

Clear IDBR Receive Full bit to clear the interrupt.

Read IDBR data.

Clear ICR STOP bit (optional), Clear ICR Ack/Nack Control bit (optional)

Wait until Unit busy is clear before clearing the ICR SCL Enable bit. (optional)



# 10.6.5 Read 2 Bytes as a Master - Send STOP Using the Abort

- 1. Write IDBR: Target slave address and R/W# bit (1 for read)
- 2. Write ICR: Set START bit, Clear STOP bit, Disable Arb loss interrupt, Set Transfer Byte bit to initiate the access
- 3. Wait for IDBR Transmit Empty interrupt. When interrupt comes. Read status register: IDBR Transmit Empty (set), Unit Busy (set), R/W# bit (set) Clear IDBR Transmit Empty bit to clear the interrupt.
- 4. Read byte 1

Write ICR: Clear START bit, Clear STOP bit, Enable Arb Loss interrupt, Clear Ack/Nack bit (Ack), Set Transfer Byte bit to initiate the access

5. Wait for Buffer full interrupt.

Read status register: IDBR Receive Full (set), Unit busy (set), R/W# bit (Set), Ack/Nack bit (Clear)

Clear IDBR Receive Full bit to clear the interrupt.

Read IDBR data.

6. Read byte 2 with Nack (STOP is not set because STOP or Repeated START is decided on the byte read)

Write ICR: Clear START bit, Clear STOP bit, Enable Arb Loss interrupt, Set Ack/Nack bit (Nack), Set Transfer Byte bit to initiate the access

7. Wait for Buffer full interrupt.

Read status register: IDBR Receive Full (set), Unit Busy (set), R/W# bit (Set), Ack/Nack bit (Set)

Clear IDBR Receive Full bit to clear the interrupt.

Read IDBR data.

There are now two options based on the byte read:

- · Send a repeated START
- Send a STOP only

Here, a STOP abort is sent.

Note: Had a NACK not been sent, the next transaction must involve another data byte read.

8. Send STOP abort condition. (STOP with no data transfer.) Write ICR: Set Master abort.



# 10.7 Glitch Suppression Logic

The  $I^2C$  Bus Interface Unit has built-in glitch suppression logic. Glitches is suppressed according to:  $2 * I^2C$  clock period. For example, with the 33 MHz (30. ns period)  $I^2C$  clock glitches of 60ns or less is suppressed. This is within the 50 ns glitch suppression specified.

### 10.8 Reset Conditions

The  $I^2C$  unit is reset with **I\_RST#**. Software is responsible for ensuring the  $I^2C$  unit is not busy (ISR[3]) before asserting reset. Software is also responsible for ensuring the  $I^2C$  bus is idle when the unit is enabled after reset. When directed to reset, the  $I^2C$  unit returns to its default reset condition with the exception of the ISAR. ISAR is not affected by a reset.

When the Unit Reset bit in the ICRx is set, only the 80331 I<sup>2</sup>C unit resets, the associated I<sup>2</sup>C MMRs remain intact. When resetting the I<sup>2</sup>C unit with the ICRx units reset, use the following guidelines:

- 1. In the ICRx register, set the reset bit and clear the remainder of the register.
- 2. Clear the ISRx register.
- 3. Clear reset in the ICRx.

# 10.9 Register Definitions

The following registers are associated with the I<sup>2</sup>C Bus Interface Units. Each I<sup>2</sup>C Bus Interface Unit has five memory-mapped control registers for independent operation. In register titles, x is 0 or 1 for unit 0 or 1, respectively.

They are all located within the peripheral memory- mapped address space of the 80331. See Section 5.8, "Register Definitions" on page 341 for the register addresses

#### Table 288. I<sup>2</sup>C Register Summary

| Section, Register Name, Acronym, Page                                           |
|---------------------------------------------------------------------------------|
| Section 10.9.1, "I <sup>2</sup> C Control Register x - ICRx" on page 576        |
| Section 10.9.2, "I <sup>2</sup> C Status Register x - ISRx" on page 578         |
| Section 10.9.3, "I <sup>2</sup> C Slave Address Register x - ISARx" on page 580 |
| Section 10.9.4, "I <sup>2</sup> C Data Buffer Register x - IDBRx" on page 581   |
| Section 10.9.5, "I <sup>2</sup> C Bus Monitor Register x - IBMRx" on page 582   |



# 10.9.1 I<sup>2</sup>C Control Register x - ICRx

The 80331 uses the bits in the I<sup>2</sup>C Control Register (ICRx) to control the I<sup>2</sup>C unit.

Table 289.  $I^2C$  Control Register x - ICRx (Sheet 1 of 2)





Table 289.  $I^2C$  Control Register x - ICRx (Sheet 2 of 2)





# 10.9.2 I<sup>2</sup>C Status Register x - ISRx

 $I^2C$  interrupts are signalled to the 80331 interrupt controller by the  $I^2C$  Interrupt Status Register (ISRx). Software uses the ISR bits to check the status of the  $I^2C$  unit and bus. ISRx bits (bits 9-5) are updated after the Ack/Nack bit has completed on the  $I^2C$  bus.

The ISRx is also used to clear interrupts signalled from the I<sup>2</sup>C Bus Interface Unit. These are:

- IDBRx Receive Full
- IDBRx Transmit Empty
- · Slave Address Detected
- · Bus Error Detected
- STOP Condition Detect
- Arbitration Lost

Table 290. I<sup>2</sup>C Status Register x - ISRx (Sheet 1 of 2)





### Table 290. I<sup>2</sup>C Status Register x - ISRx (Sheet 2 of 2)





# 10.9.3 I<sup>2</sup>C Slave Address Register x - ISARx

The  $I^2C$  Slave Address Register (ISARx) (see Table 291) defines the  $I^2C$  unit 7-bit slave address to which the 80331 responds when in slave-receive mode. This register is written by the 80331 before enabling  $I^2C$  operations. The register is fully programmable (no address is assigned to the  $I^2C$  unit) so it can be set to a value other than those of hard-wired  $I^2C$  slave peripherals that might exist in the system. The ISAR is not affected by the 80331 being reset. The ISAR register default value is  $0000000_2$ .

Table 291. I<sup>2</sup>C Slave Address Register x - ISARx





## 10.9.4 I<sup>2</sup>C Data Buffer Register x - IDBRx

The  $I^2C$  Data Buffer Register (IDBRx) is used by the 80331 to transmit and receive data from the  $I^2C$  bus. The accesses the IDBRx by the 80331 on one side and by the  $I^2C$  shift register on the other. Data coming into the  $I^2C$  Bus Interface Unit is received into the IDBRx after a full byte has been received and acknowledged. Data going out of the  $I^2C$  Bus Interface Unit is written to the IDBRx by the Intel<sup>®</sup> XScale<sup>TM</sup> core and sent to the serial bus.

When the  $I^2C$  Bus Interface Unit is in transmit mode (master or slave), the 80331 writes data to the IDBRx over the internal bus. This occurs when a master transaction is initiated or when the IDBRx Transmit Empty Interrupt is signalled. Data is moved from the IDBRx to the shift register when the Transfer Byte bit is set. The IDBR Transmit Empty Interrupt is signalled (when enabled) when a byte has been transferred on the  $I^2C$  bus and the acknowledge cycle is complete. When the IDBRx is not written by the 80331 (and a STOP condition was not in place) before the  $I^2C$  bus is ready to transfer the next byte packet, the  $I^2C$  Bus Interface Unit inserts wait states until the Intel<sup>®</sup> XScale ore writes the IDBRx and sets the Transfer Byte bit.

When the I<sup>2</sup>C Bus Interface Unit is in receive mode (master or slave), the processor reads IDBRx data over the internal bus. This occurs when the IDBRx Receive Full Interrupt is signalled. The data is moved from the shift register to the IDBRx when the Ack cycle is complete. The I<sup>2</sup>C Bus Interface Unit inserts wait states until the IDBR has been read. Refer to Section 10.4.3, "I<sup>2</sup>C Acknowledge" on page 561 for acknowledge pulse information in receiver mode. After the 80331 reads the IDBRx, the Ack/Nack Control bit is written and the Transfer Byte bit is written, allowing the next byte transfer to proceed on the I<sup>2</sup>C Bus. The IDBRx register is 00H after reset.

Table 292. I<sup>2</sup>C Data Buffer Register x - IDBRx





# 10.9.5 I<sup>2</sup>C Bus Monitor Register x - IBMRx

The  $I^2C$  Bus Monitor Register (IBMRx) tracks the status of the **SCL** and **SDA** pins. The values of these pins are recorded in this read-only register so that software may determine when the  $I^2C$  bus is hung and the  $I^2C$  unit must be reset.

Table 293. I<sup>2</sup>C Bus Monitor Register x - IBMRx





# **UARTs**

11

This chapter describes the Universal Asynchronous Receiver/Transmitter (UART) serial ports. The Intel<sup>®</sup> 80331 I/O processor (80331) UARTs are controlled via programmed I/O through memory-mapped registers.

### 11.1 Overview

Each asynchronous serial port supports all the functions of a 16550 UART. Each UART performs serial-to-parallel conversion on data characters received from a peripheral device or a modem and parallel-to-serial conversion on data characters received from the processor. The processor can read the complete status of a UART at any time during the functional operation. Available status information includes the type and condition of the transfer operations being performed by a UART and any error conditions (parity, overrun, framing, or break interrupt).

Each serial port can operate in either FIFO or non-FIFO mode. In FIFO mode, a 64-byte transmit FIFO holds data from the processor to be transmitted on the serial link and a 64-byte Receive FIFO buffers data from the serial link until read by the processor.

Each UART includes a programmable baud rate generator which is capable of dividing the input clock by divisors of 1 to (2<sup>16</sup>–1) and producing a 16X clock to drive the internal transmitter and receiver logic. Interrupts can be programmed to the user requirements, minimizing the computing required to handle the communications link. Each UART operates in a polled or an interrupt driven environment which is selected by software.



The UART hardware is responsible for executing serial protocol communication and for providing the programming interface. The UART features include:

- Registers are compatible with the 16550 and 16750
- Adds or deletes standard asynchronous communications bits (start, stop, and parity) to or from the serial data
- Independently controlled transmit, receive, line status and data set interrupts
- Baud-rate generator allows division of clock by 1 to (2 16-1) and generates an internal 16X clock; baud-rate can be manually or automatically programmed via auto-baud-rate detection circuitry
- Modem control functions (CTS#, RTS#)
- Autoflow capability controls data I/O without generating Interrupts:
  - RTS# (output) controlled by UART Receiver FIFO
  - CTS# (input) from modem controls UART transmitter
- Fully programmable serial-interface characteristics:
  - 5, 6, 7 or 8-bit characters
  - Even, odd, or no parity detection
  - -1, 1-1/2, or 2 stop bit generation
  - Baud rate generation (up to 115kbps)
- False start bit detection
- 64-byte Transmit FIFO
- 64-byte Receive FIFO with programmable threshold
- Complete status reporting capability
- · Break generation and detection
- Internal diagnostic capabilities include:
  - Loopback controls for communications link fault isolation
  - Break, parity, overrun, and framing error simulation
- Fully prioritized interrupt system controls

## 11.1.1 Compatibility with 16550 and 16750

The UARTs can be programmed to be functionally compatible with industry standard 16550 and 16750. Each UART supports most of the 16550 and 16750 functions and has additional features, as listed below.

- DMA requests for transmit and receive data services
- NRZ encoding/decoding function
- 64-byte Transmit/Receive FIFO buffers
- Programmable Receive FIFO threshold
- · Auto baud-rate detection
- · Auto flow



# 11.2 Signal Descriptions

The name and description of external signals connected to a UART module are shown in Table 294. These signals are multiplexed with the GPIO signals as specified in Chapter 16, "General Purpose I/O Unit". The selection between GPIO and UART function for these multiplexed pins is controlled by the UART Unit Enable bit (UUE bit 6) of the "UART x Interrupt Enable Register" on page 596.

Table 294. UART Signal Descriptions

| Name*   | Туре   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Ux_RXD  | Input  | SERIAL INPUT: Serial data input from device pin to the receive shift register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Ux_TXD  | Output | SERIAL OUTPUT: Composite serial data output to the communications link-peripheral, modem, or data set. The TXD signal is set to the MARKING (logic 1) state upon a Reset operation.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|         |        | CLEAR TO SEND: When low, this pin indicates that the receiving UART is ready to receive data. When the receiving UART deasserts <b>CTS#</b> high, the transmitting UART should stop transmission to prevent overflow of the receiving UARTs buffer. The <b>CTS#</b> signal is a modem-status input whose condition can be tested by the host processor or by the UART when in Autoflow mode as described below:                                                                                                                                                     |  |  |  |
|         |        | Non-Autoflow Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| Ux_CTS# | Input  | When not in Autoflow mode, bit 4 (CTS) of the Modem Status register (MSR) indicates the state of CTS#. Bit 4 is the complement of the CTS# signal. Bit 0 (DCTS) of the Modem Status register indicates whether the CTS# input has changed state since the previous reading of the Modem Status register. CTS# has no effect on the transmitter. The user can program the UART to interrupt the processor when DCTS changes state. The programmer can then stall the outgoing data stream by starving the transmit FIFO or disabling the UART with the IER register. |  |  |  |
|         |        | Note: When UART transmission is stalled by disabling the UART, the user does not receive an MSR interrupt when CTS# reasserts. This is because disabling the UART also disables interrupts. To get around this, the user can use Auto CTS in Autoflow Mode, or program the CTS# pin to interrupt.                                                                                                                                                                                                                                                                   |  |  |  |
|         |        | Autoflow Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|         |        | In Autoflow mode, the UART Transmit circuity checks the state of <b>CTS#</b> before transmitting each byte. IF <b>CTS#</b> is high, no data is transmitted. See Section 11.4.7, UART x Modem Control Register for more information on Auto CTS mode.                                                                                                                                                                                                                                                                                                                |  |  |  |
|         |        | REQUEST TO SEND: When low, this informs the remote device that the UART is ready to receive data. A reset operation sets this signal to its Inactive (high) state. LOOP mode operation holds this signal in its Inactive state.                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|         |        | Non-Autoflow Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| Ux_RTS# | Output | The RTS# output signal can be asserted by setting bit 1 (RTS) of the Modem Control register to a 1. The RTS bit is the complement of the RTS# signal.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|         |        | Autoflow Mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|         |        | RTS# is automatically asserted by the autoflow circuitry when the Receive buffer exceeds its programmed threshold. It is deasserted when enough bytes are removed from the buffer to lower the data level back to the threshold. See Section 11.4.7, UART x Modem Control Register for more information on Auto RTS mode.                                                                                                                                                                                                                                           |  |  |  |

*Note:* \* "x" in signal name replaced with either "0" or "1" for UART-0 or UART-1 respectively.



## 11.3 Theory of Operation

The format of a UART data frame is shown in Figure 105.

Figure 105. Example UART Data Frame

|     | Start<br>Bit   | Data<<br>0> | Data<<br>1> | Data<<br>2> | Data<<br>3> | Data<<br>4> | Data<<br>5> | Data<<br>6> | Data<<br>7> | Parity<br>Bit | Stop<br>Bit 1 | Stop<br>Bit 2 |  |
|-----|----------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|---------------|---------------|---------------|--|
| TXI | TXD or RXD pin |             |             |             |             |             |             |             |             |               |               |               |  |
|     |                | LSB         |             |             |             |             |             |             | MSB         |               |               |               |  |

Shaded bits are optional and can be programmed by user. —>

Each data frame is between 7 bits and 12 bits long, depending on the size of data programmed and when parity and stop bits are enabled. The frame begins with a start bit that is represented by a high-to-low transition. Next, five to eight bits of data are transmitted, beginning with the least significant bit. An optional parity bit follows, which is set when even parity is enabled and an odd number of ones exist within the data byte; or when odd parity is enabled and the data byte contains an even number of ones. The data frame ends with one, one-and-one-half or two stop bits (as programmed by the user), which is represented by one or two successive bit periods of a logic one.

NRZ coding can be used by the UART to represent individual bit values. NRZ coding is enabled when Interrupt Enable Register (IER) bit-5 is set to high. A one is represented by a line transition and a zero is represented by no line transition. Figure 106 shows the NRZ coding of the data byte 8b 0100 1011. Note that the byte's LSB is transmitted first.

Figure 106. NRZ Bit Encoding Example – (0100 1011)



The unit is disabled upon reset, and users need to program GPIO registers first and then enable the unit by setting the UART Unit Enable bit (UUE, bit-6) of Interrupt Enable Register. When the unit is enabled, the receiver starts looking for the start bit of a frame; the transmitter sends data to the transmit data pin when there is data available in the transmit FIFO. Transmit data can be written to the FIFO before the unit is enabled. When the UART is disabled, the transmitter/receiver finishes the current byte being transmitted/received (when it is in the middle of transmitting/receiving a byte), and stops transmitting/receiving more data. Disabling the UART with the UUE bit does not clear transmission/reception with the original data.

Each UART has a Transmit FIFO and a Receive FIFO each holding 64 characters of data. There

are two methods for moving data into/out of the FIFOs: Interrupts and Polling.



### 11.3.1 FIFO Interrupt Mode Operation

### 11.3.1.1 Receiver Interrupt

When the Receive FIFO and receiver interrupts are enabled (FCR[0]=1 and IER[0]=1), receiver interrupts occur as follows:

- The Receive Data Available Interrupt is asserted when the FIFO has reached its programmed trigger level. The interrupt is cleared when the FIFO drops below the programmed trigger level.
- The IIR Receive Data Available indication also occurs when the FIFO trigger level is reached, and like the interrupt, the bits are cleared when the FIFO drops below the trigger level.
- The Data Ready bit (DR in LSR register) is set to 1 as soon as a character is transferred from the shift register to the Receive FIFO. This bit is reset to 0 when the FIFO is empty.

### 11.3.1.2 Transmit Interrupt

When the transmitter FIFO and transmitter interrupt are enabled (FCR[0]=1, IER[1]=1), transmit interrupts occur as follows:

- When the Flow Control Register Transmitter Interrupt Level (TIL) bit (FCR[3]) is clear (0), The Transmit Data Request interrupt occurs when the transmit FIFO is half empty or more than half empty. The interrupt is cleared when the data level exceeds the half-empty mark. The interrupt is cleared as soon as the Transmit Holding Register is written or the IIR is read. 1 to 32 characters may be written to the transmit FIFO while servicing the interrupt when TIL=0.
- When the Flow Control Register Transmitter Interrupt Level (TIL) bit is set (1), The Transmit Data Request Interrupt occurs when the Transmit FIFO is empty. The interrupt is cleared as soon as the Transmit Holding Register is written or the IIR is read. 1 to 64 characters may be written to the Transmit FIFO while servicing the interrupt when TIL = 1.

Users could cause the UART Transmit FIFO to overflow when too many characters are written. FIFO underflow does not cause an error as the UART waits for the Transmit FIFO to be serviced.



### 11.3.2 Removing Trailing Bytes In Interrupt Mode

When the number of entries in the Receive FIFO is less than its trigger level, and no additional data is received, the remaining bytes are called trailing bytes. When the receive FIFO is being serviced by processor interrupts, trailing bytes need to be removed via the processor using the 16550 compliant character timeout interrupt: Time Out Detected (TOD) bit of Interrupt Identification Register. To enter this mode, users need to insure that the character timeout interrupt is enabled via IER[4].

To remove trailing bytes in Interrupt mode, the user must wait for the character timeout interrupt and then read all remaining bytes as indicated in the FIFO Occupancy Register (FOR), or read one byte at a time until the FIFO is empty. This can be determined by polling the Line Status Register bit 0 through programmed I/O.

### 11.3.2.1 Character Timeout Interrupt

When the Receiver FIFO and Receiver Timeout Interrupt are enabled, a character timeout interrupt (TOD) occurs to signal the presence of trailing bytes. The Interrupt is cleared and the timer is reset when a character is read from the Receiver FIFO. When a timeout Interrupt has not occurred, the timeout timer is reset after a new character is received or after the processor reads the Receiver FIFO.

When enabled via IER[4], a character timeout occurs under the following conditions:

- At least one character is in the FIFO.
- A character has not been received for the amount of time it takes to receive four or more characters at the current baud rate.
- The FIFO has not been read for the amount of time it takes to receive four or more characters

## 11.3.3 FIFO Polled Mode Operation

With the FIFOs enabled (TRFIFOE bit of FCR set to 1), clearing IER[4:0] puts the serial port in the FIFO polled mode of operation. Since the receiver and the transmitter are controlled separately, either one or both can be in the Polled Operation mode. In this mode, software checks Receiver and Transmitter status via the LSR. The processor polls the following bits for Receive and Transmit Data Service.

#### 11.3.3.1 Receive Data Service

• Processor should check *Data Ready bit of LSR* which is set when 1 or more bytes remains in the Receive FIFO or Receive Buffer register (RBR).

#### 11.3.3.2 Transmit Data Service

- Processor should check Transmit Data Request bit of LSR which is set when transmitter needs data.
- Processor can also check *Transmitter Empty bit of LSR*, which is set when the Transmit FIFO or Holding register is empty.

589



### 11.3.4 Autoflow Control

Autoflow Control uses the Clear-to-Send (CTS#) and Request-to-Send (RTS#) signals to automatically control the flow of data between the UART and external modem. When autoflow is enabled, the remote device is not allowed to send data unless the UART asserts nRTS low. When the UART deasserts RTS# while the remote device is sending data, the remote device is allowed to send one additional byte after RTS# is deasserted. An overflow could occur when the remote device violates this rule. Likewise, the UART is not allowed to transmit data unless the remote device asserts CTS# low. This feature increases system efficiency and eliminates the possibility of a Receive FIFO Overflow error due to long Interrupt latency.

Autoflow mode can be used in two ways: **Full autoflow**, automating both **CTS**# and **RTS**#, and **half autoflow**, automating only **CTS**#. Full Autoflow is enabled by writing a 1 to bits 1 and 5 of the Modem Control register (MCR). Auto-CTS-Only mode is enabled by writing a 1 to bit 5 and a 0 to bit 1 of the MCR register.

#### 11.3.4.1 RTS Autoflow

When in full autoflow mode, **RTS**# is asserted when the UART FIFO is ready to receive data from the remote transmitter. This occurs when the amount of data in the Receive FIFO is below the programmable threshold value. When the amount of data in the Receive FIFO reaches the programmable threshold, **RTS**# is deasserted. It is asserted once again when enough bytes are removed from the FIFO to lower the data level below the threshold.

### 11.3.4.2 CTS Autoflow

When in Full or Half-Autoflow mode, **CTS**# is asserted by the remote receiver when the receiver is ready to receive data from the UART. The UART checks **CTS**# before sending the next byte of data and does not transmit the byte until **CTS**# is low. When **CTS**# goes high while the transfer of a byte is in progress, the transmitter completes this byte.

*Note:* Autoflow mode can be used only in conjunction with FIFO mode.



#### 11.3.5 Auto-Baud-Rate Detection

Each UART supports auto-baud-rate detection. When enabled, the UART counts the number of 33.334 MHZ clock cycles within the *start*-bit pulse. This number is then written into the Auto-Baud-Count register (ACR) and is used to calculate the baud rate. When the ACR is written, a Auto-Baud-Lock Interrupt is generated (when enabled), and the UART automatically programs the Divisor Latch registers with the appropriate baud rate. When preferred, the processor can read the Auto-Baud- Count register and use this information to program the Divisor-Latch registers with a baud rate calculated by the processor. After the baud rate has been programmed, it is the responsibility of the processor to verify that the predetermined characters (usually **AT** or **at**) are being received correctly.

When the UART programs Divisor Latch registers, users can choose between two auto-baud calculation methods: **table-** and **formula-based**. The method is selected via bit *ABT* of the Auto-Baud Control register (ABR). When the formula method is used, any baudrate allowed in Equation 13 can be programmed by the UART. This method works well for higher baud rates, but could possibly fail below 28.8 kbps when the remote transmitter's actual baud rate differs by more than one percent of its target.

#### **Equation 13. Baud-Rate Equation**

$$BaudRate = \frac{33.334 Mhz}{(16XDivisor)}$$

The table method is more immune to such errors as the table rejects uncommon baud rates and rounds to the common ones. The table method allows any baud rate in Equation 13 above 28.8 kbps. Below 28.8 kbps the only baud rates which can be programmed by the UART are 19200, 14400, 9600, 4800, 1200, and 300 baud. Some typical values for Divisor and corresponding baud rates are provided in Table 295. Baud rates above 3600 baud require only Divisor Latch Low Register to be programmed, as Divisor Latch High Register would be 0.

Table 295. Divisor Values for Typical Baud Rates

| Baud Rate | Divisor | UART Rate | Error |
|-----------|---------|-----------|-------|
| 115.2K    | 18      | 115.74K   | 0.47% |
| 57.6K     | 36      | 57.87K    | 0.47% |
| 38.4K     | 54      | 38.58K    | 0.47% |
| 33.6K     | 62      | 33.60K    | 0.01% |
| 28.8K     | 72      | 28.94K    | 0.47% |
| 19.2K     | 109     | 19.29K    | 0.47% |
| 14.4K     | 145     | 14.47K    | 0.47% |
| 9600      | 217     | 9645      | 0.47% |
| 4800      | 434     | 4800      | 0.01% |
| 3600      | 579     | 3600      | 0.01% |
| 2400      | 868     | 2400      | 0.01% |
| 1200      | 1736    | 1200      | 0.01% |
| 600       | 3472    | 600       | 0.01% |
| 300       | 6944    | 300       | 0.01% |

When the baud rate is detected, auto-baud circuitry disarms itself by clearing bit *ABE* of the Auto-Baud Control register (ABR). When users want to rearm the circuitry, the *ABE* bit must be rewritten.

**Note:** For the auto-baud-rate detection circuit to work correctly, the first data bit transmitted after the start bit must be a logic '1'. When a logic '0' is transmitted instead, the autobaud circuit counts the zero as part of the start bit, resulting in an incorrect baud rate being programmed into the DLL and DLH registers.



### 11.3.6 Manual Baud Rate Selection

Each UART contains a programmable Baud Rate Generator that is capable of taking the fixed input clock of 33.334 MHz and dividing it by any divisor from 1 to (2<sup>16</sup>–1). The baud-rate generator output frequency is 16 times the baud rate. Two 8-bit registers store the divisor in a 16-bit binary format. These Divisor Registers must be loaded during initialization to ensure proper operation. When both Divisor Latches are loaded with 0, the 16X output clock is stopped. Access to the Divisor latch can be done with a word write. Equation 13 or Table 295 are used by the programmer to select the Divisor Latch value for the desired baud rate.



## 11.4 Register Descriptions

There are 15 registers in each UART. The registers are all 32 bit registers, but only lower 8 bits have valid data. The 12 UART registers share eight address locations in the MMR address space. Table 296 shows the registers and their addresses as offsets of a base address. The base address for each UART is 32 bits and is internal bus address FFFF F700H for UART 0, and FFFF F740H for UART 1. Note that the state of the Divisor Latch Bit (DLAB), which is the MOST significant bit of the Serial Line Control Register, affects the selection of certain of the UART registers. The DLAB bit must be set high by the system software to access the Baud Rate Generator Divisor Latches.

Table 296. UART Register Addresses as Offsets of a Base

| UART Register<br>Addresses | DLAB Bit Value | Name  | Register Accessed                          |
|----------------------------|----------------|-------|--------------------------------------------|
| Base                       | 0              | UxRBR | UART x Receive BUFFER (read only)          |
| Base                       | 0              | UxTHR | UART x Transmit BUFFER (write only)        |
| Base + 04H                 | 0              | UxIER | UART x Interrupt Enable (R/W)              |
| Base + 08H                 | X              | UxIIR | UART x Interrupt I.D. (read only)          |
| Base + 08H                 | X              | UxFCR | UART x FIFO Control (write only)           |
| Base + 0CH                 | X              | UxLCR | UART x Line Control (R/W)                  |
| Base + 10H                 | X              | UxMCR | UART x Modem Control (R/W)                 |
| Base + 14H                 | X              | UxLSR | UART x Line Status (Read only)             |
| Base + 18H                 | X              | UxMSR | UART x Modem Status (Read only)            |
| Base + 1CH                 | X              | UxSPR | UART x Scratch Pad (R/W)                   |
| Base                       | 1              | UxDLL | UART x Divisor Latch (Low Byte, R/W)       |
| Base + 04H                 | 1              | UxDLH | UART x Divisor Latch (High Byte, R/W)      |
| Base + 24H                 | X              | UxFOR | UART x FIFO Occupancy Register (R/W)       |
| Base + 28H                 | X              | UxABR | UART x Autobaud Control Register (R/W)     |
| Base + 2CH                 | X              | UxACR | UART x Autobaud Count Register (read only) |

Table 297. UART Unit Registers

| Section, Register Name, Acronym (page)                                 |
|------------------------------------------------------------------------|
| Section 11.4.1, "UART x Receive Buffer Register" on page 594           |
| Section 11.4.2, "UART x Transmit Holding Register" on page 595         |
| Section 11.4.3, "UART x Interrupt Enable Register" on page 596         |
| Section 11.4.4, "UART x Interrupt Identification Register" on page 597 |
| Section 11.4.5, "UART x FIFO Control Register" on page 599             |
| Section 11.4.6, "UART x Line Control Register" on page 601             |
| Section 11.4.7, "UART x Modem Control Register" on page 603            |
| Section 11.4.8, "UART x Line Status Register" on page 605              |
| Section 11.4.9, "UART x Modern Status Register" on page 608            |
| Section 11.4.10, "UART x Scratchpad Register" on page 609              |
| Section 11.4.11, "Divisor Latch Registers" on page 610                 |
| Section 11.4.13, "UART x Auto-Baud Control Register" on page 612       |
| Section 11.4.14, "UART x Auto-Baud Count Register" on page 613         |



Table 298. UART Register MMR Addresses

| UART Register<br>Addresses          | DLAB Bit Value | Name  | Register Accessed                          |  |  |
|-------------------------------------|----------------|-------|--------------------------------------------|--|--|
| FFF                                 | 0              | U0RBR | UART 0 Receive BUFFER (read only)          |  |  |
| FFFF F700H                          | 0              | U0THR | UART 0 Transmit BUFFER (write only)        |  |  |
| FFFF F704H                          | 0              | U0IER | UART 0 Interrupt Enable (R/W)              |  |  |
| FFF                                 | X              | U0IIR | UART 0 Interrupt I.D. (read only)          |  |  |
| FFFF F708H                          | X              | U0FCR | UART 0 FIFO Control (write only)           |  |  |
| FFFF F70CH                          | X              | U0LCR | UART 0 Line Control (R/W)                  |  |  |
| FFFF F710H                          | X              | U0MCR | UART 0 Modem Control (R/W)                 |  |  |
| FFFF F714H                          | Х              | U0LSR | UART 0 Line Status (Read only)             |  |  |
| FFFF F718H                          | Х              | U0MSR | UART 0 Modern Status (Read only)           |  |  |
| FFFF F71CH                          | Х              | U0SPR | UART 0 Scratch Pad (R/W)                   |  |  |
| FFFF F700H                          | 1              | U0DLL | UART 0 Divisor Latch (Low Byte, R/W)       |  |  |
| FFFF F704H                          | 1              | U0DLH | UART 0 Divisor Latch (High Byte, R/W)      |  |  |
| FFFF F720H                          | Х              | n/a   | Reserved                                   |  |  |
| FFFF F724H                          | Х              | U0FOR | UART 0 FIFO Occupancy Register (R/W)       |  |  |
| FFFF F728H                          | Х              | U0ABR | UART 0 Autobaud Control Register (R/W)     |  |  |
| FFFF F72CH X U0                     |                | U0ACR | UART 0 Autobaud Count Register (read only) |  |  |
| FFFF F730H<br>through<br>FFFF F73FH | х              | n/a   | Reserved                                   |  |  |
|                                     | 0              | U1RBR | UART 1 Receive BUFFER (read only)          |  |  |
| FFFF F740H                          | 0              | U1THR | UART 1 Transmit BUFFER (write only)        |  |  |
| FFFF F744H                          | 0              | U1IER | UART 1 Interrupt Enable (R/W)              |  |  |
|                                     | Х              | U1IIR | UART 1 Interrupt I.D. (read only)          |  |  |
| FFFF F748H                          | Х              | U1FCR | UART 1 FIFO Control (write only)           |  |  |
| FFFF F74CH                          | Х              | U1LCR | UART 1 Line Control (R/W)                  |  |  |
| FFFF F750H                          | Х              | U1MCR | UART 1 Modem Control (R/W)                 |  |  |
| FFFF F754H                          | Х              | U1LSR | UART 1 Line Status (Read only)             |  |  |
| FFFF F758H                          | Х              | U1MSR | UART 1 Modern Status (Read only)           |  |  |
| FFFF F75CH                          | Х              | U1SPR | UART 1 Scratch Pad (R/W)                   |  |  |
| FFFF F740H                          | 1              | U1DLL | UART 1 Divisor Latch (Low Byte, R/W)       |  |  |
| FFFF F744H                          | 1              | U1DLH | UART 1 Divisor Latch (High Byte, R/W)      |  |  |
| FFFF F760H                          | Х              | n/a   | Reserved                                   |  |  |
| FFFF F764H                          | Х              | U1FOR | UART 1 FIFO Occupancy Register (R/W)       |  |  |
| FFFF F768H                          | Х              | U1ABR | UART 1 Autobaud Control Register (R/W)     |  |  |
| FFFF F76CH                          | X              | U1ACR | UART 1 Autobaud Count Register (read only) |  |  |
| FFFF F770H<br>through<br>FFFF F77FH | х              | n/a   | Reserved                                   |  |  |



### 11.4.1 UART x Receive Buffer Register

In non-FIFO mode, this register holds the character(s) received by the UART Receive Shift register. When it receives fewer than eight bits, the bits are right-justified and the leading bits are zeroed. Reading the register empties the register and resets the *data ready (DR)* bit in the Line Status register to 0. Other (error) bits in the Line Status register are not cleared. In FIFO mode, this register latches the value of the data byte(s) at the bottom of the FIFO.

When the UART is in eight-bit Peripheral Bus mode, the 24 most significant bits must be ignored and not used. Reading these bits returns unpredictable results.

#### Table 299. UART x Receive Buffer Register - (UxRBR)



594 October, 2003 **Document Number: 273942-002** 



### 11.4.2 UART x Transmit Holding Register

This register holds the next data byte(s) to be transmitted. When the Transmit Shift register becomes empty, the contents of the Transmit Holding register are loaded into the Shift register and the *Transmit Data Request (TDRQ)* bit in the Line Status register is set to one (see Table 303).

In FIFO mode, writing to THR puts data to the top of the FIFO. The data at the bottom of the FIFO is loaded to the Shift register when it is empty. In eight-bit Peripheral mode, the 24 most significant bits are ignored and is not transmitted.

### Table 300. UART x Transmit Holding Register - (UxTHR)





### 11.4.3 UART x Interrupt Enable Register

This register enables six types of interrupts which set a value in the Interrupt Identification register. Each of the six interrupt types can be disabled by clearing the appropriate bit of the IER register. Similarly, by setting the appropriate bits, selected interrupts can be enabled.

This register also has the control bits of the unit enable and NRZ coding enable. The use of bit 7 to bit 4 is different from the register definition of standard 16550.

**Note:** A global interrupt enable/disable exists in the Modem Control Register bit 3 (IE). After reset, this bit must be set or no interrupts occurs, regardless of the state of the IER bits. See Section 11.4.7, "UART x Modem Control Register" on page 603.

**Note:** Users need to program the GPIO registers before enabling the UART. See "GPIO Pin Multiplexing" on page 720.

Table 301. UART x Interrupt Enable Register - (UxIER)

| PCI IOP Attributes Attributes | 31 28 rv/rv/rv/rv/rv/rv/rv/na/na/na/na/na/na/na/na/na/na/na/na/na/ | 24 20 16 12 8 4 0  rv r                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Unit #<br>0<br>1              | FFFF F7                                                            | Attribute Legend: RW = Read/Write RV = Reserved RC = Read Clear PR = Preserved RS = Read Only NA = Not Accessible                                                                                                                                                                         |  |  |  |  |  |  |
| Bit                           | Default                                                            | Description                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 31:8                          | 00 0000h                                                           | Reserved                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 7                             | 02                                                                 | Preserved                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 6                             | 02                                                                 | UART Unit Enable (UUE): Controls UART operation and pin multiplexing with the GPIO. Refer to "GPIO Pin Multiplexing" on page 720 for details.  0 = the unit is disabled and the shared pins operate as GPIO signals.  1 = the unit is enabled and the shared pins operate as UART signals |  |  |  |  |  |  |
| 5                             | 02                                                                 | NRZ coding Enable (NRZE): 0 = NRZ coding disabled 1 = NRZ coding enabled                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 4                             | 02                                                                 | Receiver Time Out Interrupt Enable: (RTOIE)  0 = Receiver data Time out Interrupt disabled  1 = Receiver data Time out Interrupt enabled                                                                                                                                                  |  |  |  |  |  |  |
| 3                             | 02                                                                 | Modem Interrupt Enable (MIE):  0 = Modem Status interrupt disabled  1 = Modem Status interrupt enabled                                                                                                                                                                                    |  |  |  |  |  |  |
| 2                             | 02                                                                 | Receiver Line Status Interrupt Enable (RLSE):  0 = Receiver Line Status interrupt disabled  1 = Receiver Line Status interrupt enabled                                                                                                                                                    |  |  |  |  |  |  |
| 1                             | 02                                                                 | Transmit Data request Interrupt Enable (TIE):  0 = Transmit FIFO Data Request interrupt disabled  1 = Transmit FIFO Data Request interrupt enabled                                                                                                                                        |  |  |  |  |  |  |
| 0                             | 02                                                                 | Receiver Data Available Interrupt Enable (RAVIE):  0 = Receiver Data Available (Trigger level reached) interrupt disabled  1 = Receiver Data Available (Trigger level reached) interrupt enabled                                                                                          |  |  |  |  |  |  |



### 11.4.4 UART x Interrupt Identification Register

The IIR register is read to determine the type and source of UART interrupts. To be 16550 compatible, the lower 4 bits (0-3) of the IIR register are priority encoded as shown in Table 303. When two or more interrupts represented by bits (0-3) occur, only the interrupt with the highest priority is displayed. The upper 4 bits, (4-7) are not priority encoded. These bits asserts/deasserts independently of the lower 4 bits.

Bit 0 (nIP) is used to indicate the existence of an interrupt in the priority encoded bits (0-3) of the IIR register. A low signal on this bit indicates an encoded interrupt is pending. When this bit is high, no encoded interrupt is pending, regardless of the state of the other 3 bits. IP# has no effect or association with the upper bits four bits (4-7) which assert/deassert independently of IP#.

In order to minimize software overhead during data character transfers, the UART prioritizes interrupts into four levels (listed in Table 303) and records these in the Interrupt Identification register. The Interrupt Identification register (IIR) stores information indicating that a prioritized interrupt is pending and the source of that interrupt.

Table 302. UART x Interrupt Identification Register - (UxIIR)

| PCI IOP Attributes Attributes | 31 28                                                                               | 24 20 16 12 8 4 0  TV T                                                                                                                                      |  |  |  |  |  |
|-------------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Unit #                        |                                                                                     | Scale <sup>™</sup> Core internal bus address Attribute Legend: RW = Read/Write RV = Reserved RC = Read Clear                                                                                     |  |  |  |  |  |
| 0                             |                                                                                     | 708H (DLAB=x)  PR = Preserved  RO = Read Orley  RS = Read/Set  NA = Not Accessible                                                                                                               |  |  |  |  |  |
| Bit                           | Default                                                                             | Description                                                                                                                                                                                      |  |  |  |  |  |
| 31:8                          | 00 0000h                                                                            | Reserved                                                                                                                                                                                         |  |  |  |  |  |
| 7:6                           | 002                                                                                 | FIFO Mode Enable Status (FIFOES[1:0]):  00 = Non-FIFO mode is selected  01 = Reserved  10 = Reserved  11 = FIFO mode is selected (TRFIFOE = 1)                                                   |  |  |  |  |  |
| 5                             | 02                                                                                  | Reserved                                                                                                                                                                                         |  |  |  |  |  |
| 4                             | 02                                                                                  | Autobaud Lock (ABL)  0 = Autobaud circuitry has not programmed Divisor Latch registers (DLL/DLH)  1 = Divisor Latch registers (DLL/DLH) programmed by autobaud circuitry                         |  |  |  |  |  |
|                               |                                                                                     | Time Out Detected (TOD):                                                                                                                                                                         |  |  |  |  |  |
| 3                             | 02                                                                                  | 0 = No time out interrupt is pending<br>1 = Time out interrupt is pending. (FIFO mode only)                                                                                                      |  |  |  |  |  |
|                               |                                                                                     | Interrupt Source Encoded (IID[1:0]): indicates a Modem Status Interrupt when the IP# bit is low. When IP# bit is high, there is no Interrupt.                                                    |  |  |  |  |  |
| 2:1                           | 02                                                                                  | 00 = Modem Status (CTS, DSR, RI, DCD modem signals changed state) 01 = Transmit FIFO requests data 10 = Received Data Available 11 = Receive error (Overrun, parity, framing, break, FIFO error) |  |  |  |  |  |
|                               |                                                                                     | Interrupt Pending (IP#):                                                                                                                                                                         |  |  |  |  |  |
| 0                             | 0 1 <sub>2</sub> 0 = Interrupt is pending. (Active low) 1 = No interrupt is pending |                                                                                                                                                                                                  |  |  |  |  |  |



Table 303. Interrupt Identification Register Decode

|         | Interrupt ID bits                   |   |   |                             |                                                   | Interrupt SET/RESET Function        |                                                                                                       |                                                                                                                         |  |
|---------|-------------------------------------|---|---|-----------------------------|---------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|
|         | 3                                   | 2 | 1 | 0                           | Priority                                          | Туре                                | Source                                                                                                | RESET Control                                                                                                           |  |
| IP#     | 0                                   | 0 | 0 | 1                           | -                                                 | None                                | No Interrupt is pending.                                                                              | -                                                                                                                       |  |
| IID[11] | 0                                   | 1 | 1 | 0                           | Highest                                           | Receiver Line<br>Status             | Overrun Error, Parity Error,<br>Framing Error, Break<br>Interrupt.                                    | Reading the Line Status<br>Register.                                                                                    |  |
|         |                                     |   |   |                             |                                                   |                                     | Non-FIFO mode: Receive<br>Buffer is full.                                                             | Non-FIFO mode: Reading the Receiver Buffer Register.                                                                    |  |
| IID[10] | IID[10] 0                           | 1 | 0 | 0                           | Second<br>Highest                                 | Received Data<br>Available.         | FIFO mode: Trigger level was reached.                                                                 | FIFO mode: Reading bytes until<br>Receiver FIFO drops below<br>trigger level or setting<br>RESETRF bit in FCR register. |  |
| TOD     | 1                                   | 1 | 0 | 0                           | Second<br>Highest                                 | Character<br>Timeout<br>indication. | FIFO Mode only: At least 1 character is in receiver FIFO and there was no activity for a time period. | Reading the Receiver FIFO or setting RESETRF bit in FCR register.                                                       |  |
| IID[01] | 0                                   | 0 | 1 | 0                           | Third                                             |                                     | Non-FIFO mode: Transmit<br>Holding Register Empty                                                     | Reading the IIR Register (when the source of the interrupt) or writing into the Transmit Holding Register.              |  |
|         |                                     |   |   |                             | Highest                                           | Data Request                        | FIFO mode: Transmit FIFO has half or less than half data.                                             | Reading the IIR Register (when the source of the interrupt) or writing to the Transmitter FIFO.                         |  |
| IID[00] | 0                                   | 0 | 0 | 0                           | Fourth<br>Highest                                 | Modem Status                        | Clear to Send, Data Set<br>Ready, Ring Indicator,<br>Received Line Signal Detect                      | Reading the Modem Status<br>Register.                                                                                   |  |
|         |                                     |   |   |                             |                                                   | Non Prioritiz                       | ed Interrupts                                                                                         |                                                                                                                         |  |
| ABL     | ABL 4 None Autobaud Lock Indication |   |   | Autobaud Lock<br>Indication | Autobaud circuitry has locked onto the baud rate. | Reading the IIR Register            |                                                                                                       |                                                                                                                         |  |

598 October, 2003 **Document Number: 273942-002** 



### 11.4.5 UART x FIFO Control Register

FCR is a write only register that is located at the same address as the IIR (IIR is a read only register). FCR enables/disables the transmitter/receiver FIFOs, clears the transmitter/receiver FIFOs, and sets the receiver FIFO trigger level.

#### Table 304. UART x FIFO Control Register - (UxFCR) (Sheet 1 of 2)





#### Table 304. UART x FIFO Control Register - (UxFCR) (Sheet 2 of 2)



600 October, 2003 **Document Number: 273942-002** 



### 11.4.6 UART x Line Control Register

In the Line Control Register, the system programmer specifies the format of the asynchronous data communications exchange. The serial data format consists of a start bit (logic 0), five to eight data bits, an optional parity bit, and one or two stop bits (logic 1). The LCR has bits for accessing the Divisor Latch registers and causing a Break condition. The programmer can also read the contents of the Line Control Register. The read capability simplifies system programming and eliminates the need for separate storage in system memory.

Table 305. UART x Line Control Register - (UxLCR) (Sheet 1 of 2)





#### Table 305. UART x Line Control Register - (UxLCR) (Sheet 2 of 2)





### 11.4.7 UART x Modem Control Register

This register controls the interface with the modem or data set (or a peripheral device emulating a modem). The contents of the Modem Control register are described below:

Table 306. UART x Modem Control Register - (UxMCR) (Sheet 1 of 2)





#### Table 306. UART x Modem Control Register - (UxMCR) (Sheet 2 of 2)



604 October, 2003 **Document Number: 273942-002** 



### 11.4.8 UART x Line Status Register

This register provides status information to the processor concerning the data transfers. Bits 5 and 6 show information about the transmitter section. The remainder of the bits contain information about the receiver.

In non-FIFO mode, three of the LSR register bits, parity error, framing error, and break interrupt, show the error status of the character that has just been received. In FIFO mode, these three status bits are stored with each received character in the FIFO. LSR shows the status bits of the character at the bottom of the FIFO. When the character at the bottom of the FIFO has errors, the LSR error bits are set and are not cleared until software reads LSR, even when the character in the FIFO is read and a new character is now at the bottom of the FIFO.

Bits 1 through 4 are the error conditions that produce a Receiver Line Status Interrupt when any of the corresponding conditions are detected and the interrupt is enabled. These bits are not cleared by reading the erroneous byte from the FIFO or receive buffer. They are cleared only by reading LSR. In FIFO mode, the Line Status Interrupt occurs only when the erroneous byte is at the bottom of the FIFO. When the erroneous byte being received is not at the bottom of the FIFO, an interrupt is generated only after the previous bytes are read and the erroneous byte is moved to the bottom of the FIFO.

#### Table 307. UART x Line Status Register - (UxLSR) (Sheet 1 of 3)

| PCI IOP Attributes Attributes | 31 28                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 24 20 16 rv r                                                                                                                      | 12 8                               | 4 0 ro/ro/ro/ro/ro/ro/ro/ro/na/na/na/na/na/na/na/na/na/na/na/na/na/ |  |  |  |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|---------------------------------------------------------------------|--|--|--|
| Unit #                        | Intel <sup>®</sup> X                                                                                                                                                                                                                                                                                                                                                                                                                                        | Scale <sup>™</sup> Core internal bus address                                                                                                                           | Attribute Legend:<br>RV = Reserved | RW = Read/Write<br>RC = Read Clear                                  |  |  |  |
| 0                             | FFFF F7                                                                                                                                                                                                                                                                                                                                                                                                                                                     | '14H (DLAB=x)                                                                                                                                                          | PR = Preserved                     | RO = Read Only                                                      |  |  |  |
| 1                             | FFFF F7                                                                                                                                                                                                                                                                                                                                                                                                                                                     | '54H (DLAB=x)                                                                                                                                                          | RS = Read/Set                      | NA = Not Accessible                                                 |  |  |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                        | NO = Nead/oct                      | TVA = TVOT ACCCSSIDIC                                               |  |  |  |
| Bit                           | Default                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                        | Description                        |                                                                     |  |  |  |
| 31:8                          | 00 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reserved                                                                                                                                                               |                                    |                                                                     |  |  |  |
| 7                             | FIFO Error Status (FIFOE): In non-FIFO mode, this bit is clear (0). In FIFO Mode this bit is set (1) when there is at least one parity error, framing error, or break indication for any of the characters in the FIFO. A processor read to the Line Statu register does not reset this bit. FIFOE is reset when all error bytes have been read from the FIFO. FIFOE being set to 1 does NOT generate an interrupt.  0 = No errors exit in the receive FIFO |                                                                                                                                                                        |                                    |                                                                     |  |  |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 = At least one character in receiv                                                                                                                                   |                                    |                                                                     |  |  |  |
| 6                             | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Transmitter Empty (TEMT): Set (1 Transmitter Shift register are both e Transmit Holding register or the Tra In FIFO mode, TEMT is set to 1 wh register are both empty. | mpty. It is reset to zero (        | (0) when either the ontains a data character.                       |  |  |  |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 = There is data in the Transmit S<br>FIFO<br>1 = All the data in the transmitter h                                                                                   | ,                                  | it Holding register, or the                                         |  |  |  |



#### Table 307. UART x Line Status Register - (UxLSR) (Sheet 2 of 3)





#### Table 307. UART x Line Status Register - (UxLSR) (Sheet 3 of 3)





### 11.4.9 UART x Modem Status Register

This register provides the current state of the control lines from the modem or data set (or a peripheral device emulating a modem). In addition to this current state information, the Modem Status register also provides change information. The change bit is set to a logic 1 when the control input from the Modem changes state. The change bit is reset to a logic 0 when the processor reads the Modem Status register.

*Note:* When the change bit (bit 0) is set to logic 1, a Modem Status interrupt is generated when bit 3 of the Interrupt Enable Register is set.

### Table 308. UART x Modem Status Register - (UxMSR)



608 October, 2003 **Document Number: 273942-002** 



## 11.4.10 UART x Scratchpad Register

This read/write register has no effect on the UART. It is intended as a scratchpad register for use by programmers.

### Table 309. UART x Scratchpad Register - (UxSCR)





## 11.4.11 Divisor Latch Registers

The description of use for the Divisor Latch Registers are provided in Section 11.3.5, Auto-Baud-Rate Detection and Section 11.3.6, Manual Baud Rate Selection. Refer to those sections for details on how to program these registers.

Bit DLAB in the LCR register must be set high before the Divisor Latch registers can be accessed.

A Divisor value of 0 in the Divisor Latch Register is not allowed. A value of 0 has the affect of disabling the UART. The reset value of the divisor is 02.

#### Table 310. UART x Divisor Latch Low Register - (UxDLL)



#### Table 311. UART x Divisor Latch High Register - (UxDLH)



610 October, 2003 **Document Number: 273942-002** 



### 11.4.12 UART x FIFO Occupancy Register

This register shows the number of bytes currently remaining the Receive FIFO. It can be used by the processor to determine the number of trailing bytes to remove from the receive FIFO when the Character Time-out Interrupt is detected. Refer to Section 11.3.2, "Removing Trailing Bytes In Interrupt Mode" on page 588. The FOR register is incremented once for each byte of data written to the Receive FIFO and decremented once for each byte read.

### Table 312. UART x FIFO Occupancy Register - (UxFOR)





### 11.4.13 UART x Auto-Baud Control Register

This read/write register has no effect on the UART. It is intended as a scratchpad register for use by programmers.

#### Table 313. UART x Auto-Baud Control Register - (UxABR)





# 11.4.14 UART x Auto-Baud Count Register

The Auto-Baud Count register stores the number of 33.334 MHZ clock cycles within a *start* bit pulse. This value is then used by the processor or auto-baud circuitry within the UART to calculate the baud rate. When Auto-Baud mode and Auto-Baud Interrupts are enabled, the UART interrupt the processor with the Auto-Baud Lock Interrupt after it has written the count value into the ACR. The value is written regardless of the state of the *auto-baud UART program* bit.

#### Table 314. UART x Auto-Baud Count Register - (UxACR)





# This Page Intentionally Left Blank



# Intel® 80331 I/O Processor Arbitration Unit

This chapter describes the components comprising the Intel<sup>®</sup> 80331 I/O processor (80331) arbitration, including one Internal Bus Arbiter, one PCI Selector, and two Multi-Transaction Timers. The operation modes, setup, and implementation of these components are described in this chapter.

#### 12.1 Arbitration Overview

The 80331 interfaces to one PCI bus and contains an internal PCI-like bus. Therefore, there are two buses which need an arbitration mechanism. Figure 107 illustrates all the potential bus initiators and which arbitration components are responsible for them.

Figure 107. Intel<sup>®</sup> 80331 I/O Processor Arbitration Block Diagram



The four components which comprise 80331 arbitration are:

- Internal Bus Arbitrator (Section 12.2, "Internal Bus Arbitra Overview" on page 616) Arbitrates between multiple initiators. The arbitration scheme is a round-robin with priority/promotion capabilities. The 80331 requires one PCI arbiter: the Internal Bus Arbiter.
  - Internal Bus Arbiter (IARB) arbitrates between six potential internal bus initiators (ATU, two DMA Channels, Application Accelerator, the PBI, and the Bus Interface Unit for the core).
- Multi-Transaction Timer (Section 12.4.2, "Multi-Transaction Timer Register 1 MTTR1" on page 625Section 12.4.3, "Multi-Transaction Timer Register 2 MTTR2" on page 626) Two muti-transaction timers (MTTR[2:1]) control the arbitration control for the internal bus initiators. The MTTRs counts internal bus cycles, an initiator uses across back-to-back transactions. The arbiter continues to assert GNT# to current initiator until the respective MTTR expires, or the initiator deasserts its REQ#. The 80331 implements one MTTR for the internal Intel<sup>®</sup> XScale<sup>TM</sup> core Bus Interface Unit and one for all peripheral initiators on the internal bus.
- Arbitration Configuration Registers (Section 12.4, "Register Definitions" on page 623) Priority and latency timer values for arbitration mechanism are programmable, as defined in Arbitration Configuration Registers.



#### 12.2 Internal Bus Arbiter Overview

The *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0 requires a central arbitration resource for each PCI bus within a system environment. This section details the operation of the Internal Bus Arbiter block.

The Internal Bus Arbiter supports:

- Three priority levels for each bus initiator
- A "fairness" algorithm which ensures that each potential bus initiator is granted access to the PCI bus independent of other requests
- Hidden, access-based arbitration

PCI uses the concept of access-based arbitration rather than the traditional time slot approach. When a bus initiator requires the PCI bus for a transaction, the device requests the arbitration logic for the PCI bus. PCI arbitration consists of a simple **REQ**# and GNT# handshake protocol. When a device requires the Internal Bus, it asserts its **REQ**# output. The arbitration unit allows the requesting agent access to the bus by asserting that agent's GNT# input.

PCI arbitration is a hidden arbitration scheme where the arbitration sequence occurs in the background while another bus initiator may currently control the bus. Hidden arbitration has the advantage of not consuming any bus bandwidth for arbitration overhead.

The arbiter is required by the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0 to implement a "fair" arbitration algorithm. The Internal Bus Arbiter's algorithm guarantees there is only one GNT# active on the Internal bus at any one time.

616 October, 2003 **Document Number: 273942-002** 



# 12.2.1 Theory of Operation

The arbiter's behavior is fully compliant with the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0.

#### 12.2.1.1 Priority Mechanism

The Internal Bus Arbiter supports six bus initiators on the Internal Bus. Each request can be programmed to one of three priority levels or be disabled. Application software programs the Internal Arbiter Control Register (IACR) to set the initial priority for each bus initiator. The arbiter promotes the bus initiator priority levels using a round-robin scheme.

Figure 108 is an example showing the three priority levels and the reserved slots for the promoted requester.

#### Figure 108. Arbitration Example



In Figure 108, the bus initiators are initially programmed to the priorities shown in Table 315. The IACR defines the initial priority levels for the IARB.



Table 322 shows the 2-bit values that correspond to each priority level. A priority level of  $11_2$  effectively disables the associated device by removing it from the arbitration sequence. A device programmed with a  $11_2$  priority does not receive a grant to gain access to the bus.

#### **Table 315.** Priority Programming Example

| Bus Initiator                                     | Programmed Priority        |
|---------------------------------------------------|----------------------------|
| Intel <sup>®</sup> XScale <sup>™</sup> core (BIU) | High - 00 <sub>2</sub>     |
| Memory Controller Unit                            | High - 00 <sub>2</sub>     |
| DMA Channel 0                                     | Medium - 01 <sub>2</sub>   |
| ATU                                               | Medium - 01 <sub>2</sub>   |
| Application Accelerator                           | Low - 10 <sub>2</sub>      |
| DMA Channel 1                                     | Disabled - 11 <sub>2</sub> |

The priority of the individual bus initiator determines the level to which the device is placed in the round-robin scheme. The programmed priority determines the starting priority or the lowest priority the device is. When the application programs the device for low priority, the device may be promoted up to medium and then high priority until it is granted the Internal Bus. Once the IARB grants the bus and the device asserts FRAME#, the device is reset to its initially programmed priority.

**Note:** When a low priority initiator requests the bus, with no other higher priority agent requesting the bus, that initiator is granted the bus the following clock. The promotion mechanism does not consume bus cycles.

The round-robin arbitration scheme supports three levels of round-robin arbitration: low, medium, and high priority. Using a round-robin mechanism ensures there is a winner for each priority level. To enforce the concept of fairness, a slot is reserved for the winner of each priority level (except the highest) in the next higher priority level. When the winner of a priority level is not granted the bus during that particular arbitration sequence, it is promoted to the next higher level of priority.

#### 12.2.1.2 Priority Example with Three Bus Initiators

Table 316 illustrates an example of bus arbitration with three bus initiators:

Table 316. Bus Arbitration Example – Three Bus Initiators

| Priority | Initial |   | Winning Bus Initiator |   |   |   |   |   |   |  |  |  |  |  |  |  |
|----------|---------|---|-----------------------|---|---|---|---|---|---|--|--|--|--|--|--|--|
| Level    | State   | Α | В                     | Α | С | Α | В | Α | С |  |  |  |  |  |  |  |
| High     | Α       | В | Α                     | С | А | В | Α | С | Α |  |  |  |  |  |  |  |
| Medium   | В       | С | С                     | В | В | _ | С | В | В |  |  |  |  |  |  |  |
| Low      | С       | _ | _                     | _ | - | С | _ | - | _ |  |  |  |  |  |  |  |

**NOTE:** In this example, all bus initiators are continually requesting the bus.

Each of the bus initiators (A, B, and C) are constantly requesting the bus and each is at a different priority level. The top row of Table 316 lists the current bus initiator/winner of the highest priority group. The three rows labelled as high, medium and low represent the actual priority levels that devices are currently at based on either their initial programmed priority or promotion through the levels. For example, device C starts out at low priority. Because it is the only device at this priority, it is the winner at low priority and is promoted to medium priority. Later, it wins at the medium priority level (against device B) and is promoted to high priority where it wins the level (against device A) and the bus. Device C is then put back at its programmed priority of low and starts the cycle over.

Continuing with Table 316, the winning bus initiator pattern would follow as:

ABACABACABACABAC



#### 12.2.1.3 Priority Example with Six Bus Initiators

Table 317 illustrates an example of bus arbitration with six bus initiators:

#### Table 317. Bus Arbitration Example – Six Bus Initiators

| Priority | Initial |    |    |    | Winni | ng Bus In | itiator |     |     |     |
|----------|---------|----|----|----|-------|-----------|---------|-----|-----|-----|
| Level    | State   | Α  | В  | С  | Α     | В         | D       | А   | В   | E   |
| High     | AB      | BC | AC | AB | BD    | AD        | AB      | BE  | AE  | AB  |
| Medium   | CD      | DE | DE | DE | CE    | CE        | CE      | CDF | CDF | CDF |
| Low      | EF      | F  | F  | F  | F     | F         | F       | -   | -   | -   |

NOTE: In this example, all bus initiators are continually requesting the bus.

Each of the six bus initiators (A through F) are constantly requesting the bus. There are two initiators programmed at each priority level. The top row of Table 317 lists the current bus initiator/winner of the highest priority group. The three rows labelled as high, medium and low represent the actual priority levels that devices are currently at based on either their initial programmed priority or promotion through the levels.

Continuing with Table 317, the winning bus initiator pattern would follow as:

ABCABDABFABCABDABEABCABDABF



#### 12.2.1.4 Arbitration Signalling Protocol

The Internal Bus Arbiter interfaces to all requesting agents on the bus through the **REQ**#/GNT# handshaking protocol. A bus initiator asserts its **REQ**# to request ownership of the Internal Bus. When the arbiter determines an agent may use the bus, it asserts the agent GNT# input. Agents must only assert **REQ**# to signal a true need for the bus and not to *reserve* the bus. Figure 109 illustrates arbitration between initiators of equal priority. This Internal Bus Arbiter only operates in the PCI-X mode as defined in *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0.

Figure 109. Arbitration Between Three Initiators



An agent can be granted the bus while a previous bus owner still has control of the Internal Bus (hidden arbitration). The arbiter is responsible for deciding which device is granted the bus next while each initiator is responsible for determining when the bus actually becomes free and is allowed to initiate its transaction by asserting FRAME#.

*PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0 states an initiator may deassert its **REQ**# pin before the arbiter grants the Internal bus to that initiator. When an initiator deasserts its **REQ**# pin, the Internal Bus Arbiter re-arbitrates, giving bus ownership to the next initiator based on priority algorithm defined in Section 12.2.1.1, "Priority Mechanism" on page 617.

# Note: The Internal Bus Arbiter arbitrates the Internal Bus by checking REQ[8:0]# on every cycle independent of any transactions on the bus.

The Internal Bus Arbiter may deassert an agent's GNT# on any clock. An agent must ensure its GNT# is asserted two clocks prior to the clock edge where it initiates a transaction by asserting FRAME#. When GNT# is deasserted, the transaction may not proceed.



By monitoring **REQ[8:0]**#, the arbiter can control the arbitration algorithm described in Section 12.2.1.1, "Priority Mechanism" on page 617. The arbiter asserts GNT# two clocks after **REQ**# is asserted when the agent has won the bus. An example arbitration flow is:

#### Table 318. Arbitration Flow

| Cycle | Event                                                                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | The arbiter is currently driving Initiator_As GNT#. The arbitration flow is independent of whether or not Initiator_A is involved with a transaction. For example, the Internal Bus could be parked with Initiator_A.                      |
| 1     | Initiator_B asserts its <b>REQ#</b> for PCI bus ownership. The arbitration logic calculates that Initiator_B has a higher priority than Initiator_A.                                                                                       |
| 3     | The arbiter deasserts GNT# for Initiator_A since Initiator_B is higher priority.                                                                                                                                                           |
| 4     | The arbiter asserts GNT# for Initiator_B.                                                                                                                                                                                                  |
| 7     | When Initiator_B drives FRAME#, any of the priority winners that were not granted the bus are promoted to a higher priority level when the reserved promotion slot is unoccupied (see Section 12.2.1.1, "Priority Mechanism" on page 617). |

#### 12.2.1.5 Internal Bus Arbitration Parking

Arbitration parking occurs when the arbiter asserts GNT# to a selected Internal Bus agent and no agent is currently using or requesting the bus.

Upon reset, the IARB parks the internal bus with the Intel<sup>®</sup> XScale<sup>TM</sup> core Bus Interface Unit (BIU). After an initiator requests, and is granted the bus, the arbiter parks the bus with that initiator. In other words, the last initiator that was granted the bus is responsible for parking.

When the Internal Bus is parked during an idle state, the parked agent loses the bus when the arbiter asserts another agent's GNT#. The parked agent relinquishes the bus and stops driving the address and command signals in one clock. When the arbiter deasserts an agent's GNT# on clock N-2, the agent can still initiate a normal bus transaction by driving FRAME# during clock N.



# 12.2.2 Intel<sup>®</sup> XScale<sup>™</sup> Core Arbitration

The Intel<sup>®</sup> XScale<sup>™</sup> core has an inherently small burst size. For this reason, a busy internal bus could inhibit data traffic for the core. To address this issue, the IARB implements a Multi-Transaction Timer (MTT1) which allocates a minimum timeslice where the Intel<sup>®</sup> XScale<sup>™</sup> core BIU can request the IARB to keep the core processor's GNT# asserted potentially across multiple Internal Bus transactions. Refer to Section 12.2.2.1, "Multi-Transaction Timers" on page 622 for details.

#### 12.2.2.1 Multi-Transaction Timers

The Internal Arbiter incorporates two Multi-Transaction Timers (MTT1 and MTT2) allowing the BIU or the other internal bus agents a guaranteed time-slice before losing arbitration to another internal bus agent. PCI is a transaction based protocol. In a system with long bursting agents, an agent such as the BIU with a small burst size could get starved.

The MTT overcomes these potential bottlenecks by guaranteeing a programmed timeslice with which the BIU (MTTR1) or other internal bus agents (MTTR2) are granted the internal bus. For example, once the IARB grants the internal bus to the BIU and the BIU initially asserts **I\_FRAME**#, MTT1 is loaded with the value programmed in the Multi-Transaction Timer Register 1 (MTTR1) and begins to decrement. The arbiter does not remove the BIU grant unless:

- BIU no longer requests bus by deasserting core processor REQ#.
- BIU continues to drive core processor **REQ#** and MTT expires.

**Note:** Even when a higher-priority initiator requests the internal bus, the arbiter does not deassert the BIU grant unless either of the above conditions occur.

Figure 110 illustrates an example of how the BIU uses MTT1 for efficient back-to-back transactions. For this example, the MTTR1 is programmed for 13 cycles.

Figure 110. Intel<sup>®</sup> XScale<sup>™</sup> Core Back-to-Back Transactions with MTT1 Enabled



*Note:* Multi-Transaction Timers keep track of the maximum time that an internal bus agent may continue to initiate new transactions on the internal bus per arbitration cycle. The MTT governs the internal arbiter.

Warning: When the MTTRx are programmed with zero, the MTTx are effectively disabled. However, this is not recommended to avoid potential resource lock out conditions on the internal bus; this is due to the one-deep transaction queue of the MCU. The minimum (default) value for MTT1 is recommended to be 98H (152 clocks) and the minimum (default) value for MTT2 is recommended to be 38H (56 clocks).



# 12.3 Reset Conditions

Table 319 shows all the arbitration blocks and the signal responsible for resetting its logic:

#### Table 319. Arbitration Reset

| Arbitration Block         | Reset With |
|---------------------------|------------|
| Internal Arbiter (IARB)   | I_RST#     |
| Multi-Transaction Timer 1 | I_RST#     |
| Multi-Transaction Timer 2 | I_RST#     |

**I\_RST#** moves all the internal agents to their programmed priority levels and starts the round robin arbitration sequence on the lowest number device at each priority level.

# 12.4 Register Definitions

Table 320 lists the Arbitration configuration registers which are detailed further in proceeding sections.

#### Table 320. Arbiter Register

| Section, Register Name - Acronym (Page)                                    |
|----------------------------------------------------------------------------|
| Section 12.4.1, "Internal Arbitration Control Register - IACR" on page 624 |
| Section 12.4.2, "Multi-Transaction Timer Register 1 - MTTR1" on page 625   |
| Section 12.4.3, "Multi-Transaction Timer Register 2 - MTTR2" on page 626   |



# 12.4.1 Internal Arbitration Control Register - IACR

The Internal Arbitration Control Register (IACR) sets the arbitration priority of each device that uses the internal bus. This register is part of the local arbitration configuration register space and is accessible from the 80331 core.

Table 321. Internal Arbitration Control Register - IACR



Each device is given a 2-bit priority shown in Table 322. The default values for the IACR give all the internal bus initiators the highest priority.

**Table 322.** Programmed Priority Control

| 2-Bit Programmed Value | Priority Level  |
|------------------------|-----------------|
| 002                    | High Priority   |
| 012                    | Medium Priority |
| 102                    | Low Priority    |
| 112                    | Disabled        |

624 October, 2003 **Document Number: 273942-002** 



# 12.4.2 Multi-Transaction Timer Register 1 - MTTR1

The Multi-Transaction Timer Register 1 defines the duration with which the Intel<sup>®</sup> XScale<sup>™</sup> core Bus Interface Unit retains the core processor GNT# across back-to-back transactions. This is an 8-bit value allowing up to 255 dedicated internal bus cycles for as long as the core processor GNT# is asserted. A value of zero effectively disables the MTTR1. This register is part of the local arbitration configuration register space and is accessible from the 80331 core.

Table 323. Multi-Transaction Timer Register - MTTR1





# 12.4.3 Multi-Transaction Timer Register 2 - MTTR2

The Multi-Transaction Timer Register 2 defines the duration with which agents other than the Intel<sup>®</sup> XScale To core retains the core processor GNT# across back-to-back transactions. This is an 8-bit value allowing up to 255 dedicated internal bus cycles for as long as the core processor GNT# is asserted. A value of zero effectively disables the MTTR2. This register is part of the local arbitration configuration register space and is accessible from the 80331 core.

Table 324. Multi-Transaction Timer Register - MTTR2



626 October, 2003 **Document Number: 273942-002** 



# Intel<sup>®</sup> XScale<sup>™</sup> Core and Core Performance Monitoring

**13** 

This chapter describes the Intel<sup>®</sup> XScale<sup>™</sup> core (ARM\* architecture compliant) and its associated Performance Monitoring facilities within the Intel<sup>®</sup> 80331 I/O processor (80331). The events that are monitored can provide performance information for compiler writers, system application developers and software programmers.

# 13.1 High-Level Overview of Intel<sup>®</sup> XScale<sup>™</sup> Core

The second generation Intel<sup>®</sup> XScale<sup>™</sup> core is designed for high performance and low-power; leading the industry in mW/MIPs. Many of the architectural features added to the Intel<sup>®</sup> XScale<sup>™</sup> core help hide memory latency which often is a serious impediment to high performance processors. This includes:

- the ability to continue instruction execution even while the data cache is retrieving data from external memory.
- a write buffer.
- write-back caching.
- various data cache allocation policies which can be configured different for each application.
- · and cache locking.

All these features improve the efficiency of the external bus.

# 13.1.1 ARM Compatibility

ARM Version 5 (V5) Architecture added floating point instructions to ARM Version 4. The Intel<sup>®</sup> XScale<sup>™</sup> core implements the integer instruction set architecture of ARM V5, but does not provide hardware support of the floating point instructions. The Intel<sup>®</sup> XScale<sup>™</sup> core provides the Thumb instruction set (ARM V5T) and the ARM V5E DSP extensions. Backward compatibility with the first generation of Intel<sup>®</sup> StrongARM\* products is maintained for user-mode applications. Operating systems may require modifications to match the specific hardware features of the and to take advantage of the performance enhancements added to the second generation Intel<sup>®</sup> XScale<sup>™</sup> core.



#### 13.1.2 Features

Figure 111 shows the major functional blocks of the Intel<sup>®</sup>  $XScale^{TM}$  core. The following sections give a brief, high-level overview of these blocks.

Figure 111. The Intel<sup>®</sup> XScale<sup>™</sup> Core Architecture Features



#### 13.1.2.1 Multiply/ACcumulate (MAC)

The MAC unit supports early termination of multiplies/accumulates in two cycles and can sustain a throughput of a MAC operation every cycle. Several architectural enhancements were made to the MAC to support audio coding algorithms, which include a 40-bit accumulator and support for 16-bit packed data.

#### 13.1.2.2 Memory Management

The Intel<sup>®</sup> XScale<sup>™</sup> core implements the Memory Management Unit (MMU) Architecture specified in the *ARM Architecture Reference Manual*. The MMU provides access protection and virtual to physical address translation.

The MMU Architecture also specifies the caching policies for the instruction cache and data memory. These policies are specified as page attributes and include:

- identifying code as cacheable or non-cacheable
- selecting between the mini-data cache or data cache
- · write-back or write-through data caching
- enabling data write allocation policy
- and enabling the write buffer to coalesce stores to external memory



#### 13.1.2.3 Instruction Cache

The Intel<sup>®</sup> XScale<sup>™</sup> core implements a 32-Kbyte, 32-way set associative instruction cache with a line size of 32 bytes. All requests that "miss" the instruction cache generate a 32-byte read request to external memory. A mechanism to lock critical code within the cache is also provided.

#### 13.1.2.4 Branch Target Buffer

The Intel<sup>®</sup> XScale<sup>™</sup> core provides a Branch Target Buffer (BTB) to predict the outcome of branch type instructions. It provides storage for the target address of branch type instructions and predicts the next address to present to the instruction cache when the current instruction address is that of a branch.

The BTB holds 128 entries.

#### 13.1.2.5 Data Cache

The Intel<sup>®</sup> XScale<sup>™</sup> core implements a 32-Kbyte, a 32-way set associative data cache and a 2-Kbyte, 2-way set associative mini-data cache. Each cache has a line size of 32 bytes, supports write-through or write-back caching.

The data/mini-data cache is controlled by page attributes defined in the MMU Architecture and by coprocessor 15.

The  $Intel^{\textcircled{0}}$  XScale  $^{TM}$  core allows applications to re-configure a portion of the data cache as data RAM. Software may place special tables or frequently used variables in this RAM.



# 13.2 CP14 Registers

Table 325 lists the CP14 registers implemented in the I/O processor.

#### Table 325. CP14 Registers

| Register (CRn) | Access        | Description                      |
|----------------|---------------|----------------------------------|
| 0-3            | Read / Write  | Performance Monitoring Registers |
| 4-5            | Unpredictable | Reserved                         |
| 6              | Read Only     | Core Frequency                   |
| 7              | Unpredictable | Reserved                         |
| 8-15           | Read / Write  | Software Debug                   |

# 13.2.1 Registers 0-3: Performance Monitoring

The performance monitoring unit contains the following:

- Control Register (PMNC)
- Clock Counter (CCNT)
- Interrupt Enable Register (INTEN)
- Overflow Flag Register (FLAG)
- Event Selection Register (EVTSEL)
- Four Event Counters (PMN0 PMN3)

Opcode\_2 should be zero on all accesses.

These registers can not be accessed by  $\boldsymbol{LDC}$  and  $\boldsymbol{STC}$  coprocessor instructions.

Table 326. Accessing the Performance Monitoring Registers

| Description                                 | CRn Register# | CRm Register# | Instruction                                                         |
|---------------------------------------------|---------------|---------------|---------------------------------------------------------------------|
| (PMNC) Performance Monitor Control Register | 0b0000        | 0b0001        | Read: MRC p14, 0, Rd, c0, c1, 0<br>Write: MCR p14, 0, Rd, c0, c1, 0 |
| (CCNT) Clock Counter Register               | 0b0001        | 0b0001        | Read: MRC p14, 0, Rd, c1, c1, 0<br>Write: MCR p14, 0, Rd, c1, c1, 0 |
| (INTEN) Interrupt Enable Register           | 0b0100        | 0b0001        | Read: MRC p14, 0, Rd, c4, c1, 0<br>Write: MCR p14, 0, Rd, c4, c1, 0 |
| (FLAG) Overflow Flag Register               | 0b0101        | 0b0001        | Read: MRC p14, 0, Rd, c5, c1, 0<br>Write: MCR p14, 0, Rd, c5, c1, 0 |
| (EVTSEL) Event Selection Register           | 0b1000        | 0b0001        | Read: MRC p14, 0, Rd, c8, c1, 0<br>Write: MCR p14, 0, Rd, c8, c1, 0 |
| (PMN0) Performave Count Register 0          | 0b0000        | 0b0010        | Read: MRC p14, 0, Rd, c0, c2, 0<br>Write: MCR p14, 0, Rd, c0, c2, 0 |
| (PMN1) Performave Count Register 1          | 0b0001        | 0b0010        | Read: MRC p14, 0, Rd, c1, c2, 0<br>Write: MCR p14, 0, Rd, c1, c2, 0 |
| (PMN2) Performave Count Register 2          | 0b0010        | 0b0010        | Read: MRC p14, 0, Rd, c2, c2, 0<br>Write: MCR p14, 0, Rd, c2, c2, 0 |
| (PMN3) Performave Count Register 3          | 0b0011        | 0b0010        | Read: MRC p14, 0, Rd, c3, c2, 0<br>Write: MCR p14, 0, Rd, c3, c2, 0 |



# 13.2.2 Register 1: Clock Count Register -- CCNT

The format of CCNT is shown in Table 351. The clock counter is reset to '0' by Performance Monitor Control Register (PMNC) or can be set to a predetermined value by directly writing to it. When CCNT reaches its maximum value 0xFFFF,FFFF, the next clock cycle causes it to roll over to zero and set the overflow flag (bit 6) in PMNC. An IRQ or FIQ is reported when it is enabled via bit 6 in the PMNC register.

Table 327. Clock Count Register -- CCNT





# 13.2.3 Register 6: Core Clock Configuration Register -- CCLKCFG

Intel<sup>®</sup> XScale<sup>™</sup> core frequency can be determined by reading this register.

Opcode\_2 and CRm should be zero.

#### Table 328. Clock Count Register -- CCNT





# 13.2.4 Registers 8-15: Software Debug

Software debug is supported by address breakpoint registers (Coprocessor 15, register 14), serial communication over the JTAG interface and a trace buffer. Registers 8 and 9 are used for the serial interface and registers 10 through 13 support a 256 entry trace buffer. Register 14 and 15 are the debug link register and debug SPSR (saved program status register).

Opcode\_2 and CRm are zero.

#### Table 329. Accessing the Debug Registers

| Function                                           | CRn (Register #) | Instruction                                              |
|----------------------------------------------------|------------------|----------------------------------------------------------|
| Access Transmit Debug Register (TX)                | 0b1000           | MRC p14, 0, Rd, c8, c0, 0<br>MCR p14, 0, Rd, c8, c0, 0   |
| Access Receive Debug Register (RX)                 | 0b1001           | MCR p14, 0, Rd, c9, c0, 0<br>MRC p14, 0, Rd, c9, c0, 0   |
| Access Debug Control and Status Register (DBGCSR)  | 0b1010           | MCR p14, 0, Rd, c10, c0, 0<br>MRC p14, 0, Rd, c10, c0, 0 |
| Access Trace Buffer Register (TBREG)               | 0b1011           | MCR p14, 0, Rd, c11, c0, 0<br>MRC p14, 0, Rd, c11, c0, 0 |
| Access Checkpoint 0 Register (CHKPT0)              | 0b1100           | MCR p14, 0, Rd, c12, c0, 0<br>MRC p14, 0, Rd, c12, c0, 0 |
| Access Checkpoint 1 Register (CHKPT1)              | 0b1101           | MCR p14, 0, Rd, c13, c0, 0<br>MRC p14, 0, Rd, c13, c0, 0 |
| Access Transmit and Receive Debug Control Register | 0b1110           | MCR p14, 0, Rd, c14, c0, 0<br>MRC p14, 0, Rd, c14, c0, 0 |
| Debug Saved Program Status Register                | 0b1111           | MCR p14, 0, Rd, c15, c0, 0<br>MRC p14, 0, Rd, c15, c0, 0 |



# 13.3 CP15 Registers

Table 330 lists the CP15 registers implemented in the I/O processor.

#### Table 330. CP15 Registers

| Register (CRn) | Opcode_2 | Access                     | Description            |
|----------------|----------|----------------------------|------------------------|
| 0              | 0        | Read / Write-Ignored       | ID                     |
| 0              | 1        | Read / Write-Ignored       | Cache Type             |
| 1              | 0        | Read / Write               | Control                |
| 1              | 1        | Read / Write               | Auxiliary Control      |
| 2              | 0        | Read / Write               | Translation Table Base |
| 3              | 0        | Read / Write               | Domain Access Control  |
| 4              | -        | Unpredictable              | Reserved               |
| 5              | 0        | Read / Write               | Fault Status           |
| 6              | 0        | Read / Write               | Fault Address          |
| 7              | 0        | Read-unpredictable / Write | Cache Operations       |
| 8              | 0        | Read-unpredictable / Write | TLB Operations         |
| 9              | 0        | Read / Write               | Cache Lock Down        |
| 10             | 0        | Read / Write               | TLB Lock Down          |
| 11 - 12        | -        | Unpredictable              | Reserved               |
| 13             | 0        | Read / Write               | Process ID (PID)       |
| 14             | 0        | Read / Write               | Breakpoint Registers   |
| 15             | 0        | Read / Write               | (CRm = 1) CP Access    |

634 October, 2003 **Document Number: 273942-002** 



# 13.3.1 Register 0: ID and Cache Type Registers

Register 0 houses two read-only registers that are used for part identification: an ID register and a cache type register.

The ID Register is selected when  $opcode\_2=0$ . This register returns the code for the A0 stepping/revision. The low order four bits of the register are the chip revision number and is incremented for future steppings.F

#### Table 331. ID Register

| 31  | 30    | 29   | 28  | <b>27</b>                                  | 26                   | 25  | 24   | 23   | 22   | <b>21</b> | 20 | 19 | 18                  | 17                                                                                | 16                         | 15                                   | 14                              | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 12                            | 11                       | 10          | 9    | 8            | 7             | 6    | 5 | 4   | 3 | 2    | 1    | 0 |
|-----|-------|------|-----|--------------------------------------------|----------------------|-----|------|------|------|-----------|----|----|---------------------|-----------------------------------------------------------------------------------|----------------------------|--------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------|-------------|------|--------------|---------------|------|---|-----|---|------|------|---|
| 0   | 1     | 1    | 0   | 1                                          | 0                    | 0   | 1    | 0    | 0    | 0         | 0  | 0  | 1                   | 0                                                                                 | 1                          | 0                                    | 1                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                             | 0                        | 0           | 0    | 0            | 1             | X    | 0 | 1   | F | Revi | sion | 1 |
| res | set v | valu | ıe: | As                                         | Sho                  | own | 1    |      |      |           |    |    |                     |                                                                                   |                            |                                      |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               |                          |             |      |              |               |      |   |     |   |      |      |   |
|     | Ві    | its  |     |                                            | Access               |     |      |      |      |           |    |    |                     |                                                                                   |                            | cess Description                     |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               |                          |             |      |              |               |      |   |     |   |      |      |   |
|     | 31    | :24  |     | Re                                         | Read / Write Ignored |     |      |      |      |           |    |    |                     |                                                                                   |                            |                                      |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               |                          | ema<br>pora |      | n)           |               |      |   |     |   |      |      |   |
|     | 23    | :16  |     | Re                                         | ad /                 | / W | rite | Igno | orec | i         |    |    |                     |                                                                                   | Arc                        | chite                                | ectu                            | re v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ers                           | ion                      | = A         | RM   | * V          | ersi          | on t | 5 |     |   |      |      |   |
|     | 15    | 5:4  |     | Read / Write Ignored  Read / Write Ignored |                      |     |      |      |      |           |    |    | I/O<br>Bits<br>Bits | pro<br>s[15<br>s[11<br>s[7:                                                       | 5:12<br>:8]<br>:8]<br>4] u | ssor<br>] refe<br>refe<br>sed<br>3RG | er to<br>fer to<br>I for<br>S_E | to the the implication in the im | men<br>ne p<br>impolen<br>hig | roc<br>pler<br>nen<br>h) | ess<br>ner  | or g | gene<br>on : | erati<br>= 0x | 0    |   | )x4 |   |      |      |   |
|     | 3     | :0   |     | Read / Write Ignored                       |                      |     |      |      |      |           |    |    |                     | Revision number for the processor (Implementation Specified) A0 stepping = 0b0000 |                            |                                      |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                               |                          |             |      |              |               |      |   |     |   |      |      |   |

The Cache Type Register is selected when opcode\_2=1 and describes the present I/O processor cache.

#### Table 332. Cache Type Register

| 31 30 29 28  | 27 20                    | 6 25   | 24   | 23    | 22 2 <sup>,</sup> | l 20 | 19 | 18                                              | 17   | 16                                    | 15   | 14   | 13                    | 12    | 11   | 10    | 9    | 8     | 7    | 6   | 5    | 4   | 3      | 2  | 1 | 0 |
|--------------|--------------------------|--------|------|-------|-------------------|------|----|-------------------------------------------------|------|---------------------------------------|------|------|-----------------------|-------|------|-------|------|-------|------|-----|------|-----|--------|----|---|---|
| 0 0 0 0      | 1 (                      | 1      | 1    | 0     | 0 0               | 1    | 1  | 0                                               | 1    | 0                                     | 1    | 0    | 1                     | 0     | 0    | 0     | 0    | 1     | 1    | 0   | 1    | 0   | 1      | 0  | 1 | 0 |
| reset value: | As Sh                    | nown   | 1    |       |                   |      |    |                                                 |      |                                       |      |      |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| Bits         |                          |        |      | Ac    | cess              |      |    |                                                 |      |                                       |      |      |                       |       |      | L     | )es  | crip  | otio | n   |      |     |        |    |   |   |
| 31:29        | Read                     | l-as-Z | Zero | ) / W | rite I            | gnor | ed |                                                 |      | Res                                   | ser  | /ed  |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 28:25        | Read                     | l / Wr | rite | Igno  | red               |      |    |                                                 |      | The                                   | e ca | iche | ss =<br>es si<br>ent. | upp   | ort  | lock  |      |       |      |     |      |     |        |    |   |   |
| 24           | Read                     | l / Wr | rite | Igno  | red               |      |    |                                                 |      | Har                                   | rvar | d C  | ach                   | е     |      |       |      |       |      |     |      |     |        |    |   |   |
| 23:21        | Read                     | l-as-Z | Zero | ) / W | rite l            | gnor | ed |                                                 |      | Res                                   | ser  | /ed  |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 20:18        | Read                     | l / Wi | rite | Igno  | red               |      |    |                                                 |      | Data Cache Size = 0b110 = 32 kB       |      |      |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 17:15        | Read                     | l / Wi | rite | Igno  | red               |      |    |                                                 |      | Data cache associativity = 0b101 = 32 |      |      |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 14           | Read                     | l-as-z | Zero | ) / W | rite l            | gnor | ed |                                                 |      | Reserved                              |      |      |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 13:12        | Read                     | l / Wi | rite | Igno  | red               |      |    |                                                 |      | Dat                                   | a c  | ach  | e lir                 | ne le | eng  | th =  | 0b   | 10 :  | = 8  | wor | ds/l | ine |        |    |   |   |
| 11:9         | Read                     | l-as-z | Zero | ) / W | rite l            | gnor | ed |                                                 |      | Res                                   | ser  | /ed  |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 8:6          | Read / Write Ignored     |        |      |       |                   |      |    | Inst                                            | truc | tion                                  | ca   | che  | siz                   | e =   | 0b′  | 110   | = 3  | 2 kE  | 3    |     |      |     |        |    |   |   |
| 5:3          | 5:3 Read / Write Ignored |        |      |       |                   |      |    | Instruction cache associativity = 0b101 = 32 kB |      |                                       |      |      |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 2            | Read                     | l-as-Z | Zerc | ) / W | rite I            | gnor | ed |                                                 |      | Res                                   | ser  | /ed  |                       |       |      |       |      |       |      |     |      |     |        |    |   |   |
| 1:0          | Read                     | l / Wr | rite | Igno  | red               |      |    |                                                 |      | Inst                                  | truc | tion | ca                    | che   | line | e ler | ngth | า = ( | 0b1  | 0 = | 8 w  | ord | ls/lir | ne |   |   |



# 13.3.2 Register 1: Control and Auxiliary Control Registers

Register 1 is made up of two registers, one that is compliant with ARM Version 5 and is referenced by  $opcode\_2 = 0x0$ , and the other which is specific to Intel<sup>®</sup> XScale<sup>TM</sup> microarchitecture and is referenced by  $opcode\_2 = 0x1$ .

The Exception Vector Relocation bit (bit 13 of the ARM control register) allows the vectors to be mapped into high memory rather than their default location at address 0. This bit is readable and writable by software. When the MMU is enabled, the exception vectors are accessed via the usual translation method involving the PID register and the TLBs. To avoid automatic application of the PID to exception vector accesses, software may relocate the exceptions to high memory.

#### Table 333. ARM\* Control Register

| 31 30 29 28 | 8 27 26 25 24 23 22 21 20 19 18       | 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |
|-------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
|             |                                       | V I Z 0 R S B 1 1 1 1 C A M                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |
| reset value | : writeable bits set to 0             |                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |
| Bits        | Access                                | Description                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |
| 31:14       | Read-Unpredictable /<br>Write-as-Zero | Reserved                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 13          | Read / Write                          | Exception Vector Relocation (V).  0 = Base address of exception vectors is 0x0000,0000  1 = Base address of exception vectors is 0xFFFF,0000                                                              |  |  |  |  |  |  |  |  |  |  |
| 12          | Read / Write                          | Instruction Cache Enable/Disable (I)  0 = Disabled  1 = Enabled                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |
| 11          | Read / Write                          | Branch Target Buffer Enable (Z) 0 = Disabled 1 = Enabled                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 10          | Read-as-Zero / Write-as-Zero          | Reserved                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 9           | Read / Write                          | ROM Protection (R) This selects the access checks performed by the memory management unit. See the ARM Architecture Reference Manual - ARM Limited. Order number: ARM DDI 0100E. for more information.    |  |  |  |  |  |  |  |  |  |  |
| 8           | Read / Write                          | System Protection (S) This selects the access checks performed by the memory management unit. See the ARM Architecture Reference Manual - ARM Limited. Order number: ARM DDI 0100E. for more information. |  |  |  |  |  |  |  |  |  |  |
| 7           | Read / Write                          | Big/Little Endian (B)  0 = Little-endian operation  1 = Big-endian operation                                                                                                                              |  |  |  |  |  |  |  |  |  |  |
| 6:3         | Read-as-One / Write-as-One            | = 0b1111                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 2           | Read / Write                          | Data cache enable/disable (C)  0 = Disabled  1 = Enabled                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| 1           | Read / Write                          | Alignment fault enable/disable (A)  0 = Disabled  1 = Enabled                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |
| 0           | Read / Write                          | Memory management unit enable/disable (M)  0 = Disabled  1 = Enabled                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |

# Intel<sup>®</sup> 80331 I/O Processor Developer's Manual Intel<sup>®</sup> XScale<sup>™</sup> Core and Core Performance Monitoring

The mini-data cache attribute bits, in the I/O processor Control Register, are used to control the allocation policy for the mini-data cache and whether it uses write-back caching or write-through caching.

The configuration of the mini-data cache is setup before any data access is made that may be cached in the mini-data cache. Once data is cached, software must ensure that the mini-data cache has been cleaned and invalidated before the mini-data cache attributes can be changed.

#### Table 334. Auxiliary Control Register

| 31 30 29 2  | 28 27 26 25 24 23 22 21 20 19         | 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                    |
|-------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                       | MD P K                                                                                                                                                                                                            |
| reset value | e: writeable bits set to 0            |                                                                                                                                                                                                                   |
| Bits        | Access                                | Description                                                                                                                                                                                                       |
| 31:6        | Read-Unpredictable /<br>Write-as-Zero | Reserved                                                                                                                                                                                                          |
|             |                                       | Mini Data Cache Attributes (MD)                                                                                                                                                                                   |
| 5:4         | Read / Write                          | All configurations of the Mini-data cache are cacheable, stores are buffered in the write buffer and stores are coalesced in the write buffer as long as coalescing is globally enabled (bit 0 of this register). |
|             |                                       | 0b00 = Write back, Read allocate 0b01 = Write back, Read/Write allocate 0b10 = Write through, Read allocate 0b11 = Unpredictable                                                                                  |
| 3:2         | Read-Unpredictable /<br>Write-as-Zero | Reserved                                                                                                                                                                                                          |
|             |                                       | Page Table Memory Attribute (P)                                                                                                                                                                                   |
| 1           | Read / Write                          | When set, page table accesses are protected by ECC. See Section 11, "Bus Controller" on page 11-1 of the Intel® 80200 processor based on Intel® XScale Microarchitecture Developer's Manual for more information. |
|             |                                       | Write Buffer Coalescing Disable (K)                                                                                                                                                                               |
| 0           | Read / Write                          | This bit globally disables the coalescing of all stores in the write buffer no matter what the value of the Cacheable and Bufferable bits are in the page table descriptors.                                      |
|             |                                       | 0 = Enabled<br>1 = Disabled                                                                                                                                                                                       |



# 13.3.3 Register 2: Translation Table Base Register

#### **Table 335.** Translation Table Base Register

| 31 30 29 28  | 27 26 25 24 23 22 21 20 19 18 17   | 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                              |
|--------------|------------------------------------|---------------------------------------------------------------------------------------|
|              | Translation Table Base             |                                                                                       |
| reset value: | unpredictable                      |                                                                                       |
| Bits         | Access                             | Description                                                                           |
| 31:14        | Read / Write                       | <b>Translation Table Base</b> - Physical address of the base of the first-level table |
| 13:0         | Read-unpredictable / Write-as-Zero | Reserved                                                                              |

# 13.3.4 Register 3: Domain Access Control Register

#### Table 336. Domain Access Control Register

| 31 30 | 29 28             | 27 26  | 25 24    | 23 22 | 21 20 | 19 18 | 17 16    | 15 14                                       | 13 12                    | 11 10   | 9 8      | 7 6          | 5 4     | 3 2    | 1 0 |
|-------|-------------------|--------|----------|-------|-------|-------|----------|---------------------------------------------|--------------------------|---------|----------|--------------|---------|--------|-----|
| D15   | D14               | D13    | D12      | D11   | D10   | D9    | D8       | D7                                          | D6                       | D5      | D4       | D3           | D2      | D1     | D0  |
| reset | value:            | unpred | lictable | •     |       |       |          |                                             |                          |         |          |              |         |        |     |
| Bi    | its               | Access |          |       |       |       |          |                                             |                          |         | Descrip  | tion         |         |        |     |
| 31    | 31:0 Read / Write |        |          |       |       |       | of<br>Re | ecess p<br>each fie<br>eference<br>DI 01001 | eld can<br>e <i>Manu</i> | be four | nd in th | e <i>ARM</i> | Archite | ecture | J   |

638 October, 2003 **Document Number: 273942-002** 



# 13.3.5 Register 5: Fault Status Register

The Fault Status Register (FSR) indicates which fault has occurred, which is either a prefetch abort or a data abort. Bit 10 extends the encoding of the status field for prefetch aborts and data aborts. Bit 9 indicates that a debug event occurred and the exact source of the event is found in the debug control and status register (CP14, register 10). When bit 9 is set, the domain and extended status field are undefined.

Upon entry into the prefetch abort or data abort handler, hardware updates this register with the source of the exception. Software is not required to clear these fields.

#### Table 337. Fault Status Register

| 31 30 29 28  | 27 26 25 24 23 22 21 20 19 18 17   | 16 15 14 13 12 11                                              | 10   | 9     | 8    | 7 6    | 5      | 4    | 3 2   | ! 1  | 0 |
|--------------|------------------------------------|----------------------------------------------------------------|------|-------|------|--------|--------|------|-------|------|---|
|              |                                    |                                                                | X    | D     | 0    | Do     | main   |      | S     | tatu | S |
| reset value: | unpredictable                      |                                                                |      |       |      |        |        |      |       |      |   |
| Bits         | Access                             |                                                                | D    | )es   | crip | tion   |        |      |       |      |   |
| 31:11        | Read-unpredictable / Write-as-Zero | Reserved                                                       |      |       |      |        |        |      |       |      |   |
|              |                                    | Status Field Extens                                            | sion | (X)   | )    |        |        |      |       |      |   |
| 10           | Read / Write                       | This bit is used to exwhen there is a prefeabort.              |      |       |      |        |        |      |       |      |   |
|              |                                    | Debug Event (D)                                                |      |       |      |        |        |      |       |      |   |
| 9            | Read / Write                       | This flag indicates a cause of the debug debug control registe | ever | nt is | fοι  | ınd in | the M  |      |       |      |   |
| 8            | Read-as-zero / Write-as-Zero       | = 0                                                            |      |       |      |        |        |      |       |      |   |
| 7:4          | Read / Write                       | Domain - Specifies accessed when a da                          |      |       |      |        |        | ns v | vas l | oein | g |
| 3:0          | Read / Write                       | Status - Type of data                                          | a ac | ces   | s b  | eing a | ittemp | ted  |       |      |   |

# 13.3.6 Register 6: Fault Address Register

#### Table 338. Fault Address Register

| 31  | 30 2  | 29  | 28  | <b>27</b> | 26   | 25   | 24   | 23 | 22  | 21 | 20 | 19 | 18  | 17   | 16   | 15   | 14  | 13  | 12 | 11 | 10   | 9  | 8    | 7   | 6 | 5 | 4    | 3     | 2  | 1  | 0 |
|-----|-------|-----|-----|-----------|------|------|------|----|-----|----|----|----|-----|------|------|------|-----|-----|----|----|------|----|------|-----|---|---|------|-------|----|----|---|
|     |       |     |     |           |      |      |      |    |     |    |    |    | Fau | lt V | irtu | al A | \dd | res | s  |    |      |    |      |     |   |   |      |       |    |    |   |
| res | set v | alu | ie: | unp       | rec  | lict | able | •  |     |    |    |    |     |      |      |      |     |     |    |    |      |    |      |     |   |   |      |       |    |    |   |
|     | Bit   | s   |     |           |      |      |      | Α  | ссе | ss |    |    |     |      |      |      |     |     |    |    |      | es | crip | tio | n |   |      |       |    |    |   |
|     | 31:   | 0   |     | Re        | ad , | / Wı | rite |    |     |    |    |    |     |      |      |      |     |     |    |    | ss - |    |      |     |   |   | A of | f the | da | ta |   |



### 13.3.7 Register 7: Cache Functions

All the functions defined in the first generation of  $Intel^{\textcircled{m}}$  XScale microarchitecture appear here. The I/O processor adds other functions as well. This register is accessed as write-only. Reads from this register, as with an MRC, have an undefined effect.

The Drain Write Buffer function not only drains the write buffer but also drains the fill buffer.

The I/O processor does not check permissions on addresses supplied for cache or TLB functions. Because only privileged software may execute these functions, full accessibility is assumed. Cache functions do not generate any of the following:

- · translation faults
- · domain faults
- permission faults

The invalidate instruction cache line command does not invalidate the BTB. When software invalidates a line from the instruction cache and modifies the same location in external memory, it needs to invalidate the BTB also. Not invalidating the BTB in this case may cause unpredictable results.

Disabling/enabling a cache has no effect on contents of the cache: valid data stays valid, locked items remain locked. All operations defined in Table 339 work regardless of whether the cache is enabled or disabled.

Since the Clean D Cache Line function reads from the data cache, it is capable of generating a parity fault. The other operations do not generate parity faults.

#### Table 339. Cache Functions

| Function                        | opcode_2 | CRm    | Data    | Instruction                |
|---------------------------------|----------|--------|---------|----------------------------|
| Invalidate I&D cache & BTB      | 0b000    | 0b0111 | Ignored | MCR p15, 0, Rd, c7, c7, 0  |
| Invalidate I cache & BTB        | 0b000    | 0b0101 | Ignored | MCR p15, 0, Rd, c7, c5, 0  |
| Invalidate I cache line         | 0b001    | 0b0101 | MVA     | MCR p15, 0, Rd, c7, c5, 1  |
| Invalidate D cache              | 0b000    | 0b0110 | Ignored | MCR p15, 0, Rd, c7, c6, 0  |
| Invalidate D cache line         | 0b001    | 0b0110 | MVA     | MCR p15, 0, Rd, c7, c6, 1  |
| Clean D cache line              | 0b001    | 0b1010 | MVA     | MCR p15, 0, Rd, c7, c10, 1 |
| Drain Write (& Fill) Buffer     | 0b100    | 0b1010 | Ignored | MCR p15, 0, Rd, c7, c10, 4 |
| Invalidate Branch Target Buffer | 0b110    | 0b0101 | Ignored | MCR p15, 0, Rd, c7, c5, 6  |
| Allocate Line in the Data Cache | 0b101    | 0b0010 | MVA     | MCR p15, 0, Rd, c7, c2, 5  |

The line-allocate command allocates a tag into the data cache specified by bits [31:5] of Rd. When a valid dirty line (with a different MVA) already exists at this location, it is evicted. The 32 bytes of data associated with the newly allocated line are not initialized and therefore generates unpredictable results when read.

This command may be used for cleaning the entire data cache on a context switch and also when re-configuring portions of the data cache as data RAM. In both cases, Rd is a virtual address that maps to some non-existent physical memory. When creating data RAM, software must initialize the data RAM before read accesses can occur.



# Intel<sup>®</sup> 80331 I/O Processor Developer's Manual Intel<sup>®</sup> XScale<sup>™</sup> Core and Core Performance Monitoring

Other items to note about the line-allocate command are:

- It forces all pending memory operations to complete.
- Bits [31:5] of Rd is used to specific the virtual address of the line to allocated into the data cache.
- When the targeted cache line is already resident, this command has no effect.
- This command cannot be used to allocate a line in the mini Data Cache.
- The newly allocated line is not marked as "dirty" so it never gets evicted. However, when a valid store is made to that line it is marked as "dirty" and gets written back to external memory when another line is allocated to the same cache location. This eviction produces unpredictable results when the line-allocate command used a virtual address that mapped to non-existent memory.

To avoid this situation, the line-allocate operation is only used when one of the following can be guaranteed:

- The virtual address associated with this command is not one that is generated during normal program execution. This is the case when line-allocate is used to clean/invalidate the entire cache.
- The line-allocate operation is used only on a cache region destined to be locked. When the region is unlocked, it must be invalidated before making another data access.



# 13.3.8 Register 8: TLB Operations

Disabling/enabling the MMU has no effect on the contents of either TLB: valid entries stay valid, locked items remain locked. All operations defined in Table 340 work regardless of whether the TLB is enabled or disabled.

This register is accessed as write-only. Reads from this register, as with an MRC, have an undefined effect.

#### Table 340. TLB Functions

| Function               | opcode_2 | CRm    | Data    | Instruction               |
|------------------------|----------|--------|---------|---------------------------|
| Invalidate I&D TLB     | 0b000    | 0b0111 | Ignored | MCR p15, 0, Rd, c8, c7, 0 |
| Invalidate I TLB       | 0b000    | 0b0101 | Ignored | MCR p15, 0, Rd, c8, c5, 0 |
| Invalidate I TLB entry | 0b001    | 0b0101 | MVA     | MCR p15, 0, Rd, c8, c5, 1 |
| Invalidate D TLB       | 0b000    | 0b0110 | Ignored | MCR p15, 0, Rd, c8, c6, 0 |
| Invalidate D TLB entry | 0b001    | 0b0110 | MVA     | MCR p15, 0, Rd, c8, c6, 1 |

### 13.3.9 Register 9: Cache Lock Down

Register 9 is used for locking down entries into the instruction cache and data cache.

Table 341 shows the command for locking down entries in the instruction cache, instruction TLB, and data TLB. The entry to lock is specified by the virtual address in Rd. The data cache locking mechanism follows a different procedure than the others. The data cache is placed in lock down mode such that all subsequent fills to the data cache result in that line being locked in, as controlled by Table 342.

Lock/unlock operations on a disabled cache have an undefined effect. This register is accessed as write-only. Reads from this register, as with an MRC, have an undefined effect.

#### Table 341. Cache Lockdown Functions

| Function                       | opcode_2 | CRm    | Data                   | Instruction               |
|--------------------------------|----------|--------|------------------------|---------------------------|
| Fetch and Lock I cache line    | 0b000    | 0b0001 | MVA                    | MCR p15, 0, Rd, c9, c1, 0 |
| Unlock Instruction cache       | 0b001    | 0b0001 | Ignored                | MCR p15, 0, Rd, c9, c1, 1 |
| Read data cache lock register  | 0b000    | 0b0010 | Read lock mode value   | MRC p15, 0, Rd, c9, c2, 0 |
| Write data cache lock register | 0b000    | 0b0010 | Set/Clear lock<br>mode | MCR p15, 0, Rd, c9, c2, 0 |
| Unlock Data Cache              | 0b001    | 0b0010 | Ignored                | MCR p15, 0, Rd, c9, c2, 1 |

#### Table 342. Data Cache Lock Register

| 31 30 29 2  | 8 27 26 25 24 23 22 21 20 19 18 17 | 7 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                             |
|-------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------|
|             |                                    | L                                                                                                                      |
| reset value | : writeable bits set to 0          |                                                                                                                        |
| Bits        | Access                             | Description                                                                                                            |
| 31:1        | Read-unpredictable / Write-as-Zero | Reserved                                                                                                               |
| 0           | Read / Write                       | Data Cache Lock Mode (L)  0 = No locking occurs  1 = Any fill into the data cache while this bit is set gets locked in |



# 13.3.10 Register 10: TLB Lock Down

Register 10 is used for locking down entries into the instruction TLB, and data TLB. Lock/unlock operations on a TLB when the MMU is disabled have an undefined effect.

This register is accessed as write-only. Reads from this register, as with an MRC, have an undefined effect.

Table 343 shows the command for locking down entries in the instruction TLB, and data TLB. The entry to lock is specified by the virtual address in Rd.

#### Table 343. TLB Lockdown Functions

| Function                       | opcode_2 | CRm    | Data    | Instruction                |
|--------------------------------|----------|--------|---------|----------------------------|
| Translate and Lock I TLB entry | 0b000    | 0b0100 | MVA     | MCR p15, 0, Rd, c10, c4, 0 |
| Translate and Lock D TLB entry | 0b000    | 0b1000 | MVA     | MCR p15, 0, Rd, c10, c8, 0 |
| Unlock I TLB                   | 0b001    | 0b0100 | Ignored | MCR p15, 0, Rd, c10, c4, 1 |
| Unlock D TLB                   | 0b001    | 0b1000 | Ignored | MCR p15, 0, Rd, c10, c8, 1 |



### 13.3.11 Register 13: Process ID

The I/O processor supports the remapping of virtual addresses through a Process ID (PID) register. This remapping occurs before the instruction cache, instruction TLB, data cache and data TLB are accessed. The PID register controls when virtual addresses are remapped and to what value.

The PID register is a 7-bit value that is ORed with bits 31:25 of the virtual address when they are zero. This effectively remaps the address to one of 128 "slots" in the 4 Gbytes of address space. When bits 31:25 are not zero, no remapping occurs. This feature is useful for operating system management of processes that may map to the same virtual address space. In those cases, the virtually mapped caches on the I/O processor do not require invalidating on a process switch.

#### Table 344. Accessing Process ID

| Function                  | opcode_2 | CRm    | Instruction                |
|---------------------------|----------|--------|----------------------------|
| Read Process ID Register  | 0b000    | 0b0000 | MRC p15, 0, Rd, c13, c0, 0 |
| Write Process ID Register | 0b000    | 0b0000 | MCR p15, 0, Rd, c13, c0, 0 |

#### Table 345. Process ID Register

| 31 30 29 28  | 27 26 25                     | 24  | 23 | 22                                                                                                                       | 21 | 20 | 19   | 18    | 17   | 16  | 15  | 14  | 13   | 12 | 11   | 10    | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------|------------------------------|-----|----|--------------------------------------------------------------------------------------------------------------------------|----|----|------|-------|------|-----|-----|-----|------|----|------|-------|------|---|---|---|---|---|---|---|---|---|
| Process ID   |                              |     |    |                                                                                                                          |    |    |      |       |      |     |     |     |      |    |      |       |      |   |   |   |   |   |   |   |   |   |
| reset value: | 0x0000,0                     | 000 |    |                                                                                                                          |    |    |      |       |      |     |     |     |      |    |      |       |      |   |   |   |   |   |   |   |   |   |
| Bits         | Access                       |     |    | Description                                                                                                              |    |    |      |       |      |     |     |     |      |    |      |       |      |   |   |   |   |   |   |   |   |   |
| 31:25        | Read / Write                 |     |    | <b>Process ID</b> - This field is used for remapping the virtual address when bits 31-25 of the virtual address are zero |    |    |      |       |      |     |     |     |      |    |      |       |      |   |   |   |   |   |   |   |   |   |
| 24:0         | Read-as-Zero / Write-as-Zero |     |    | ser<br>mpa                                                                                                               |    |    | Shou | ıld l | be p | rog | ran | nme | d to | ze | ro f | or fu | utur | Э |   |   |   |   |   |   |   |   |

#### 13.3.11.1 The PID Register Affect On Addresses

All addresses generated and used by User Mode code are eligible for being "PIDed" as described in the previous section. Privileged code, however, must be aware of certain special cases in which address generation does not follow the usual flow.

The PID register is not used to remap the virtual address when accessing the Branch Target Buffer (BTB). Any writes to the PID register invalidate the BTB, which prevents any virtual addresses from being double mapped between two processes.

A breakpoint address must be expressed as an MVA when written to the breakpoint register. This means the value of the PID must be combined appropriately with the address before it is written to the breakpoint register. All virtual addresses in translation descriptors are MVAs.

644 October, 2003 **Document Number: 273942-002** 



# 13.3.12 Register 14: Breakpoint Registers

The I/O processor contains two instruction breakpoint address registers (IBCR0 and IBCR1), one data breakpoint address register (DBR0), one configurable data mask/address register (DBR1), and one data breakpoint control register (DBCON). The I/O processor also supports a 256 entry, trace buffer that records program execution information. The registers to control the trace buffer are located in CP14.

#### 

| Function                                                    | opcode_2 | CRm    | Instruction                                                        |
|-------------------------------------------------------------|----------|--------|--------------------------------------------------------------------|
| Access Instruction Breakpoint<br>Control Register 0 (IBCR0) | 0b000    | 0b1000 | MRC p15, 0, Rd, c14, c8, 0; read MCR p15, 0, Rd, c14, c8, 0; write |
| Access Instruction Breakpoint<br>Control Register 1(IBCR1)  | 0b000    | 0b1001 | MRC p15, 0, Rd, c14, c9, 0; read MCR p15, 0, Rd, c14, c9, 0; write |
| Access Data Breakpoint Address<br>Register (DBR0)           | 0b000    | 0b0000 | MRC p15, 0, Rd, c14, c0, 0; read MCR p15, 0, Rd, c14, c0, 0; write |
| Access Data Mask/Address Register (DBR1)                    | 0b000    | 0b0011 | MRC p15, 0, Rd, c14, c3, 0; read MCR p15, 0, Rd, c14, c3, 0; write |
| Access Data Breakpoint Control Register (DBCON)             | 0b000    | 0b0100 | MRC p15, 0, Rd, c14, c4, 0; read MCR p15, 0, Rd, c14, c4, 0; write |



# 13.3.13 Register 15: Coprocessor Access Register

Sharing resources among different applications requires a state saving mechanism. Two possibilities are:

- The operating system, during a context switch, saves the state of the coprocessor when the last executing process had access rights to the coprocessor.
- The operating system, during a request for access, saves off the old coprocessor state and saves it with last process to have access to it.

Under both scenarios, the OS needs to restore state when a request for access is made. This means the OS has to maintain a list of what processes are modifying CP0 and their associated state.

#### Example 7. Disallowing Access to CP0

#### Table 347. Coprocessor Access Register

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 | 6 1 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | - / | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------------------------------------|-----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
|                                                |     | 0  | С  | C  | С  | С  | С | С | С   | С | С | С | С | С | С | C |
|                                                | C   | 0  | P  | P  | P  | P  | P | P | P   | P | P | Р | P | P | P | P |
|                                                |     |    | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

#### reset value: 0x0000,0000

| Bits  | Access                             | Description                                                                                                                                                 |
|-------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | Read-unpredictable / Write-as-Zero | Reserved - Program to zero for future compatibility                                                                                                         |
| 15:14 | Read-as-Zero/Write-as-Zero         | Reserved - Program to zero for future compatibility                                                                                                         |
|       |                                    | Coprocessor Access Rights-<br>Each bit in this field corresponds to the access rights for<br>each coprocessor.                                              |
| 13:0  | Read / Write                       | For each bit:                                                                                                                                               |
| 13.0  | read / Wille                       | O = Access denied. Attempts to access corresponding coprocessor generates an undefined exception.     1 = Access allowed. Includes read and write accesses. |
|       |                                    | Setting any of bits 12:1 has an undefined effect.                                                                                                           |



# 13.4 Core Performance Monitoring Unit (CPMON)

#### 13.4.1 CPMON Overview

The Intel<sup>®</sup> XScale<sup>™</sup> core hardware provides two 32-bit performance counters that allow two unique events to be monitored simultaneously. In addition, Intel<sup>®</sup> XScale<sup>™</sup> core implements a 32-bit clock counter that can be used in conjunction with the performance counters; its sole purpose is to count the number of core clock cycles which is useful in measuring total execution time.

Intel<sup>®</sup> XScale <sup>TM</sup> core can monitor either occurrence events or duration events. When counting occurrence events, a counter is incremented each time a specified event takes place and when measuring duration, a counter counts the number of processor clocks that occur while a specified condition is true. When any of the 3 counters overflow, an IRQ or FIQ is generated when it is enabled. (IRQ or FIQ selection is programmed in the interrupt controller.) Each counter has its own interrupt enable. The counters continue to monitor events even after an overflow occurs, until disabled by software.

Each of these counters can be programmed to monitor any one of various events.

To further augment performance monitoring, the Intel<sup>®</sup> XScale<sup>™</sup> core clock counter can be used to measure the executing time of an application. This information combined with a duration event can feedback a percentage of time the event occurred with respect to overall execution time.

Each of the three counters and the performance monitoring control register are accessible through Coprocessor 14 (CP14), registers 0-3. Refer to Section 7.3.1, "Registers 0-3: Performance Monitoring", in the Intel<sup>®</sup> 80200 Processor based on Intel<sup>®</sup> XScale Microarchitecture Developer's Manual (Order Number: 273411), for more details on accessing these registers with MRC, MCR, LDC, and STC coprocessor instructions. Access is allowed in privileged mode only.



# 13.4.2 Performance Monitoring Events

Table 348 lists events that may be monitored by the CPMON. Each of the Performance Monitor Count Registers (PMN0 and PMN1) can count any listed event. Software selects which event is counted by each PMNx register by programming the evtCountx fields of the PMNC register.

#### **Table 348.** Performance Monitoring Events

| Event Number (evtCount0 or evtCount1) | Event Definition                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0                                   | Instruction cache miss requires fetch from external memory.                                                                                                                                                                                                                                                                                                                                                                           |
| 0x1                                   | Instruction cache cannot deliver an instruction. This could indicate an ICache miss or an ITLB miss. This event occurs every cycle in which the condition is present.                                                                                                                                                                                                                                                                 |
| 0x2                                   | Stall due to a data dependency. This event occurs every cycle in which the condition is present.                                                                                                                                                                                                                                                                                                                                      |
| 0x3                                   | Instruction TLB miss.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x4                                   | Data TLB miss.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x5                                   | Branch instruction executed, branch may or may not have changed program flow.                                                                                                                                                                                                                                                                                                                                                         |
| 0x6                                   | Branch mispredicted.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0x7                                   | Instruction executed.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x8                                   | Stall because the data cache buffers are full. This event occurs every cycle in which the condition is present.                                                                                                                                                                                                                                                                                                                       |
| 0x9                                   | Stall because the data cache buffers are full. This event occurs once for each contiguous sequence of this type of stall.                                                                                                                                                                                                                                                                                                             |
| 0xA                                   | Data cache access, not including Cache Operations (defined in Section 7.2.8 of the Intel® 80200 Processor based on Intel® XScale™ Microarchitecture Developer's Manual).                                                                                                                                                                                                                                                              |
| 0xB                                   | Data cache miss, not including Cache Operations (defined in Section 7.2.8 of the Intel <sup>®</sup> 80200 Processor based on Intel <sup>®</sup> XScale Microarchitecture Developer's Manual).                                                                                                                                                                                                                                         |
| 0xC                                   | Data cache write-back. This event occurs once for each 1/2 line (four words) that are written back from the cache.                                                                                                                                                                                                                                                                                                                    |
| 0xD                                   | Software changed the PC. This event occurs any time the PC is changed by software and there is not a mode change. For example, a <b>mov</b> instruction with PC as the destination triggers this event. Executing a <b>swi</b> from User mode does not trigger this event, because it incurs a mode change.                                                                                                                           |
| 0x10                                  | BCU detected a 1-bit error while reading data from the bus. This event may be counted even when reporting of 1-bit errors is disabled. See Section 11.3, "Error Handling" on page 11-2 of the Intel® 80200 Processor based on Intel® XScale™ Microarchitecture Developer's Manual for a description of 1-bit errors.                                                                                                                  |
| 0x11                                  | The BCUs request queue is full. This event takes place each clock cycle in which the condition is met. A high incidence of this event indicates the BCU is often waiting for transactions to complete on the external bus.                                                                                                                                                                                                            |
| 0x12                                  | The BCUs request queue is not empty and the bus is in hold (see Section 10.2.5, "Multimaster Support" on page 10-9 of the Intel® 80200 Processor based on Intel® XScale Microarchitecture Developer's Manual, for a description of hold mode on the external bus). This event takes place each clock cycle in which the condition is met. A high incidence of this event indicates the BCU is starved for access to the external bus. |
| 0x13                                  | RMW cycle occurred due to narrow write on ECC-protected memory (see Section 11.2, "ECC" on page 11-1 of the Intel® 80200 Processor based on Intel® XScale™ Microarchitecture Developer's Manual, for a description of ECC and RMW cycles).                                                                                                                                                                                            |
| 0x14                                  | The BCU detected an ECC error, but no ELOG register was available in which to log the error. (See Section 11.4.2, "ECC Error Registers" on page 11-9 of the Intel <sup>®</sup> 80200 Processor based on Intel <sup>®</sup> XScale <sup>™</sup> Microarchitecture Developer's Manual, for a description of the ELOG registers).                                                                                                        |
| all others                            | Reserved, unpredictable results                                                                                                                                                                                                                                                                                                                                                                                                       |

# Intel<sup>®</sup> 80331 I/O Processor Developer's Manual Intel<sup>®</sup> XScale<sup>™</sup> Core and Core Performance Monitoring

Some typical combination of counted events are listed in this section and summarized in Table 349. In this section, we call such an event combination a *mode*.

#### Table 349. Some Common Uses of the CPMON

| Mode                         | PMNC.evtCount0               | PMNC.evtCount1         |
|------------------------------|------------------------------|------------------------|
| Instruction Cache Efficiency | 0x7 (instruction count)      | 0x0 (ICache miss)      |
| Data Cache Efficiency        | 0xA (Dcache access)          | 0xB (DCache miss)      |
| Instruction Fetch Latency    | 0x1 (ICache cannot deliver)  | 0x0 (ICache miss)      |
| Data/Bus Request Buffer Full | 0x8 (DBuffer stall duration) | 0x9 (DBuffer stall)    |
| Stall/Writeback Statistics   | 0x2 (data stall)             | 0xC (DCache writeback) |
| Instruction TLB Efficiency   | 0x7 (instruction count)      | 0x3 (ITLB miss)        |
| Data TLB Efficiency          | 0xA (Dcache access)          | 0x4 (DTLB miss)        |

#### 13.4.2.1 Instruction Cache Efficiency Mode

PMN0 totals the number of instructions that were executed, which does not include instructions fetched from the instruction cache that were never executed. This can happen when a branch instruction changes the program flow; the instruction cache may retrieve the next sequential instructions after the branch, before it receives the target address of the branch.

PMN1 counts the number of instruction fetch requests to external memory. Each of these requests loads 32 bytes at a time.

Statistics derived from these two events:

- Instruction cache miss-rate. This is derived by dividing PMN1 by PMN0.
- The average number of cycles it took to execute an instruction or commonly referred to as cycles-per-instruction (CPI). CPI can be derived by dividing CCNT by PMN0, where CCNT was used to measure total execution time.

#### 13.4.2.2 Data Cache Efficiency Mode

PMN0 totals the number of data cache accesses, which includes cacheable and non-cacheable accesses, mini-data cache access and accesses made to locations configured as data RAM.

Note that **STM** and **LDM** each count as several accesses to the data cache depending on the number of registers specified in the register list. **LDRD** registers two accesses.

PMN1 counts the number of data cache and mini-data cache misses. Cache operations do not contribute to this count. See Section 7.2.8 of the Intel<sup>®</sup> 80200 Processor based on Intel<sup>®</sup> XScale Microarchitecture Developer's Manual, for a description of these operations.

The statistic derived from these two events is:

• Data cache miss-rate. This is derived by dividing PMN1 by PMN0.



#### 13.4.2.3 Instruction Fetch Latency Mode

PMN0 accumulates the number of cycles when the instruction-cache is not able to deliver an instruction to  $Intel^{\otimes}$  XScale  $^{TM}$  core due to an instruction-cache miss or instruction-TLB miss. This event means that the processor core is stalled.

PMN1 counts the number of instruction fetch requests to external memory. Each of these requests loads 32 bytes at a time. This is the same event as measured in the instruction cache efficiency mode and is included in this mode for convenience so that only one performance monitoring run is need.

Statistics derived from these two events:

- The average number of cycles the processor stalled waiting for an instruction fetch from external memory to return. This is calculated by dividing PMN0 by PMN1. When the average is high then Intel<sup>®</sup> XScale To core may be starved of the bus external to Intel<sup>®</sup> XScale Core.
- The percentage of total execution cycles the processor stalled waiting on an instruction fetch from external memory to return. This is calculated by dividing PMN0 by CCNT, which was used to measure total execution time.

#### 13.4.2.4 Data/Bus Request Buffer Full Mode

The Data Cache has buffers available to service cache misses or uncacheable accesses. For every memory request that the Data Cache receives from the processor core a buffer is speculatively allocated in case an external memory request is required or temporary storage is needed for an unaligned access. When no buffers are available, the Data Cache stalls the processor core. How often the Data Cache stalls depends on the performance of the bus external to Intel<sup>®</sup> XScale<sup>TM</sup> core and what the memory access latency is for Data Cache miss requests to external memory. When the Intel<sup>®</sup> XScale<sup>TM</sup> core memory access latency is high, possibly due to starvation, these Data Cache buffers iscome full. This performance monitoring mode is provided to see when Intel<sup>®</sup> XScale<sup>TM</sup> core is being starved of the bus external to Intel<sup>®</sup> XScale<sup>TM</sup> core, which effects the performance of the application running on Intel<sup>®</sup> XScale<sup>TM</sup> core.

PMN0 accumulates the number of clock cycles the processor is being stalled due to this condition and PMN1 monitors the number of times this condition occurs.

Statistics derived from these two events:

- The average number of cycles the processor stalled on a data-cache access that may overflow the data-cache buffers. This is calculated by dividing PMN0 by PMN1. This statistic lets you know when the duration event cycles are due to many requests or are attributed to just a few requests. When the average is high then Intel<sup>®</sup> XScale<sup>TM</sup> core may be starved of the bus external to Intel<sup>®</sup> XScale<sup>TM</sup> core.
- Percent of total execution cycles processor stalled because Data Cache request buffer was not available. Calculate by dividing PMN0 by CCNT, used to measure total execution time.

650 October, 2003 **Document Number: 273942-002** 



#### 13.4.2.5 Stall/Writeback Statistics

When an instruction requires the result of a previous instruction and that result is not yet available, Intel<sup>®</sup> XScale<sup>™</sup> core stalls in order to preserve the correct data dependencies. PMN0 counts the number of stall cycles due to data-dependencies. Not all data-dependencies cause a stall; only the following dependencies cause such a stall penalty:

- Load-use penalty: try to use load result before load completes. To avoid penalty, software should delay using load result until available. Penalty shows data-cache access latency effect.
- Multiply/Accumulate-use penalty: try to use multiply or multiply/accumulate operation result before operation completes. To avoid penalty, software should delay using result until available.
- ALU use penalty: there are a few isolated cases where back-to-back ALU operations may result in one cycle delay in the execution. These cases are defined in Chapter 14, "Performance Considerations" of the Intel® 80200 Processor based on Intel® XScale Microarchitecture Developer's Manual.

PMN1 counts the number of writeback operations emitted by the data cache. These writebacks occur when the data cache evicts a dirty line of data to make room for a newly requested line or as the result of clean operation (CP15, register 7).

Statistics derived from these two events:

- Percent of total execution cycles processor stalled because of data dependency. Calculate by dividing PMN0 by CCNT, used to measure total execution time. Often a compiler can reschedule code to avoid these penalties, given the right optimization switches.
- Total number of data writeback requests to external memory can be derived solely with PMN1.

#### 13.4.2.6 Instruction TLB Efficiency Mode

PMN0 totals the number of instructions that were executed, which does not include instructions that were translated by the instruction TLB and never executed. This can happen when a branch instruction changes the program flow; the instruction TLB may translate the next sequential instructions after the branch, before it receives the target address of the branch.

PMN1 counts the number of instruction TLB table-walks, which occurs when there is a TLB miss. When the instruction TLB is disabled PMN1 does not increment.

Statistics derived from these two events:

- Instruction TLB miss-rate. This is derived by dividing PMN1 by PMN0.
- The average number of cycles it took to execute an instruction or commonly referred to as cycles-per-instruction (CPI). CPI can be derived by dividing CCNT by PMN0, where CCNT was used to measure total execution time.

#### 13.4.2.7 Data TLB Efficiency Mode

PMN0 totals the number of data cache accesses, which includes cacheable and non-cacheable accesses, mini-data cache access and accesses made to locations configured as data RAM.

Note that **STM** and **LDM** each count as several accesses to the data TLB depending on the number of registers specified in the register list. **LDRD** registers two accesses.

PMN1 counts the number of data TLB table-walks, which occurs when there is a TLB miss. When the data TLB is disabled PMN1 does not increment.

The statistic derived from these two events is:

Data TLB miss-rate. This is derived by dividing PMN1 by PMN0.



# 13.4.3 Statistics from Multiple Performance Monitoring Runs

Even though only two events can be monitored at any given time, multiple performance monitoring runs can be done, capturing different events from different modes. For example, the first run could monitor the number of writeback operations (PMN1 of mode, Stall/Writeback) and the second run could monitor the total number of data cache accesses (PMN0 of mode, Data Cache Efficiency). From the results, a percentage of writeback operations to the total number of data accesses can be derived.

# **13.4.4 Examples**

In this example, the events selected with the Instruction Cache Efficiency mode are monitored and CCNT is used to measure total execution time. Sampling time ends when PMN0 overflows which generates an IRQ interrupt.

#### **Example 8. Configuring the Performance Monitor**

Counter overflow can be dealt with in the IRQ interrupt service routine as shown below:

#### **Example 9.** Interrupt Handling

```
IRQ_INTERRUPT_SERVICE_ROUTINE:
; Assume that performance counting interrupts are the only IRQ in the system
MRC P14,0,R1,C0,c0,0; read the PMNC register
BIC R2,R1,#1; clear the enable bit
MCR P14,0,R2,C0,c0,0; clear interrupt flag and disable counting
MRC P14,0,R3,C1,c0,0; read CCNT register
MRC P14,0,R4,C2,c0,0; read PMN0 register
MRC P14,0,R5,C3,c0,0; read PMN1 register

MRC P14,0,R5,C3,c0,0; read PMN1 register

SUBSPC,R14,#4; return from interrupt
```

As an example, assume the following values in CCNT, PMN0, PMN1 and PMNC:

#### **Example 10. Computing the Results**

```
; Assume CCNT overflowed

CCNT = 0x0000,0020 ; Overflowed and continued counting

Number of instructions executed = PMN0 = 0x6AAA,AAAA

Number of instruction cache miss requests = PMN1 = 0x0555,5555

Instruction Cache miss-rate = 100 * PMN1/PMN0 = 5%

CPI = (CCNT + 2^32)/Number of instructions executed = 2.4 cycles/instruction
```

In the contrived example above, the instruction cache had a miss-rate of 5% and CPI was 2.4.



# 13.4.5 CPMON Registers

#### Table 350. CPMON Registers

| Register | Description                                                               |
|----------|---------------------------------------------------------------------------|
| CCNT     | Section 13.4.5.1, "Clock Count Register CCNT" on page 653                 |
| PMNx     | Section 13.4.5.2, "Performance Count Registers PMNx" on page 654          |
| PMNC     | Section 13.4.5.3, "Performance Monitor Control Register PMNC" on page 655 |

#### 13.4.5.1 Clock Count Register -- CCNT

The format of CCNT is shown in Table 351. The clock counter is reset to '0' by Performance Monitor Control Register (PMNC) or can be set to a predetermined value by directly writing to it. When CCNT reaches its maximum value 0xFFFF,FFFF, the next clock cycle causes it to roll over to zero and set the overflow flag (bit 6) in PMNC. An IRQ or FIQ is reported when it is enabled via bit 6 in the PMNC register.

Table 351. Clock Count Register -- CCNT





#### 13.4.5.2 Performance Count Registers -- PMNx

There are two 32-bit event counters; their format is shown in Table 352. The event counters are reset to '0' by the PMNC register or can be set to a predetermined value by directly writing to them. When an event counter reaches its maximum value 0xFFFF,FFFF, the next event it needs to count causes it to roll over to zero and set the overflow flag (bit 8 or 9) in PMNC. An IRQ interrupt is reported when it is enabled via bit 4 or 5 in the PMNC register.

Table 352. Performance Count Register -- PMNx



#### 13.4.5.2.1 Extending Count Duration Beyond 32 Bits

To increase the monitoring duration, software can extend the count duration beyond 32 bits by counting the number of overflow interrupts each 32-bit counter generates. This can be done in the interrupt service routine (ISR) where an increment to some memory location every time the interrupt occurs enables longer durations of performance monitoring. This does intrude upon program execution but is negligible, since the ISR execution time is in the order of tens of cycles compared to the number of cycles it took to generate an overflow interrupt (2<sup>32</sup>).

654 October, 2003 **Document Number: 273942-002** 



#### 13.4.5.3 Performance Monitor Control Register -- PMNC

The performance monitor control register (PMNC) is a coprocessor register that:

- controls which events PMN0 and PMN1 monitors.
- detects which counter overflowed.
- enables/disables interrupt reporting.
- extends CCNT counting by six more bits (cycles between counter rollover =  $2^{38}$ ).
- resets all counters to zero.
- and enables the entire mechanism.

Table 353 shows the format of the PMNC register.

Table 353. Performance Monitor Control Register -- PMNC (Sheet 1 of 2)





Table 353. Performance Monitor Control Register -- PMNC (Sheet 2 of 2)





## 13.4.5.4 Managing PMNC

The following are a few notes about controlling the performance monitoring mechanism:

- An interrupt is reported when a counter's overflow flag is set and its associated interrupt enable bit is set in the PMNC register. The interrupt remains asserted until software clears the overflow flag by writing a one to the flag that is set. Note that the interrupt unit (Chapter 15, "Interrupt Controller Unit") and the CPSR must have enabled the interrupt in order for software to receive it.
- The counters continue to record events even after they overflow.



# This Page Intentionally Left Blank



Timers 14

This chapter describes the Intel<sup>®</sup> 80331 I/O processor (80331) dual-programmable 32-bit timers and Watch Dog Timer. Topics include timer registers (TMRx, TCRx and TRRx), timer operation, timer interrupts, and timer register values at initialization.

Each timer is programmed by the timer registers. These registers are mapped into Intel<sup>®</sup> XScale<sup>™</sup> microarchitecture Coprocessor 6, registers 0 to 5. They may be accessed/manipulated with the MCR, MRC, STC, and LDC instructions. The *CRn* field of the instruction denotes the register number to be accessed. The *opcode\_1* and *opcode\_2* fields of the instruction should be zero. The *CRm* field of the instruction should be one. Most systems restricts access to CP6 to privileged processes. To control access to CP6, use the Coprocessor Access Register.

Figure 112 shows a diagram of the timer functions. See also Figure 113 for the Programmable Timer state diagram.

Figure 112. Programmable Timer Functional Diagram



# Intel® 80331 I/O Processor Developer's Manual Timers



When enabled, a timer decrements the user-defined count value with each Timer Clock (TCLOCK) cycle. The countdown rate is also user-configurable to be equal to the internal bus frequency, or the internal bus clock rate divided by 4, 8 or 16. The timers can be programmed to either stop when the count value reaches zero (single-shot mode) or run continuously (auto-reload mode). When a timer's count reaches zero, the timer's interrupt unit signals the processor's interrupt controller.

#### **Table 354.** Timer Performance Ranges

| Internal Bus Frequency (MHz) | Max Resolution (ns) | Max Range (mins) |
|------------------------------|---------------------|------------------|
| 266                          | 3.75                | 4.30             |



# 14.1 Timer Operation

This section summarizes the programmable timer and Watch Dog Timer operation and describes load/store access latency for the timer registers.

# 14.1.1 Basic Programmable Timer Operation

Each timer has a programmable enable bit in its control register (TMRx.enable) to start and stop counting. This allows the programmer to prevent user mode tasks from enabling or disabling the timer. Once the timer is enabled, the value stored in the Timer Count Register (TCRx) decrements every Timer Clock (TCLOCK) cycle. TCLOCK is determined by the Timer Input Clock Select (TMRx.csel) bit setting. The countdown rate can be set to equal the internal bus clock frequency, or the internal bus clock rate divided by 4, 8 or 16. Setting TCLOCK to a slower rate lets the user specify a longer count period with the same 32-bit TCRx value.

Software can read or write the TCRx value whether the timer is running or stopped. This lets the user monitor the count without using hardware interrupts.

When the TCRx value decrements to zero, the unit's interrupt request signals the processor's interrupt controller. See Section 14.2, "Timer Interrupts" on page 664 for more information. The timer checks the value of the timer reload bit (TMRx.reload) setting. When TMRx.reload. = 1, the processor:

- Automatically reloads TCRx with the value in the Timer Reload Register (TRRx).
- Decrements TCRx until it equals 0 again.

This process repeats until software clears TMRx.reload or TMR.enable.

When TMRx.reload = 0, the timer stops running and sets the terminal count bit (TMRx.tc). This bit remains set until user software reads or writes the TMRx register. Either access type clears the bit. The timer ignores any value specified for TMRx.tc in a write request.

#### Table 355. Timer Mode Register Control Bit Summary



**NOTE:** X = don't care

N = a number between 1H and FFFF FFFFH



## 14.1.2 Watch Dog Timer Operation

The Watch Dog Timer (WDT) is a 32-bit down counter that can be used to reset the Internal Bus and the Intel<sup>®</sup> XScale<sup>TM</sup> core when software gets stuck in an infinite loop. A reset of the Internal Bus also results in the **M\_RST**# output to be asserted which can be used to reset the system or as an external indicator of the WDT expiration.

Following **P\_RST**# assertion, the WDT is disabled.

The software can enable the WDT by using coprocessor instructions (i.e, MCR or LDC) to write the value 1E1E 1E1EH followed by the value E1E1 E1E1H to the WDT Control register. When enabled, the WDT is initialized with FFFF FFFFH and begin to decrement towards 0000 0000H.

The software is required periodically to write the WDT initialization sequence (the value 1E1E 1E1EH followed by the value E1E1 E1E1H) to the WDT Control register in order to reset the timer value to FFFF FFFFH. For a 266 MHz Internal Bus frequency, this means that the sequence must be written approximately every fifteen seconds.

*Note:* The WDT always runs at Internal Bus frequency speed of 266MHz.

When the software fails to reinitialize the WDT prior to the timer value transitioning to zero, an Internal Bus Reset is generated. The Internal Bus Reset reinitializes all Internal Bus peripherals and the Intel<sup>®</sup> XScale  $^{^{TM}}$  core.

*Warning:* Once enabled, the WDT can **not** be disabled without resetting the Intel<sup>®</sup> XScale<sup>TM</sup> core.



## 14.1.3 Load/Store Access Latency for Timer Registers

As with all other load accesses from internal memory-mapped registers, a load instruction that accesses a timer register has a latency of one internal processor cycle. With one exception, a store access to a timer register completes and all state changes take effect before the next instruction begins execution. The exception to this is when disabling a timer. Latency associated with the disabling action is such that a timer interrupt may be posted immediately after the disabling instruction completes. This can occur when the timer is near zero as the store to TMRx occurs. In this case, the timer interrupt is posted immediately after the store to TMRx completes and before the next instruction can execute. Table 356 summarizes the timer access and response timings. Refer also to the individual register descriptions for details.

Note that the processor may delay the actual issuing of the load or store operation due to previous instruction activity and resource availability of processor functional units.

The processor ensures that the TMRx.tc bit is cleared within one internal bus clock after a load or store instruction accesses TMRx.

Table 356. Timer Responses to Register Bit Settings

| Name                                     | Status | Action                                                                                                                                                                                                                                                                                |
|------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (TMRx.tc)<br>Terminal Count              | READ   | Timer clears this bit when user software accesses TMRx. This bit can be set 1 internal bus clock later. The timer sets this bit within 1 internal bus clock of TCRx reaching zero when TMRx.reload=0.                                                                                 |
| Bit 0                                    | WRITE  | Timer clears this bit within 1 internal bus clock after the software accesses TMRx. The timer ignores any value specified for TMRx.tc in a write request.                                                                                                                             |
| (TMRx.enable)<br>Timer Enable            | READ   | Bit is available 1 internal bus clock after executing a read instruction from TMRx.                                                                                                                                                                                                   |
| Bit 1                                    | WRITE  | Writing a '1' enables the internal bus clock to decrement TCRx within 1 internal bus clock after executing a store instruction to TMRx.                                                                                                                                               |
| (TMRx.reload)                            | READ   | Bit is available 1 internal bus clock after executing a read instruction from TMRx.                                                                                                                                                                                                   |
| Timer Auto Reload<br>Enable<br>Bit 2     | WRITE  | Writing a '1' enables the reload capability within 1 internal bus clock after the store instruction to TMRx has executed. The timer loads TRRx data into TCRx and decrements this value during the next internal bus clock cycle.                                                     |
| (TMRx.csel1:0)                           | READ   | Bits are available 1 internal bus clock after executing a read instruction from TMRx.csel1:0 bit(s).                                                                                                                                                                                  |
| Timer Input Clock<br>Select<br>Bits 4-5  | WRITE  | The timer re-synchronizes the clock cycle used to decrement TCRx within one internal bus clock cycle after executing a store instruction to TMRx.csel1:0 bit(s).                                                                                                                      |
| (TCRx.d31:0)<br>Timer Count<br>Register  | READ   | The current TCRx count value is available within 1 internal bus clock cycle after executing a read instruction from TCRx. When the timer is running, the pre-decremented value is returned as the current value.                                                                      |
|                                          | WRITE  | The value written to TCRx becomes the active value within 1 internal bus clock cycle. When the timer is running, the value written is decremented in the current clock cycle.                                                                                                         |
| (TRRx.d31:0)<br>Timer Reload<br>Register | READ   | The current TRRx count value is available within 1 internal bus clock after executing a read instruction from TRRx. When the timer is transferring the TRRx count into TCRx in the current count cycle, the timer returns the new TCRx count value to the executing read instruction. |
|                                          | WRITE  | The value written to TRRx becomes the active value stored in TRRx within 1 internal bus clock cycle. When the timer is transferring the TRRx value into the TCRx, data written to TRRx is also transferred into TCRx.                                                                 |



# 14.2 Timer Interrupts

Each timer is the source for one interrupt. When a timer detects a zero count in its TCRx, the timer generates an internal level-detected Timer Interrupt signal (TINTx) to the interrupt controller, and the interrupt source (INTSRC[1:0]) bit is set in the interrupt controller. Each timer interrupt can be selectively masked in the Interrupt Control (INTCTL[1:0]) registers. Refer to Section 15.5, "Intel® 80331 I/O Processor Interrupt Controller Unit" for a description of interrupt controller operation.

After servicing the timer interrupt, the interrupt service routine clears the pending request by writing a '1' to the appropriate bit of the Timer Interrupt Status Register (TISR).

When a timer generates a second interrupt request before the CPU services the first interrupt request, the second request may be lost.

When auto-reload is enabled for a timer, the timer continues to decrement the value in TCRx even after entry into the timer interrupt handler.



# 14.3 Timer State Diagram

Figure 113 shows the common states of the Timer Unit. For uncommon conditions see Section 14.5, "Uncommon TCRX and TRRX Conditions" on page 674.

Figure 113. Timer Unit State Diagram





# 14.4 Timer Registers

As shown in Table 357, each timer has three memory-mapped registers:

- Timer Mode Register programs the specific mode of operation or indicates the current programmed status of the timer. This register is described in Section 14.4.2, "Timer Mode Registers TMR0:1" on page 667.
- Timer Count Register contains the timer's current count. See Section 14.4.3, "Timer Count Register TCR0:1" on page 670.
- Timer Reload Register contains the timer's reload count. See Section 14.4.4, "Timer Reload Register TRR0:1" on page 671.

#### Table 357. Timer Registers

| Timer Unit | Register Acronym | Register Name           |
|------------|------------------|-------------------------|
| Timer 0    | TMR0             | Timer Mode Register 0   |
|            | TCR0             | Timer Count Register 0  |
|            | TRR0             | Timer Reload Register 0 |
| Timer 1    | TMR1             | Timer Mode Register 1   |
|            | TCR1             | Timer Count Register 1  |
|            | TRR1             | Timer Reload Register 1 |

# 14.4.1 Power Up/Reset Initialization

Upon **P\_RST#** assertion, the timer registers are initialized to the values shown in Table 358.

#### **Table 358.** Timer Powerup Mode Settings

| Mode/Control Bit | Notes                                        |
|------------------|----------------------------------------------|
| TMRx.tc = 0      | No terminal count                            |
| TMRx.enable = 0  | Prevents counting and assertion of TINTx     |
| TMRx.reload = 0  | Single terminal count mode                   |
| TMRx.pri = 0     | Privileged Mode and User Mode Writes Allowed |
| TMRx.csel1:0 = 0 | Timer Clock = internal bus clock             |
| TCRx.d31:0 = 0   | Undefined                                    |
| TRRx.d31:0 = 0   | Undefined                                    |
| TINTx output     | Deasserted                                   |

666 October, 2003 **Document Number: 273942-002** 



# 14.4.2 Timer Mode Registers – TMR0:1

The Timer Mode Register (TMRx) lets the user program the mode of operation and determine the current status of the timer. TMRx bits are described in the subsections following Table 359 and are summarized in Table 355.

Note: TMR0:1 registers are read-only from Memory-Mapped Register Address space.

#### Table 359. Timer Mode Register – TMRx



#### 14.4.2.1 Bit 0 - Terminal Count Status Bit (TMRx.tc)

The TMRx.tc bit is set when the Timer Count Register (TCRx) decrements to 0 and bit 2 (TMRx.reload) is not set for a timer. The TMRx.tc bit allows applications to monitor timer status through software instead of interrupts. TMRx.tc remains set until software accesses (reads or writes) TMRx. The access clears TMRx.tc. The timer ignores any value specified for TMRx.tc in a write request.

When auto-reload is selected for a timer and the timer is enabled, the TMRx.tc bit status is unpredictable. Software should not rely on the value of the TMRx.tc bit when auto-reload is enabled.

The processor also clears the TMRx.tc bit upon hardware or software reset. Refer to Section 18.2, "Reset Overview" on page 755.



#### 14.4.2.2 Bit 1 - Timer Enable (TMRx.enable)

The TMRx.enable bit allows user software to control the timer's RUN/STOP status. When:

TMRx.enable = 1 The Timer Count Register (TCRx) value decrements every Timer

Clock (TCLOCK) cycle. TCLOCK is determined by the Timer Input Clock Select (TMRx.csel bits 0-1). See Section 14.4.2.5. When TMRx.reload=0, the timer automatically clears TMRx.enable when the count reaches zero. When TMRx.reload=1, the bit remains set. See

Section 14.4.2.3.

TMRx.enable = 0 The timer is disabled and ignores all input transitions.

User software sets this bit. Once started, the timer continues to run, regardless of other processor activity. Three events can stop the timer:

- User software explicitly clearing this bit (i.e., TMRx.enable = 0).
- TCRx value decrements to 0, and the Timer Auto Reload Enable (TMRx.reload) bit = 0.
- Hardware or software reset. Refer to Section 18.2, "Reset Overview" on page 755.

#### 14.4.2.3 Bit 2 - Timer Auto Reload Enable (TMRx.reload)

The TMRx.reload bit determines whether the timer runs continuously or in single-shot mode. When TCRx = 0 and TMRx.enable = 1 and:

TMRx.reload = 1 The timer runs continuously. The processor:

- 1. Automatically loads TCRx with the value in the Timer Reload Register (TRRx), when TCRx value decrements to 0.
- 2. Decrements TCRx until it equals 0 again.

Steps 1 and 2 repeat until software clears TMRx bits 1 or 2.

TMRx.reload = 0 The timer runs until the Timer Count Register = 0. TRRx has no effect on the timer.

User software sets this bit. When TMRx.enable and TMRx.reload are set and TRRx does not equal 0, the timer continues to run in auto-reload mode, regardless of other processor activity. Two events can stop the timer:

- User software explicitly clearing either TMRx.enable or TMRx.reload.
- Hardware or software reset.

The processor clears this bit upon hardware or software reset.



#### 14.4.2.4 Bit 3 - Timer Register Privileged Read/Write Control (TMRx.pri)

The TMRx.pri bit enables or disables user mode writes to the timer registers (TMRx, TCRx, TRRx). Privileged mode writes are allowed regardless of this bit's condition. Software can read these registers from either mode.

When:

TMRx.pri = 1 The timer ignores the user mode write to the timer registers; however,

writes from the privileged modes are allowed.

TMRx.pri = 0 The timer registers can be written from either the user mode or the

privileged modes.

The processor clears TMRx.pri upon hardware or software reset.

#### 14.4.2.5 Bits 4, 5 - Timer Input Clock Select (TMRx.csel1:0)

User software programs the TMRx.csel bits to select the Timer Clock (TCLOCK) frequency. See Table 360. As shown in Figure 112, the internal bus clock is an input to the timer clock unit. These bits allow the application to specify whether TCLOCK runs at or slower than the internal bus clock frequency.

#### Table 360. Timer Input Clock (TCLOCK) Frequency Selection

| Bit 5<br>TMRx.csel1 | Bit 4<br>TMRx.csel0 | Timer Clock (TCLOCK)                  |
|---------------------|---------------------|---------------------------------------|
| 0                   | 0                   | Timer Clock = internal bus clock      |
| 0                   | 1                   | Timer Clock = internal bus clock / 4  |
| 1                   | 0                   | Timer Clock = internal bus clock / 8  |
| 1                   | 1                   | Timer Clock = internal bus clock / 16 |

The processor clears these bits upon hardware or software reset (TCLOCK = Core Clock).



# 14.4.3 Timer Count Register – TCR0:1

The Timer Count Register (TCRx) is a 32-bit register that contains the timer's current count. The register value decrements with each timer clock tick. When this register value decrements to zero (terminal count), a timer interrupt is generated. When TMRx.reload is not set for the timer, the status bit in the timer mode register (TMRx.tc) is set and remains set until the TMRx register is accessed. Table 361 shows the timer count register.

*Note:* TCR0:1 registers are read-only from Memory-Mapped Register Address space.

Table 361. Timer Count Register – TCRx



The valid programmable range is from 1H to FFFF FFFFH. Avoid programming TCRx to 0 as it has varying results as described in Section 14.5, "Uncommon TCRX and TRRX Conditions" on page 674.

User software can read or write TCRx whether the timer is running or stopped. Bit 3 of TMRx determines user read/write control (Section 14.4.2.5). The TCRx value is undefined after hardware or software reset.



# 14.4.4 Timer Reload Register – TRR0:1

The Timer Reload Register (TRRx; Table 362) is a 32-bit register that contains the timer's reload count. The timer loads the reload count value into TCRx when TMRx.reload is set (1), TMRx.enable is set (1) and TCRx equals zero.

As with TCRx, the valid programmable range is from 1H to FFFF FFFFH. Avoid programming a value of 0, as it may prevent TINTx from asserting continuously. (See Section 14.5, "Uncommon TCRX and TRRX Conditions" on page 674 for more information.)

User software can access TRRx whether the timer is running or stopped. Bit 3 of TMRx determines read/write control (Section 14.4.2.5, "Bits 4, 5 - Timer Input Clock Select (TMRx.csel1:0)" on page 669). TRRx value is undefined after hardware or software reset.

*Note:* TRR0:1 registers are read-only from Memory-Mapped Register Address space.

#### Table 362. Timer Reload Register – TRRx





# 14.4.5 Timer Interrupt Status Register – TISR

The Timer Interrupt Status Register (TISR; Table 363) is a two-bit register that contains the timer's pending interrupt status. The setting of these status bits represents the assertion of a "level-sensitive" interrupt request to the "Intel<sup>®</sup> 80331 I/O Processor Interrupt Controller Unit". After the interrupt service routine completes processing of the interrupt request, it needs to write a '1' to the appropriate bit in the TISR to clear the pending request.

TISR interrupt requests are cleared after hardware or software reset.

Note: TISR register is read-only from Memory-Mapped Register Address space.

Table 363. Timer Interrupt Status Register — TISR





# 14.4.6 Watch Dog Timer Control Register – WDTCR

The Watch Dog Timer Control Register (WDTCR) is a 32-bit register that software can use to enable the WDT or read the current WDT count value. The register value decrements with each internal bus clock tick. When this register value decrements to zero (terminal count), an Internal Bus Reset is generated. The timer can be enabled and/or reinitialized by writing 1E1E 1E1EH immediately followed by E1E1 E1E1H to the WDTCR.

Note: WDTCR register is read-only from Memory-Mapped Register Address space.

Table 364. Watch Dog Timer Control Register -- WDTCR





# 14.5 Uncommon TCRx and TRRx Conditions

Table 355 summarizes the most common settings for programming the timer registers. Under certain conditions, however, it may be useful to set the Timer Count Register or the Timer Reload Register to zero before enabling the timer. Table 365 details the conditions and results when these conditions are set.

#### Table 365. Uncommon TMRx Control Bit Settings

| TRRx | TCRx | Bit 2<br>(TMRx.reload) | Bit 1<br>(TMRx.enable) | Action                                                                                                                 |
|------|------|------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------|
| Х    | 0    | 0                      | 1                      | TMRx.tc and TINTx set, TMR.enable cleared                                                                              |
| 0    | 0    | 1                      | 1                      | Timer and auto reload enabled, TINTx not generated and timer enable remains set.                                       |
| 0    | N    | 1                      | 1                      | Timer and auto reload enabled. TINTx set when TCRx=0. The timer remains enabled but further TINTx's are not generated. |

**NOTE:** X = don't care

N = a number between 1H and FFFF FFFFH



# Interrupt Controller Unit

15

This chapter describes the Intel® 80331 I/O processor (80331) Interrupt Controller Unit. The operation modes, setup, external memory interface, and implementation of the interrupts are described in this chapter.

## 15.1 Overview

The interrupt control unit manages the interrupt routing and interrupt sources to the  $Intel^{\mathbb{R}}$  XScale  $^{IM}$  core.

An interrupt is an event that causes a temporary break in program execution so the processor can handle another task. Interrupts commonly request I/O services or synchronize the processor with some external hardware activity. For interrupt handler portability across the Intel<sup>®</sup> XScale microarchitecture family (ARM\* architecture compliant), the architecture defines a consistent exception handling mechanism. To manage exceptions which include interrupt requests in parallel with processor execution, the 80331 provides an on-chip programmable interrupt controller.

Requests for interrupt service come from many sources and are prioritized such that instruction execution is redirected only when an exception interrupt request is of higher priority than that of the executing task. On the 80331, interrupt requests may originate from external hardware sources, internal peripherals or software. The 80331 contains a number of integrated peripherals which may generate interrupts, including:

- DMA Channel 0
- DMA Channel 1
- ATU
- UART 0 and 1
- Timers 0 and 1
- Performance Monitoring Unit

- I<sup>2</sup>C Bus Interface Units 0 and 1
- Application Accelerator Unit
- Messaging Unit
- Memory Controller Unit
- Peripheral Bus Interface Unit
- •

The interrupt controller can also intercept external processor interrupts and forward them to the PCI interrupt pins.

Interrupts are detected with the chip 4-bit interrupt port, an 12-bit GPIO port, and with a dedicated High-Priority Interrupt (**HPI**#) input in the Intel<sup>®</sup> XScale<sup>™</sup> core interrupt controller. Interrupt requests originate from software by the **SWI** instruction.

Ultimately, all interrupt sources that are steered to the Intel<sup>®</sup> XScale<sup>™</sup> core processor are combined into one of two internal interrupt exceptions: IRQ and FIQ.



# 15.2 Theory of Operation

## 15.2.1 Interrupt Controller Unit

The 80331 Interrupt Controller Unit (ICU) provides the ability to generate interrupts to both the Intel<sup>®</sup> XScale <sup>TM</sup> core and the PCI interrupt pins.

In addition to the internal peripherals, external devices may also generate interrupts to the Intel<sup>®</sup> XScale<sup>™</sup> core. External devices can generate interrupts via the **S\_INT[D:A]**# pins, the **GPIO[7:0]/XINT[15:8]**# pins, and the **HPI**# pin. The Peripheral Interrupt Controller provides the ability to direct PCI interrupts. The routing logic enables, under software control, the ability to intercept external PCI interrupts and forward to the PCI interrupt output pinsor to the Intel<sup>®</sup> XScale Tore.

The Interrupt Controller has two functions:

- Internal Peripheral Interrupt Control
- External Interrupt Routing

The internal peripheral interrupt control mechanism consolidates a number of interrupt sources for a given peripheral into a single interrupt driven to the Intel<sup>®</sup> XScale <sup>™</sup> core. High performance data movement associated interrupts are fully demultiplexed into the ICU, however. In order to provide the executing software with the knowledge of interrupt source, coprocessor mapped status registers describe the source of the active interrupts and the vectors to interrupt handlers for the highest priority active sources. All of the peripheral interrupts are individually enabled from the respective peripheral control registers.

The Peripheral interrupt routing mechanism allows the host software (or Intel<sup>®</sup> XScale<sup>TM</sup> microarchitecture software) to route external interrupts to either the Intel<sup>®</sup> XScale<sup>TM</sup> core or the **P\_INTA#**, **P\_INTB#**, **P\_INTC#**, and **P\_INTD#** output pins. This routing mechanism is controlled through a memory-mapped register accessible from the 80331.

676 October, 2003 **Document Number: 273942-002** 



# 15.3 The Intel<sup>®</sup> XScale<sup>™</sup> Core Exceptions Architecture

The Intel<sup>®</sup> XScale<sup>TM</sup> core supports five types of exceptions<sup>1</sup>, and a privileged processing mode for each type.

- IRQ and FIQ internal interrupt exceptions otherwise known as the normal and fast interrupts, respectively
- memory aborts (used to implement memory protection or virtual memory)
- attempted execution of an undefined instruction
- software interrupts (SWIs) (used to make a call to an Operating System)

When an exception occurs, some of the standard registers are replaced with registers specific to the exception mode. All exceptions have replacement (or banked) registers for R14 and R13, and one interrupt mode has more registers for fast interrupt processing.

After an exception, R14 holds the return address for exception processing, which is used both to return after the exception is processed and to address the instruction that caused the exception.

R13 is banked across exception modes to provide each exception handler with a private stack pointer (SP). The fast interrupt mode also banks R8 to R12, so that interrupt processing can begin without the need to save or restore these registers. There is a seventh processing mode, System Mode, that does not have any banked registers (it uses the User mode registers), which is used to run normal (non-exception) tasks that require a privileged processor mode.

#### 15.3.1 CPSR and SPSR

All other processor state is held in status registers. The current operating processor status is in the Current Program Status Register or CPSR. The CPSR holds:

- Four condition code flags (Negative, Zero, Carry and Overflow)
- Two interrupt disable bits (one for each type of interrupt)
- Five bits which encode the current processor mode

All five exception modes also have a Saved Program Status Register (SPSR) which holds the CPSR of the task immediately before the exception occurred. Both the CPSR and SPSR are accessed with special instructions.

# 15.3.2 The Exception Process

When an exception occurs, the Intel<sup>®</sup> XScale<sup>™</sup> core halts execution after the current instruction and begins execution at a fixed address in low memory, known as the exception vectors. There is a separate vector location for each exception (and two for memory aborts to distinguish between data and instruction accesses).

An operating system installs a handler on every exception at initialization. Privileged operating system tasks normally run in System mode to allow exceptions to occur within the operating system without state loss (exceptions overwrite their R14 when an exception occurs, and System mode is the only privileged mode that cannot be entered by an exception).

**Document Number: 273942-002** October, 2003 677

<sup>1.</sup> Exception Description from the ARM Architecture Reference Manual, p. 1-3, Copyright Advanced RISC Machines Ltd. (ARM) 1996



# 15.3.3 Exception Priorities and Vectors

It is important to note that fast interrupt (FIQ) is higher priority than the normal interrupt (IRQ). In addition, while an FIQ exception is executing, the IRQ exception is masked out.

When an exception is taken by the processor, the Program Counter (PC) is loaded with the vector associated with that exception as specified by Table 366.

Generally, the instruction at this location is required to be a branch instruction to the associated exception handler. However, in the case of an FIQ, this is not necessary since the vector location is at the very bottom of all the defined exception vectors, thus the entire FIQ exception handler can be placed at that vector location.

#### Table 366. Exception Priorities And Vectors

| Exception                             | Priority    | Vector <sup>a</sup> |
|---------------------------------------|-------------|---------------------|
| Reset                                 | 1 (Highest) | 0000 0000H          |
| Data Abort                            | 2           | 0000 0010H          |
| FIQ                                   | 3           | 0000 001CH          |
| IRQ                                   | 4           | 0000 0018H          |
| Prefetch Abort                        | 5           | 0000 000CH          |
| Undefined Instructions                | 6 (Lowest)  | 0000 0004H          |
| Software Interrupt (SWI) <sup>b</sup> | 6 (Lowest)  | 0000 0008H          |

By enabling the Exception Vector Relocation mode (bit 13, CP15, Register 1), the Vectors (except Reset Vector) can be relocated to be based at FFFF 0000H rather than 0000 0000H. (i.e., FIQ Vector located at FFFF 001CH)

# 15.3.4 Software Requirements For Exception Handling

To use the processor's exception handling facilities, user software must provide the following items in memory:

- Exception Handler Routines
- Software handler to nest certain exceptions (i.e., FIQ and IRQ)

These items are established in memory as part of the initialization procedure.

#### 15.3.4.1 Nesting FIQ and IRQ Exceptions

Hardware does not provide support for nesting of any particular exception, including the FIQ and IRQ exceptions.

In order to provide support for nested interrupts, a software handler must be provided to save the Link Register (R14) and the SPSR (Saved Program Status Register) before reenabling the FIQ or IRQ exception.

b. Undefined Instruction and SWI can not occur at the same time since SWI is a particular instruction decoding.



# 15.4 Intel<sup>®</sup> 80331 I/O Processor External Interrupt Interface

The interrupt controller attached to the Intel<sup>®</sup> XScale<sup>™</sup> core, has the facilities necessary to handle all core processor and peripheral internal interrupts, as well as four external interrupts (**S\_INT[D:A]**#XINT[3:0]#), twelve GPIO inputs (**GPIO[7:0**]), and one High Priority Interrupt (**HPI**#).

80331 Primary PCI local bus interface includes four interrupt output signals. Interrupts from the Secondary PCI bus, the Messaging Unit and Address Translation Unit are routed to these interrupt output signals via the interrupt controller steering logic.

## 15.4.1 Interrupt Inputs

The 17 external interrupt input pins of the 80331 have the following definitions:

**S\_INT[D:A]**#**XINT[3:0]**#**External Interrupt (Input)** - These pins cause interrupts to be requested. Each pin is a level-detect input only. These pins are internally synchronized. These pins only act as interrupt inputs when they are unmasked in the INTCTL[1:0] registers.

**GPIO[7:0]** External Interrupt (Input) - These pins cause interrupts (XINT[15:8]#) to be requested. Each pin is a level-detect input only. These pins are internally synchronized. These pins only act as interrupt inputs when they are configured as general purpose inputs and are unmasked in the INTCTL[1:0] registers.

**HPI#**High-Priority Interrupt (Input) - Causes a high priority interrupt event to occur.
The external HPI# input requires a level input and is maskable by the INTCTL[1:0] registers. This pin is internally synchronized.

The external interrupt input interface for the 80331 consists of the pins shown in Table 367.

#### **Table 367.** Interrupt Input Pin Descriptions

| Signal         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S_INTA#/XINT0# | Directed to the <b>P_INTA#</b> (XINT4#) output or the 80331 Interrupt Controller input XINT0#. When directed to the 80331 Interrupt Controller input XINT0#, the XINT0# input can be steered to either the FIQ or the IRQ internal interrupt input of the Intel <sup>®</sup> XScale <sup>™</sup> core.                                                                                                                                     |
| S_INTB#/XINT1# | Directed to the <b>P_INTB#</b> ( <b>XINT5#</b> ) output or the 80331 Interrupt Controller input <b>XINT1#</b> . When directed to the 80331 Interrupt Controller input <b>XINT1#</b> , the <b>XINT1#</b> input can be steered to either the FIQ or the IRQ internal interrupt input of the Intel <sup>®</sup> XScale <sup>™</sup> core.                                                                                                     |
| S_INTC#/XINT2# | Directed to the <b>P_INTC#</b> ( <b>XINT6#</b> ) output or the 80331 Interrupt Controller input <b>XINT2#</b> . When directed to the 80331 Interrupt Controller input <b>XINT2#</b> , the <b>XINT2#</b> input can be steered to either the FIQ or the IRQ internal interrupt input of the Intel <sup>®</sup> XScale <sup>™</sup> core.                                                                                                     |
| S_INTD#/XINT3# | Directed to the <b>P_INTD#</b> ( <b>XINT7#</b> ) output or the 80331 Interrupt Controller input <b>XINT3#</b> . When directed to the 80331 Interrupt Controller input <b>XINT3#</b> , the <b>XINT3#</b> input can be steered to either the FIQ or the IRQ internal interrupt input of the Intel <sup>®</sup> XScale <sup>™</sup> core.                                                                                                     |
| XINT[15:8]#    | Interrupt Inputs dedicated to the Intel <sup>®</sup> XScale <sup>™</sup> core. Functionary is muxed with <b>GPIO[7:0]</b> functionality. <b>XINT8#</b> corresponds to <b>GPIO[0]</b> , <b>XINT9#</b> corresponds to <b>GPIO[1]</b> , and so on. Interrupt functionality is available on these pins only when configured as General Purpose Inputs. To enable a given pin as an interrupt, it needs to be unmasked in the INTCTL1 register. |
| HPI#           | <b>HPI#</b> is a dedicated interrupt input to the Intel <sup>®</sup> XScale <sup>™</sup> core. This interrupt can be disabled by the INTCTL0 register, and can be steered to either the FIQ or the IRQ internal interrupt (not the interrupt outputs).                                                                                                                                                                                     |



# 15.4.2 Outbound Interrupts

The Messaging Unit (MU) has the capability of generating interrupts on the PCI interrupt output pin . The MU has four distinct messaging mechanisms. Each allows a host processor or external PCI agent and the 80331 to communicate through message passing and interrupt generation. The four mechanisms are:

- Message Registers allow the 80331 and external PCI agents to communicate by passing messages in one of four 32-bit Message Registers. In this context, a message is any 32-bit data value. Message registers combine aspects of mailbox registers and doorbell registers. Writes to the message registers may optionally cause interrupts.
- **Doorbell Registers** allow the 80331 to assert the PCI interrupt signals and allow external PCI agents to generate an interrupt to the Intel<sup>®</sup> XScale <sup>TM</sup> core.
- Circular Queues support a message passing scheme that uses four circular queues.
- **Index Registers** support a message passing scheme that uses a portion of the 80331 local memory to implement a large set of message registers.

All four mechanisms can result in Outbound Interrupts to a host processor.

The Messaging Unit (MU) is a part of the Address Translation Unit (ATU) and uses the ATU interrupt pin.

The external interrupt output interface for 80331 consists of the pins shown in Table 368.

#### **Table 368.** Interrupt Output Pin Descriptions

| Signal  | Description                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | Primary PCI Interrupt output of 80331 source from <b>S_INTA#</b> based on interrupt steering control.                                                                                                                                                                                                                             |
| P_INTA# | When the 80331 bridge is disabled ( <b>BRG_EN</b> is low), and arbiter/central resource is disabled ( <b>ARB_EN</b> is low), the 80331 ATU/MU interrupt is also connected to this Primary PCI Output.                                                                                                                             |
| P_INTB# | Primary PCI Interrupt output of 80331 source from <b>S_INTB#</b> based on interrupt steering control.                                                                                                                                                                                                                             |
|         | Primary PCI Interrupt output of 80331 source from <b>S_INTC#</b> based on interrupt steering control.                                                                                                                                                                                                                             |
| P_INTC# | The 80331 ATU/MU interrupt is also connected to this Primary PCI Output based on internally wiring the ATU IDSEL input to S_AD30. This routing applies to 80331 modes with bridge enabled ( <b>BRG_EN</b> is high), and bridge disabled ( <b>BRG_EN</b> is low) and arbiter/central resource is enabled ( <b>ARB_EN</b> is high). |
| P_INTD# | Primary PCI Interrupt output of 80331 source from <b>S_INTD#</b> based on interrupt steering control.                                                                                                                                                                                                                             |



# 15.4.3 Interrupt Routing

The four PCI interrupt inputs of the 80331, **S\_INT[D:A]**#/**XINT[3:0]**#, can be routed to either Intel<sup>®</sup> XScale<sup>TM</sup> core interrupt inputs or to the primary PCI interrupt output pins **P\_INT[D:A]**#/**XINT[7:4]**#.

Routing of interrupt inputs is controlled by the PCI Interrupt Routing Select Register (PIRSR). Table 369 summarizes the usage of the bits in the PIRSR.

#### Table 369. Interrupt Routing Summary

| PIRSR Select Bit | Bit Value | Description                                      |
|------------------|-----------|--------------------------------------------------|
| bit 0            | 1         | S_INTA# Input Pin routed to ICU XINT0# Input Pin |
| Dit 0            | 0         | S_INTA# Input Pin routed to P_INTA# Output Pin   |
| bit 1            | 1         | S_INTB# Input Pin routed to ICU XINT1# Input Pin |
| DIL I            | 0         | S_INTB# Input Pin routed to P_INTB# Output Pin   |
| bit 2            | 1         | S_INTC# Input Pin routed to ICU XINT2# Input Pin |
|                  | 0         | S_INTC# Input Pin routed to P_INTC# Output Pin   |
| bit 3            | 1         | S_INTD# Input Pin routed to ICU XINT3# Input Pin |
|                  | 0         | S_INTD# Input Pin routed to P_INTD# Output Pin   |

**Note: XINT0**# through **XINT3**# of the 80331 Interrupt Controller only handles level sensitive inputs such as PCI interrupts. When any Select bit is cleared, the logic external to the ICU input must drive an inactive level ('1') to the corresponding interrupt input of the 80331 Interrupt Controller.



# 15.5 Intel<sup>®</sup> 80331 I/O Processor Interrupt Controller Unit

The 80331 Interrupt Controller Unit (ICU) provides a flexible, low-latency means for requesting interrupts and minimizing the core's interrupt handling burden.

All interrupt sources are combined into one of the two internal interrupt exceptions: IRQ and FIQ.

The interrupt controller provides the following features for managing hardware-requested interrupts:

- Flexibility to direct interrupt sources to either the FIQ or IRQ internal interrupt exception
- 13 external interrupt pins.
  - One high-priority maskable interrupt pin, HPI#.
  - Four maskable Inputs, S INT[D:A]#/XINT[3:0]#.
  - Twelve GPIO Pins (when configured as Inputs), GPIO[7:0]/XINT[15:8]#
- Two internal programmable timer sources.
- Peripheral interrupt sources.

All interrupts are *level sensitive*: interrupt sources must keep asserting the interrupt signal until software causes the source to deassert it.

All interrupt sources are individually maskable with the ICUs Interrupt Control registers (

). Additionally, all interrupts may be quickly disabled by altering the F and I bits in the CPSR as specified in the *ARM Architecture Reference Manual* - ARM Limited. Order number: ARM DDI 0100E...

When software running on the 80331 is vectored to an Interrupt Service Routine (ISR), it reads the ICUs IRQ Interrupt Vector Register (IINTVEC) or FIQ Interrupt Vector register (FINTVEC) to quickly retrieve the address for the interrupt handler of the highest priority active interrupt source.



# 15.5.1 Programmer Model

Software has access to 15 registers in the ICU. These registers control, masking, prioritization, and vector generation for all interrupt sources.

#### 15.5.1.1 Active Interrupt Source Control and Status

The INTCTL[1:0] register is used to enable or disable (mask) individual interrupts. As mentioned, masking of all interrupts may still be accomplished via the CPSR register in the core. INTSTR[1:0] are used to direct internal interrupts to either FIQ or IRQ. IINTSRC[1:0] and FINTSRC[1:0] are read-only registers that record all currently active and unmasked interrupt sources; the architecture for the interrupt source registers and FIQ/IRQ generation is illustrated in Figure 114.

Figure 114. Interrupt Controller Block Diagram (Active Interrupt Source Registers)





#### 15.5.1.2 Prioritization and Vector Generation for Active Interrupt Sources

The INTPRI[3:0] registers reserve two bits for each source to assign one of four priority levels.

| 00 <sub>2</sub> - High Priority     |
|-------------------------------------|
| 01 <sub>2</sub> - Med/High Priority |
| 10 <sub>2</sub> - Med/Low Priority  |
| 11 <sub>2</sub> - Low Priority      |

When interrupt vector generation is enabled and there are multiple requests pending either in the FINTSRC[1:0] or the IINTSRC[1:0] registers, the prioritizer selects a highest priority active source for each source register.

**Note:** When multiple interrupts at the same priority level are pending for either FIQ or IRQ, the highest priority active source is selected according to a fixed priority based on bit location. Highest order bit is first.

The INTBASE and INTSIZE registers are used to establish a contiguous Interrupt Service Routine (ISR) memory range for all of 64 possible sources. The architecture provides for an ISR ranging from 256 bytes to 64 Kbytes per source.

The actual vector value is a function of the INTBASE and the INTSIZE registers and is based on a fixed order of all 64 possible interrupt sources. The vectors begin at INTBASE with source 0 (i.e., IINTSRC0 bit 0), and end at INTBASE + INTSIZE (per source)\*63 with source 63 (i.e., IINTSRC1 bit 31).

#### Example 11. Determining the Location of the Interrupt Handler for Source 25

```
INTBASE = 0x81200000 ; 2 Mbyte Aligned Base Address
INTSIZE = 0xE ; 32 Kbytes per source (ISR Memory Range of 2 Mbytes)
ISR Address(25) = 0x81200000 + conv_hex(2^15*25) = 0x812C8000
```



Based on IINTSRC[1:0], FINTSRC[1:0], INTPRI[3:0], INTBASE, and INTSIZE, the interrupt controller generates the values provided by the IINTVEC and FINTVEC registers as illustrated in Figure 115. The IINTVEC and FINTVEC registers presents the vector for the active interrupt source with the highest priority to the IRQ and FIQ exception handlers, respectively.

Figure 115. Interrupt Controller Block Diagram (FIQ/IRQ Interrupt Vector Generation)



*Note:* The 80331 does not use all 64 possible sources.

ICU registers reside in Coprocessor 6 (CP6). They may be accessed/manipulated with the MCR, MRC, STC, and LDC instructions. The instruction *CRn* field denotes the accessed register number. The instruction *opcode\_1*, *opcode\_2*, and *CRm* fields should be zero. Most systems restricts access to CP6 to privileged processes. To control access to CP6, use Coprocessor Access Register.

An instruction that modifies an ICU register is guaranteed to take effect before the next instruction executes. For example, when an instruction masks an interrupt source, subsequent instructions execute in an environment in which the masked interrupt does not occur.



# 15.5.2 Operational Blocks

The ICU provides the connections to the Intel<sup>®</sup> XScale<sup>™</sup> core. These connections are shown in Figure 116.

Figure 116. Intel<sup>®</sup> 80331 I/O Processor Interrupt Controller Connections





# 15.5.3 Intel<sup>®</sup> 80331 I/O Processor: Internal Peripheral Interrupt

The 80331 Interrupt Controller receives inputs from multiple internal interrupt sources. All pending interrupts required during normal operation of the various peripheral units are available in either the IINTSRC0, IINTSRC1, FINTSRC0 or FINTSRC1 registers depending on the value in INTSTR0 or INTSTR1. To provide the best latency for high performance event driven activities, the DMA channel and AAU interrupts are fully demultiplexed into the interrupt source registers for FIQ and IRQ so that software does not need to access these peripheral units to diagnose the exact source and cause of the interrupt. The IINTSRC[1:0] and the FINTSRC[1:0] registers also include pending interrupts that indicate that an error has occurred in one of the peripheral units. For the interrupts that indicate errors, more detail about the exact cause of the interrupt can be determined by reading the status register of the respective peripheral unit.

#### 15.5.3.1 Normal Interrupt Sources

The 80331 Interrupt Controller receives normal interrupts from the two DMA channels, Performance Monitoring Unit, the I<sup>2</sup>C Bus Interface Unit, the ATU, the Programmable Timers, the Messaging Unit, the Application Accelerator Unit (AAU) and the UARTs. The DMA/AAU channel interrupts for End of Transfer interrupt or End of Chain interrupt are demultiplexed into the interrupt controller. A Performance Monitoring Unit interrupt implies that at least one of the fourteen programmable event counters and/or the Global Time Stamp Counter has a pending interrupt condition.

A valid interrupt from any of these sources outputs a *level-sensitive* interrupt to the 80331 Interrupt Controller input. The corresponding IRQ or FIQ interrupt source register bit in the interrupt controller should remain active as long as the interrupt is pending in the peripheral unit. The appropriate interrupt source bit is cleared by clearing the source of the interrupt at the internal peripheral.

The normal interrupt sources which drive the inputs to the 80331 Interrupt Controller are detailed in Table 370.

**Note:** The UART and I<sup>2</sup>C Bus Interface Unit interrupt sources are combined as a single interrupt, and include both normal and error conditions within the respective units.

#### Table 370. Normal Interrupt Sources (Sheet 1 of 2)

| Unit                           | Interrupt<br>Condition | Register                                                                  |  |
|--------------------------------|------------------------|---------------------------------------------------------------------------|--|
| DMA<br>Channel 0               | End of<br>Chain        | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| DMA<br>Channel 0               | End of<br>Transfer     | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| DMA<br>Channel 1               | End of<br>Chain        | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| DMA<br>Channel 1               | End of<br>Transfer     | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| Application<br>Accelerator     | End of<br>Chain        | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| Application<br>Accelerator     | End of<br>Transfer     | Section 6.14.2, "Channel Status Register x - CSRx" on page 372            |  |
| Core<br>Performance<br>Monitor | Counter<br>Overflow    | Section 13.4.5.3, "Performance Monitor Control Register PMNC" on page 655 |  |



# Table 370. Normal Interrupt Sources (Sheet 2 of 2)

| Part      | Unit        | Interrupt<br>Condition  | Register                                                                             |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------|--------------------------------------------------------------------------------------|--|
| Part      |             |                         | Receive Buffer Full                                                                  |  |
| Interface Unit 0 Register 0 Register 0 STOP Detected Bus Error Detected Arbitration Lost Detected Arbitration Lost Detected Receive Buffer Full Transmit Buffer Empty Status Register 1 STOP Detected Bus Error Detected Arbitration Lost Detected Arbitration Lost Detected Bus Error Detected Bus Error Detected Arbitration Lost Detected Arbitration Lost Detected Bus Error Detected Bus Error Detected Arbitration Lost Detected Index Register Interrupt Inbound Post Queue Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt I |             |                         | Transmit Buffer Empty                                                                |  |
| Register   O   STOP Detected   Bus Error Detected   Arbitration Lost Detected   Bus Error Detected   Bus Error Detected   Arbitration Lost Detected   Arbitration Lost Detected   Arbitration Lost Detected   Arbitration Lost Detected   Index Register Indown Interrupt Status Register   Inbound Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt   Inbound Message 1 Interrupt Inbound Message 0 Interrupt   Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Interrupt Inbound Message 1 Interrupt Interrupt Inbound Message 1 Interrupt Interr   |             | I <sup>2</sup> C Status | Slave Address Detect (General Call Address Detect)                                   |  |
| Arbitration Lost Detected  Arbitration Lost Detected  Receive Buffer Full Transmit Buffer Empty Slave Address Detect (General Call Address Detect) Transmit Buffer Empty Slave Address Detect (General Call Address Detect) ToP Detected Arbitration Lost Detected Bus Error Detected Arbitration Lost Detected Bus Error Detected Arbitration Lost Detected Index Register Interrupt Inbound Post Queue Interrupt Inbound Doorbell Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Interr |             |                         | STOP Detected                                                                        |  |
| Page      |             |                         | Bus Error Detected                                                                   |  |
| Transmit Buffer Empty   Slave Address Detect (General Call Address Detect)   STOP Detected   Bus Error Detected   Arbitration Lost Detected   Bus Error Detected   Bus Error Detected   Arbitration Lost Detected   Index Register Interrupt   Inbound Interrupt   Inbound Post Queue Interrupt   Inbound Post Queue Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Interrupt   Inbound Message 0 Interrupt   Interrupt   Inbound Message 0 Interrupt   I   |             |                         | Arbitration Lost Detected                                                            |  |
| Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |                         | Receive Buffer Full                                                                  |  |
| Interface Unit 1 STOP Detected Bus Error Detected Arbitration Lost Detected Bus Error Detected Arbitration Lost Detected Index Register Interrupt Inbound Interrupt Status Register Toutherrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interrupt  |             |                         | Transmit Buffer Empty                                                                |  |
| Messaging Unit Inbound Interrupt Status Register Configure Register Write Timer 10  UART Unit 1 UART |             | I <sup>2</sup> C Status | Slave Address Detect (General Call Address Detect)                                   |  |
| Messaging Unit Inbound Interrupt Status Register Interrupt Inbound Doorbell Interrupt Inbound Doorbell Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt Inbound Message 0 Interrupt Inbound Interrupt Inbound Message 0 Interrupt Inbound Interrupt Inbound Message 0 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interrupt Inbound Interrupt Inbound Message 1 Interrupt Inbound Interru |             | Register 1              | STOP Detected                                                                        |  |
| Index Register Interrupt   Inbound Interrupt   Inbound Post Queue Interrupt   Inbound Doorbell Interrupt   Inbound Doorbell Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Interrupt   Inbound Message 1 Interrupt   Interrupt   Inbound Message 1 Interrupt   Interrupt   Interrupt   Interrupt   Interrupt   Interrupt   Inbound Message 1 Interrupt   Interrupt   Interrupt   Interrupt   Interrupt   Indoording   Interrupt   Inter   |             |                         | Bus Error Detected                                                                   |  |
| Messaging Unit  Messaging Unit  Inbound Interrupt Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  Configure Register Write  Write  Timer 0  Timer 0  Timer 1  Timer Mode Register 1  UART Unit 0  INART Unit 1  UART Unit 1  Inbound Post Queue Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Inbound Message 0 Interrupt  ATU BIST Start  ATU BIST Start ATU Configuration registers written by an inbound Configuration Write cycle. This includes dedicated interrupt status bits for configuration writes to the VPDAR, IABAR1 and IAUBAR1 registers.  Timer 0 has decremented to 0 interrupt.  Received Line Status  Received Data is Available  Character Timeout Indications  Transmit FIFO Data Request  Autobaud Lock Indication  Received Data is Available  UART 1  UART Unit 1  Interrupt ID  Inbound Post Queue Interrupt Inbound Message 1 Interrupt Inbound Message 1 Interrupt Interrupt Inbound Message 1 Interrupt Inbound Pation Inbound |             |                         | Arbitration Lost Detected                                                            |  |
| Messaging Unit Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  ATU Interrupt Status Register  Configuration registers written by an inbound Configuration Write cycle. This includes dedicated interrupt status bits for configuration writes to the VPDAR, IABAR1 and IAUBAR1 registers.  Timer 0 Timer Mode Register 0  Timer 1 Timer Mode Register 1  UART Unit 0 Interrupt ID Register  UART Unit 1 UART 1 INTERIOR I |             |                         | Index Register Interrupt                                                             |  |
| Unit Status Register   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Inbound Message 1 Interrupt   Interrupt   Inbound Message 1 Interrupt   Interrupt   Interrupt   ATU BIST   Inter |             |                         | Inbound Post Queue Interrupt                                                         |  |
| Register   Inbound Message 1 Interrupt   Inbound Message 0 Interrupt   Inbound Message 0 Interrupt    ATU   Interrupt Status   ATU BIST Start   Register   Configure Register Write    |             |                         | Inbound Doorbell Interrupt                                                           |  |
| ATU Interrupt Status Register  Configure Register Write  Timer 0  Timer 1  UART Unit 0  UART Unit 1  UART Unit 2  Any of the ATU Configuration registers written by an inbound Configuration Write  UART Unit Configuration Intervel Excelled A | 0           |                         | Inbound Message 1 Interrupt                                                          |  |
| ATU BIST Start Register Configure Register Write  Timer 0 Timer 1 Timer Mode Register 1  Timer 1 Timer Mode Register 1  VART Unit 0  UART Unit 0  VART Unit 1  UART 1  |             |                         | Inbound Message 0 Interrupt                                                          |  |
| Register Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ATU         | Interrupt<br>Status     | ATU BIST Start                                                                       |  |
| Timer 0 Register 0 Timer 0 has decremented to 0 interrupt.  Timer 1 Timer Mode Register 1 Timer 1 has decremented to 0 interrupt.  Received Line Status Received Data is Available Character Timeout Indications Transmit FIFO Data Request Autobaud Lock Indication  Received Line Status Received Line Status Transmit FIFO Data Request Autobaud Lock Indication Received Line Status Received Data is Available Character Timeout Indications Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             | Register                | cycle. This includes dedicated interrupt status bits for configuration writes to the |  |
| Timer 1 Register 1 Timer 1 nas decremented to 0 Interrupt.  Received Line Status Received Data is Available Character Timeout Indications Transmit FIFO Data Request Autobaud Lock Indication Received Line Status Received Line Status  Transmit FIFO Data Request Autobaud Lock Indication Received Line Status Received Data is Available Character Timeout Indications Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Timer 0     |                         | Timer 0 has decremented to 0 interrupt.                                              |  |
| UART Unit 0 UART 0 Interrupt ID Register Transmit FIFO Data Request Autobaud Lock Indication  Received Line Status  Received Data is Available  Character Timeout Indications  Transmit FIFO Data Request Autobaud Lock Indication  Received Line Status  Received Data is Available  Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Timer 1     |                         | Timer 1 has decremented to 0 interrupt.                                              |  |
| UART Unit 0 Interrupt ID Register Character Timeout Indications  Transmit FIFO Data Request Autobaud Lock Indication  Received Line Status Received Data is Available  UART 1 Interrupt ID Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |                         | Received Line Status                                                                 |  |
| Register Transmit FIFO Data Request Autobaud Lock Indication  Received Line Status Received Data is Available  UART 1 UART 1 Interrupt ID Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             | Interrupt ID            | Received Data is Available                                                           |  |
| Autobaud Lock Indication  Received Line Status  Received Data is Available  UART 1  UA | UART Unit 0 |                         | Character Timeout Indications                                                        |  |
| Received Line Status  UART 1 UART 1 UART 1 Interrupt ID Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |             |                         | Transmit FIFO Data Request                                                           |  |
| UART 1 UART 1 Received Data is Available Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |                         | Autobaud Lock Indication                                                             |  |
| UART Unit 1 Interrupt ID Character Timeout Indications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | UART Unit 1 | _                       | Received Line Status                                                                 |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |                         | Received Data is Available                                                           |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |                         | Character Timeout Indications                                                        |  |
| Register Transmit FIFO Data Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |                         | Transmit FIFO Data Request                                                           |  |
| Autobaud Lock Indication                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |                         | Autobaud Lock Indication                                                             |  |



#### 15.5.3.2 Error Interrupt Sources

The 80331 Interrupt Controller receives error interrupts from the ATU, the Messaging Unit, the two DMA channels and the AAU. Each of these interrupts represent an error condition in the peripheral unit. Refer to the appropriate units for more details.

A valid interrupt from any of these sources outputs a *level-sensitive* interrupt to the 80331 Interrupt Controller input. The corresponding FIQ or IRQ interrupt source register bit in the interrupt controller should remain active as long as the interrupt is pending in the peripheral unit. The appropriate FIQ or IRQ interrupt source bit is cleared by clearing the source of the interrupt at the internal peripheral.

#### Table 371. Error Interrupt Sources

| Unit                                | Register                                       | Error Condition                          |  |
|-------------------------------------|------------------------------------------------|------------------------------------------|--|
|                                     |                                                | Initiated Split Completion Error Message |  |
|                                     |                                                | Received Split Completion Error Message  |  |
|                                     |                                                | Power State Transition                   |  |
|                                     |                                                | P_SERR# Asserted                         |  |
|                                     |                                                | PCI Detected Parity Error                |  |
| ATU                                 | ATU Interrupt Status Register                  | IB Master Abort                          |  |
|                                     |                                                | P_SERR# Detected                         |  |
|                                     |                                                | PCI Master Abort                         |  |
|                                     |                                                | PCI Target Abort (master)                |  |
|                                     |                                                | PCI Target Abort (target)                |  |
|                                     |                                                | PCI Master Parity Error                  |  |
| Messaging Unit                      | Inhound Interrupt Status Posister              | Outbound Free Queue Full Interrupt       |  |
| wiessaging Offic                    | Inbound Interrupt Status Register              | Error Doorbell Interrupt                 |  |
|                                     | Channel Status Register 0                      | IB Master Abort                          |  |
| DMA Channel 0                       |                                                | PCI Master Abort                         |  |
| DIVIA CHAIIITEI U                   |                                                | PCI Target Abort (master)                |  |
|                                     |                                                | Unexpected Split Completion              |  |
|                                     | Channel Status Register 1                      | IB Master Abort                          |  |
| DMA Channel 1                       |                                                | PCI Master Abort                         |  |
| DIVIA CHARIFIEI I                   |                                                | PCI Target Abort (master)                |  |
|                                     |                                                | Unexpected Split Completion              |  |
| Application Accelerator (AAU Error) | Accelerator Status Register                    | ister IB Master Abort                    |  |
|                                     | Memory Controller Interrupt<br>Status Register | ECC Error 0                              |  |
|                                     |                                                | ECC Error 1                              |  |
| Memory Controller                   |                                                | ECC Error N                              |  |
|                                     |                                                | Address Region Error                     |  |
|                                     |                                                | IB Discard Timer Expired                 |  |

The PCI Interrupt Routing Select Register and the Interrupt Source Register are described in Section 15.7.



# 15.5.4 High-Priority Interrupt (HPI#)

The **HPI**# pin generates an interrupt for implementation of critical interrupt routines.

# 15.5.5 Timer Interrupts

Each of the two timer units has an associated interrupt. Timer interrupts are connected directly to the 80331 interrupt controller and are posted in either the IINTSRC0 or FINTSRC0 registers. These interrupts are set up through the timer control registers described in Chapter 14, "Timers."

# 15.5.6 Software Interrupts

The application program may use the SWI instruction to request interrupt service.

690 October, 2003 **Document Number: 273942-002** 



# 15.6 Default Status

The interrupt logic is reset by the PCI reset signal or through software. Table 372 shows the power-up and reset values.

#### Table 372. Default Interrupt Routing and Status Values

| Register | Default Value | Description                                                                                          |
|----------|---------------|------------------------------------------------------------------------------------------------------|
| INTCTL0  | 0000 0000H    | All interrupts 31:0 masked.                                                                          |
| INTCTL1  | 0000 0000H    | All interrupts 63:32 masked.                                                                         |
| INTSTR0  | 0000 0000H    | All interrupts 31:0 steered to IRQ.                                                                  |
| INTSTR1  | 0000 0000H    | All interrupts 63:32 steered to IRQ.                                                                 |
| IINTSRC0 | 0000 0000H    | All IRQ interrupts 31:0 inactive.                                                                    |
| IINTSRC1 | 0000 0000H    | All IRQ interrupts 63:32 inactive.                                                                   |
| FINTSRC0 | 0000 0000H    | All FIQ interrupts 31:0 inactive.                                                                    |
| FINTSRC1 | 0000 0000H    | All FIQ interrupts 63:32 inactive.                                                                   |
| PIRSR    | 0000 0000H    | Interrupts S_INT[D:A]#/XINT[3:0]# routed to the P_INT[D:A]# Outputs. Interrupts XINT[7:4]# disabled. |



# 15.7 Interrupt Control Unit Registers

All Interrupt Controller registers are visible as 80331 memory mapped registers and can be accessed through the internal memory bus. Each is a 32-bit register and is memory-mapped in the Intel<sup>®</sup> XScale TM core memory space.

The PCI Interrupt Routing Select Register is accessible from the internal memory bus and also during PCI configuration cycles through the PCI configuration register space. See Chapter 3, "Address Translation Unit" for additional information regarding the PCI configuration cycles that access the PCI Interrupt Routing Select Register. The programmer's interface to the interrupt controller is through both coprocessor registers and memory-mapped control register. Table 373 describes these registers.

The coprocessor registers may be accessed/manipulated with the MCR, MRC, STC, and LDC instructions. The *CRn* field of the instruction denotes the register number to be accessed. The *opcode\_1*, *opcode\_2*, and *CRm* fields of the instruction should be zero. Most systems restricts access to CP6 to privileged processes. To control access to CP6, use the Coprocessor Access Register.

Table 373. Interrupt Controller Register Addresses

| Register Name | Description                           | Coprocessor Register (CR <sub>m</sub> = 0) or MMR Address |
|---------------|---------------------------------------|-----------------------------------------------------------|
| INTCTL0       | Interrupt Control Register 0          | CP6, Register 0 (Read/Write) FFFF E790H (Read-Only)       |
| INTCTL1       | Interrupt Control Register 1          | CP6, Register 1 (Read/Write) FFFF E794H (Read-Only)       |
| INTSTR0       | Interrupt Steer Register 0            | CP6, Register 2 (Read/Write) FFFF E798H (Read-Only)       |
| INTSTR1       | Interrupt Steer Register 1            | CP6, Register 3 (Read/Write) FFFF E79CH (Read-Only)       |
| IINTSRC0      | IRQ Interrupt Source Register 0       | CP6, Register 4 (Read-Only) FFFF E7A0H (Read-Only)        |
| IINTSRC1      | IRQ Interrupt Source Register 1       | CP6, Register 5 (Read-Only) FFFF E7A4H (Read-Only)        |
| FINTSRC0      | FIQ Interrupt Source Register 0       | CP6, Register 6 (Read-Only) FFFF E7A8H (Read-Only)        |
| FINTSRC1      | FIQ Interrupt Source Register 1       | CP6, Register 7 (Read-Only) FFFF E7ACH (Read-Only)        |
| IPR0          | Interrupt Priority Register 0         | CP6, Register 8 (Read/Write) FFFF E7B0H (Read-Only)       |
| IPR1          | Interrupt Priority Register 1         | CP6, Register 9 (Read/Write) FFFF E7B4H (Read-Only)       |
| IPR2          | Interrupt Priority Register 2         | CP6, Register 10 (Read/Write) FFFF E7B8H (Read-Only)      |
| IPR3          | Interrupt Priority Register 3         | CP6, Register 11 (Read/Write) FFFF E7BCH (Read-Only)      |
| INTBASE       | Interrupt Base Register               | CP6, Register 12 (Read/Write) FFFF E7C0H (Read-Only)      |
| INTSIZE       | Interrupt Size Register               | CP6, Register 13 (Read/Write) FFFF E7C4H (Read-Only)      |
| IINTVEC       | IRQ Interrupt Vector Register         | CP6, Register 14 (Read/Write) FFFF E7C8H (Read-Only)      |
| FINTVEC       | FIQ Interrupt Vector Register         | CP6, Register 15 (Read/Write) FFFF E7CCH (Read-Only)      |
| PIRSR         | PCI Interrupt Routing Select Register | FFFF E1ECH                                                |



# 15.7.1 Interrupt Control Register 0 - INTCTL0

The Interrupt Control register 0 is a 32-bit Coprocessor 6 control register used to specify which of 32 interrupts are masked.

Note: INTCTL0 register is read-only from Memory-Mapped Register Address space.

Table 374. Interrupt Control Register 0 - INTCTL0 (Sheet 1 of 2)





Table 374. Interrupt Control Register 0 - INTCTL0 (Sheet 2 of 2)





# 15.7.2 Interrupt Control Register 1 - INTCTL1

The Interrupt Control register 1 is a 32-bit Coprocessor 6 control register used to specify which of 32 interrupts are masked.

Note: INTCTL1 register is read-only from Memory-Mapped Register Address space.

Table 375. Interrupt Control Register 1 - INTCTL1 (Sheet 1 of 2)





Table 375. Interrupt Control Register 1 - INTCTL1 (Sheet 2 of 2)





# 15.7.3 Interrupt Steering Register 0 - INTSTR0

The Interrupt Steering Register 0 allows system designers to direct any of 32 internal or external interrupt sources to either one of the two internal interrupt exceptions, FIQ and IRQ.

When an interrupt is enabled with the INTCTL0 register, this register steers the interrupt to an internal interrupt exception.

Note: INTSTR0 register is read-only from Memory-Mapped Register Address space.

Table 376. Interrupt Steering Register 0 - INTSTR0 (Sheet 1 of 2)





Table 376. Interrupt Steering Register 0 - INTSTR0 (Sheet 2 of 2)





# 15.7.4 Interrupt Steering Register 1 - INTSTR1

The Interrupt Steering Register 1 allows system designers to direct any of 32 internal or external interrupt sources to either one of the two internal interrupt exceptions, FIQ and IRQ.

When an interrupt is enabled with the INTCTL1 register, this register steers the interrupt to an internal interrupt exception.

Note: INTSTR1 register is read-only from Memory-Mapped Register Address space.

Table 377. Interrupt Steering Register 1 - INTSTR1 (Sheet 1 of 2)





Table 377. Interrupt Steering Register 1 - INTSTR1 (Sheet 2 of 2)





#### 15.7.5 IRQ Interrupt Source Register 0 - IINTSRC0

The IRQ Interrupt Source register is a 32-bit Coprocessor 6 control register used to specify which of 32 interrupts that are steered to the internal IRQ exception are unmasked by the INTCTL0 register and active. The INTSTR0 control register is used to steer individual interrupts to the IRQ exception.

The IINTSRC0 register may be used by an Interrupt Service Routine (ISR) to determine quickly the source of an IRQ interrupt.

*Note:* IINTSRC0 register is read-only from Memory-Mapped Register Address space.

Table 378. IRQ Interrupt Source Register 0 - IINTSRC0 (Sheet 1 of 2)





Table 378. IRQ Interrupt Source Register 0 - IINTSRC0 (Sheet 2 of 2)





# 15.7.6 IRQ Interrupt Source Register 1 - IINTSRC1

The IRQ Interrupt Source register is a 32-bit Coprocessor 6 control register used to specify which of 32 interrupts that are steered to the internal IRQ exception are unmasked by the INTCTL1 register and active. The INTSTR1 control register is used to steer individual interrupts to the IRQ exception.

The IINTSRC1 register may be used by an Interrupt Service Routine (ISR) to determine quickly the source of an IRQ interrupt.

Note: IINTSRC1 register is read-only from Memory-Mapped Register Address space.

Table 379. IRQ Interrupt Source Register 1 - IINTSRC1 (Sheet 1 of 2)

| Table 373. In a interrupt oource register 1 - invroitor (oneet 1 of 2) |                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Attı                                                                   | Coprocessor Attributes    To ro rv ro rv ro |                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Bit                                                                    | Default                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 31                                                                     | 02                                                                              | HPI# Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                                                 |  |  |
| 30                                                                     | 02                                                                              | Messaging Unit Error Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                                 |  |  |
| 29                                                                     | 02                                                                              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 28                                                                     | 02                                                                              | Application Accelerator Unit Error Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                   |  |  |
| 27                                                                     | 02                                                                              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 26                                                                     | 02                                                                              | DMA Channel 1 Error Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                                  |  |  |
| 25                                                                     | 02                                                                              | DMA Channel 0 Error Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                                  |  |  |
| 24                                                                     | 02                                                                              | Memory Controller Unit Error Interrupt - when set, an error condition exists within the MCU. The bit indicates one of the following conditions:  • A single-bit correctable or uncorrectable ECC error.  • A multi-bit correctable or uncorrectable ECC error.  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1 |  |  |
| 23                                                                     | 02                                                                              | ATU Error Interrupt  0 = Not Interrupting or Not steered to internal IRQ exception or masked by INTCTL1  1 = Interrupting and steered to internal IRQ exception and unmasked by INTCTL1                                                                                                                                                                                                                                            |  |  |



Table 379. IRQ Interrupt Source Register 1 - IINTSRC1 (Sheet 2 of 2)





#### 15.7.7 FIQ Interrupt Source Register 0 - FINTSRC0

The FIQ Interrupt Source register 0 is a 32-bit Coprocessor 6 control register used to specify which interrupts that are steered to the internal FIQ exception are unmasked by the INTCTL0 register and active. The INTSTR0 control register is used to steer individual interrupts to the FIQ exception.

The FINTSRC0 register may be used by an Interrupt Service Routine (ISR) to determine quickly the source of an FIQ interrupt.

*Note:* FINTSRC0 register is read-only from Memory-Mapped Register Address space.

Table 380. FIQ Interrupt Source Register 0 - FINTSRC0 (Sheet 1 of 2)





Table 380. FIQ Interrupt Source Register 0 - FINTSRC0 (Sheet 2 of 2)





## 15.7.8 FIQ Interrupt Source Register 1 - FINTSRC1

The FIQ Interrupt Source register 1 is a 32-bit Coprocessor 6 control register used to specify which interrupts that are steered to the internal FIQ exception are unmasked by the INTCTL1 register and active. The INTSTR1 control register is used to steer individual interrupts to the FIQ exception.

The FINTSRC1 register may be used by an Interrupt Service Routine (ISR) to determine quickly the source of an FIQ interrupt.

*Note:* FINTSRC1 register is read-only from Memory-Mapped Register Address space.

Table 381. FIQ Interrupt Source Register 1 - FINTSRC1 (Sheet 1 of 2)





Table 381. FIQ Interrupt Source Register 1 - FINTSRC1 (Sheet 2 of 2)





## 15.7.9 Interrupt Priority Register 0 - IPR0

The Interrupt Priority Register 0 is a 32-bit Coprocessor 6 control register used to assign a priority level to interrupt sources 15 down to 0. The IPR0 control register is used to assign one of 4 priority levels to each interrupt source independent of the INTSTR[1:0] registers:

| 00 <sub>2</sub> - High Priority     |
|-------------------------------------|
| 01 <sub>2</sub> - Med/High Priority |
| 10 <sub>2</sub> - Med/Low Priority  |
| 11 <sub>2</sub> - Low Priority      |

When interrupt vector generation is enabled and there are multiple requests pending either in the FINTSRC[1:0] or the IINTSRC[1:0] registers, the highest priority vectors pending for either FIQ or IRQ is presented in the FINTVEC or IINTVEC, respectively.

Table 382. Interrupt Priority Register 0 - IPR0





# 15.7.10 Interrupt Priority Register 1 - IPR1

The Interrupt Priority Register 1 is a 32-bit Coprocessor 6 control register used to assign a priority level to interrupt sources 31 down to 15. The IPR1 control register is used to assign one of 4 priority levels to each interrupt source independent of the INTSTR[1:0] registers:

| 00 <sub>2</sub> - High Priority     |  |  |
|-------------------------------------|--|--|
| 01 <sub>2</sub> - Med/High Priority |  |  |
| 10 <sub>2</sub> - Med/Low Priority  |  |  |
| 11 <sub>2</sub> - Low Priority      |  |  |

When interrupt vector generation is enabled and there are multiple requests pending either in the FINTSRC[1:0] or the IINTSRC[1:0] registers, the highest priority vectors pending for either FIQ or IRQ is presented in the FINTVEC or IINTVEC, respectively.

Table 383. Interrupt Priority Register 180331 - IPR1





# 15.7.11 Interrupt Priority Register 2 - IPR2

The Interrupt Priority Register 2 is a 32-bit Coprocessor 6 control register used to assign a priority level to interrupt sources 47 down to 32. The IPR2 control register is used to assign one of 4 priority levels to each interrupt source independent of the INTSTR[1:0] registers:

| 00 <sub>2</sub> - High Priority     |  |  |
|-------------------------------------|--|--|
| 01 <sub>2</sub> - Med/High Priority |  |  |
| 10 <sub>2</sub> - Med/Low Priority  |  |  |
| 11 <sub>2</sub> - Low Priority      |  |  |

When interrupt vector generation is enabled and there are multiple requests pending either in the FINTSRC[1:0] or the IINTSRC[1:0] registers, the highest priority vectors pending for either FIQ or IRQ is presented in the FINTVEC or IINTVEC, respectively.

Table 384. Interrupt Priority Register 2 - IPR2





# 15.7.12 Interrupt Priority Register 3 - IPR3

The Interrupt Priority Register 3 is a 32-bit Coprocessor 6 control register used to assign a priority level to interrupt sources 63 down to 48. The IPR3 control register is used to assign one of 4 priority levels to each interrupt source independent of the INTSTR[1:0] registers:

| 00 <sub>2</sub> - High Priority     |  |  |
|-------------------------------------|--|--|
| 01 <sub>2</sub> - Med/High Priority |  |  |
| 10 <sub>2</sub> - Med/Low Priority  |  |  |
| 11 <sub>2</sub> - Low Priority      |  |  |

When interrupt vector generation is enabled and there are multiple requests pending either in the FINTSRC[1:0] or the IINTSRC[1:0] registers, the highest priority vectors pending for either FIQ or IRQ is presented in the FINTVEC or IINTVEC, respectively.

Table 385. Interrupt Priority Register 3 - IPR3





# 15.7.13 Interrupt Base Register - INTBASE

The Interrupt Base Register indicates the beginning of the Interrupt Service Routine (ISR) memory range that contains the interrupt service routines for up to 64 sources. The starting address must be on a boundary equal to the granularity of the ISR memory range as specified by the INTSIZE register.

For instance, the upper 24 bits are used for a 256 byte range, upper 16 bits for a 64 Kbyte range.

Note: INTBASE register is read-only from Memory-Mapped Register Address space.

Table 386. Interrupt Base Register - INTBASE





# 15.7.14 Interrupt Size Register - INTSIZE

The Interrupt Size Register indicates the size of the Interrupt Service Routine (ISR) memory range that contains the interrupt service routines for up to 64 sources. The INTSIZE register can allocate from 4 bytes to 64 Kbytes of memory address space for the ISR per source. This means that the INTSIZE register can allocate a total ISR memory space that ranges in size from 256 bytes to 4 Mbytes.

Along with the starting address defined in the INTBASE register, the INTSIZE register fully specifies the ISR memory range.

*Note:* INTSIZE register is read-only from Memory-Mapped Register Address space.

Table 387. Interrupt Size Register - INTSIZE





# 15.7.15 IRQ Interrupt Vector Register - IINTVEC

The IRQ Interrupt Vector Register is a 32-bit Coprocessor 6 control register. Following an IRQ exception, the IRQ interrupt service routine reads the 32-bit vector to the ISR for the active IRQ source with the highest priority.

The actual vector value is a function of the INTBASE and the INTSIZE registers and is based on a fixed order of all 64 possible interrupt sources. The vectors begin at INTBASE with source 0 (i.e., IINTSRC0 bit 0), and end at INTBASE + INTSIZE (per source)\*63 with source 63 (i.e., IINTSRC1 bit 31).

Before returning to User Mode from Interrupt Mode, the software reads the IINTVEC register and process any lower priority IRQ sources that are active. When there are no longer any active IRQ sources, a read from the IINTVEC register returns FFFF FFFFH.

Table 388. IRQ Interrupt Vector Register- IINTVEC





# 15.7.16 FIQ Interrupt Vector Register - FINTVEC

The FIQ Interrupt Vector Register is a 32-bit Coprocessor 6 control register. Following an FIQ exception, the FIQ interrupt service routine reads the 32-bit vector to the ISR for the active FIQ source with the highest priority.

The actual vector value is a function of the INTBASE and the INTSIZE registers and is based on a fixed order of all 64 possible interrupt sources. The vectors begin at INTBASE with source 0 (i.e., FINTSRC0 bit 0), and end at INTBASE + INTSIZE (per source)\*63 with source 63 (i.e., FINTSRC1 bit 31).

Before returning to User Mode from Interrupt Mode, the software reads the FINTVEC register and process any lower priority FIQ sources that are active. When there are no longer any active FIQ sources, a read from the FINTVEC register returns FFFF FFFFH.

Table 389. FIQ Interrupt Vector Register- FINTVEC





# 15.7.17 PCI Interrupt Routing Select Register - PIRSR

The PCI Interrupt Routing Select Register (PIRSR) determines the routing of the external input pins. The input pins consist of four external interrupt inputs which are routed to either PCI interrupts or Intel<sup>®</sup> XScale core interrupts. The external interrupt pins are defined as "level sensitive," asserted low. The assertion and deassertion of the interrupt pins are synchronous to the PCI or processor clock.

All external interrupt inputs, **S\_INT[D:A]#XINT[3:0]#**, are required to be "level sensitive," asserted low. The interrupt assertion is cleared at the source by the interrupt handler.

Table 390 shows the bit definitions for programming the PCI Interrupt Routing Select Register.

Table 390. PCI Interrupt Routing Select Register- PIRSR





# This Page Intentionally Left Blank



# General Purpose I/O Unit

16

This chapter describes the Intel<sup>®</sup> 80331 I/O processor (80331) General Purpose I/O Unit. The operation modes, setup, external memory interface, and implementation of the General Purpose I/Os (GPIOs) are described in this chapter.

# 16.1 General Purpose Input Output Support

Eight pins are provided as General Purpose Input Output (GPIO) pins. The twelve pins are **GPIO[7:0]**. These pins can be used by the Intel<sup>®</sup> XScale Core to control or monitor external devices in the I/O subsystem.

The interface for the two serial UART ports are multiplexed on to XINT[15:8]#/GPIO[7:0].

Warning:

To avoid serial port integrity problems, the user needs to ensure that the GPIO Output Data Register - GPOD bits associated with a UART port is cleared prior to setting the enable bit for that serial UART port. The user prepares to enable the serial UART ports by clearing GPOD bits associated with the respective shared GPIO pins. Refer to Section 16.1.4, "GPIO Pin Multiplexing" for the details on shared GPIO pins.

When a UART port is enabled through the UxIER Register bit 6 ("UART x Interrupt Enable Register" on page 596), the GPIO functionality described in the following sections is not available on the associated pins. UART ports are disabled following system reset.

# 16.1.1 General Purpose Inputs

The current state of the twelve GPIO pins can be read in Section 16.2.2, "GPIO Input Data Register - GPID" on page 723).

Note:

When configured as general purpose inputs, the twelve GPIO pins can be used as up to 12 additional external interrupt inputs dedicated to the Intel<sup>®</sup> XScale<sup>TM</sup> core. This feature is available on a per pin basis simply by programming the INTCTL[1:0] registers.

# 16.1.2 General Purpose Outputs

The output function of the GPIO pins is controlled by two registers, as stated in Section 16.2.3, "GPIO Output Data Register - GPOD" on page 724) and Section 16.2.1, "GPIO Output Enable Register - GPOE" on page 722).

The output enables are mapped on a per bit basis to each of the data bits in the GPIO Output Data Register. When a bit of the GPIO Output Enable Register is cleared, the corresponding data bit value in the GPIO Output Data Register is actively driven on the appropriate GPIO pin.



# 16.1.3 Reset Initialization of General Purpose Input Output Function

The GPIO Input Data Register is initialized to the state of GPIO[7:0] upon assertion of P\_RST#.

The GPIO Output Data Register is initialized to all zeros upon assertion of P\_RST#.

The GPIO Output Enable Register is initialized to FFH upon assertion of **P\_RST#**. This means that **GPIO[7:0]** initializes as inputs.

The **GPIO**[7:0] pins is tristated during **P\_RST**# assertion.

#### 16.1.4 **GPIO** Pin Multiplexing

The GPIO pins are multiplexed with the UART ports as specified in. The selection between GPIO and UART function for these multiplexed pins is controlled by the UART Unit Enable bit (UUE bit 6) of the Section 11.4.3, "UART x Interrupt Enable Register" on page 596.

#### Table 391. GPIO Pin Multiplexing

| GPIO Pin | UART 0 Shared Port | UART 0 Port Signal | Default         |
|----------|--------------------|--------------------|-----------------|
| GPIO[0]  | UART0              | U0_RXD             | GPIO[0] - Input |
| GPIO[1]  | UART0              | U0_TXD             | GPIO[1] - Input |
| GPIO[2]  | UART0              | U0_CTS#            | GPIO[2] - Input |
| GPIO[3]  | UART0              | U0_RTS#            | GPIO[3] - Input |
| GPIO Pin | UART 1 Shared Port | UART 1 Port Signal | Default         |
| GPIO[4]  | UART1              | U1_RXD             | GPIO[4] - Input |
| GPIO[5]  | UART1              | U1_TXD             | GPIO[5] - Input |
| GPIO[6]  | UART1              | U1_CTS#            | GPIO[6] - Input |
| GPIO[7]  | UART1              | U1_RTS#            | GPIO[7] - Input |

720 October, 2003 **Document Number: 273942-002** 



#### 16.2 Register Definitions

All GPIO registers are visible as 80331 memory mapped registers and can be accessed through the internal memory bus. Each is a 32-bit register and is memory-mapped in the Intel<sup>®</sup> XScale core memory space.

The programmer interface to the General Purpose I/O interface is through memory-mapped control registers. Table 392 describes these registers.

#### Table 392. General Purpose I/O Registers Addresses

| Register Name | Description                 | MMR Address |
|---------------|-----------------------------|-------------|
| GPOE          | GPIO Output Enable Register | FFFF F780H  |
| GPID          | GPIO Input Data Register    | FFFF F784H  |
| GPOD          | GPIO Output Data Register   | FFFF F788H  |



#### 16.2.1 GPIO Output Enable Register - GPOE

The GPIO Output Enable Register enables on a per pin basis the output value contained in the GPIO Output Data Register onto the appropriate pin.

The GPIO Output Enable Register is initialized to FFH such that all of **GPIO[7:0]** are inputs.

In order to enable a particular GPIO pin to operate as an output following the deassertion of **P\_RST#**, the user needs to write a '0' into the appropriate GPOE bit.

Table 393. GPIO Output Enable Register - GPOE





#### 16.2.2 GPIO Input Data Register - GPID

The GPIO Input Data Register reflects the state of the appropriate **IRQ** bus pin following the deassertion of **P\_RST**#.

Table 394. GPIO Input Data Register - GPID





#### 16.2.3 GPIO Output Data Register - GPOD

The GPIO Output Data Register is driven on a per bit basis on the appropriate **IRQ** bus pin following the deassertion of **P\_RST#** when the corresponding bit in the GPOE register is cleared.

Table 395. Output Data Register - GPOD





# Peripheral Registers

17

This chapter summarizes the registers for the integrated peripherals (MMR). Each register is defined in detail in the corresponding unit chapter.

#### 17.1 Overview

The Peripheral Registers of the Intel<sup>®</sup> 80331 I/O processor (80331) can be accessed via three methods: the PCI Configuration Register interface, Peripheral Memory-Mapped Register interface and the high performance Intel<sup>®</sup> XScale<sup>™</sup> core (ARM\* architecture compliant) Coprocessor Register interface.

The PCI Configuration Register interface is supported by the PCI interface and PCI Configuration Cycle transaction type. The 80331 does not support access to the PCI Configuration Register Interface by the core processor.

The Peripheral Memory-Mapped Register (PMMR) interface gives software the ability to read and modify internal control registers. Each of these registers is accessed as a memory-mapped 32-bit register with a unique memory address. Access is accomplished through regular memory-format instructions from the Intel<sup>®</sup> XScale Tore.

The Intel<sup>®</sup> XScale<sup>™</sup> core Coprocessor Register (CCR) interface gives software the ability to read and modify internal control registers at a very low latency as compared to the PMMR interface.

These registers are specific to the 80331 only. They support the:

- DMA Controller Unit
- Memory Controller
- Intel<sup>®</sup> XScale<sup>TM</sup> Core Bus Interface Unit
- Interrupt Controller Unit
- Messaging Unit
- Intel® 80331 I/O Processor Arbitration Unit
- UARTs

- Address Translation Unit
- I<sup>2</sup>C Bus Interface Units
- Application Accelerator Unit
- General Purpose I/O Unit
- Peripheral Bus Interface Unit
- I/O Level Control

Each of these peripherals fully describe the independent functionality of the registers, control and usage.

Control and status registers for the Intel<sup>®</sup> XScale<sup>™</sup> core use the CCR interface. Accesses to coprocessor registers do not generate external bus cycles. See the Intel<sup>®</sup> 80200 Processor based on Intel<sup>®</sup> XScale<sup>™</sup> Microarchitecture Developer's Manual (Order Number: 273411) for a full description of the usage of the coprocessor register space in the Intel<sup>®</sup> XScale<sup>™</sup> core. For completeness, these registers are included in the tables of registers for the CCR interface. These registers can only be accessed using the Intel<sup>®</sup> XScale<sup>™</sup> core coprocessor instructions.

The PMMR interface provides full accessibility from the ATU, and the Intel<sup>®</sup> XScale<sup>TM</sup> core. Addresses FFFF E000H through FFFF FFFFH are allocated to the PMMR interface.



#### 17.2 Accessing the PCI Configuration Registers

The 80331 PCI configuration space consists of the PCI-to-PCI bridge and the ATU. Table 396 summarizes the PCI programming model of the I/O processor. The configuration registers of the bridge are not memory mapped, and are only accessible via PCI congruent space from the PCI interface.

The registers of the ATU are both memory mapped and mapped to PCI configuration space. The

Table 396. Intel® 80331 I/O Processor PCI Programming Model

| Bus                 | Device | Function | Unit                     |
|---------------------|--------|----------|--------------------------|
| Primary PCI Bus #   | 0      | 0        | PCI-to-PCI Bridge        |
| Secondary PCI Bus # | 0      | 0        | Address Translation Unit |

ATU registers are listed in the Peripheral Memory Mapped Register section. The configuration registers of the bridge are summarized in the PCI Configuration Register section, including address and access type.

For PCI Configuration Read transactions, the PMMR shall return a value of zero for registers declared as "reserved". For PCI Configuration Write transactions, the PMMR shall discard the data. For all other types of access, reading or writing a register declared as "reserved" is undefined.

#### 17.3 Accessing Peripheral Memory-Mapped Registers

The PMMR interface is a slave device connected to the 80331 internal bus. This interface accepts data transactions which appear on the internal bus from the ATU and the Intel<sup>®</sup> XScale TM core.

The PMMR interface allows these devices to perform read, write, or read-modify-write transactions. The specific actions taken when modifying any value in the PMMR space is independently defined within each chapter which describes the functionality of the register.

Note: The PMMR interface does not support multi-DWORD burst accesses from any internal bus master.

All PMMR transactions are allowed from the Intel<sup>®</sup> XScale<sup>TM</sup> core operating in either user or supervisor mode. In addition, the PMMR does not provide any access exception to the Intel<sup>®</sup> XScale<sup>TM</sup> core.



## 17.4 Accessing Peripheral Registers Using the Core Coprocessor Register Interface

Registers may be accessed/manipulated through the CCR interface with the MCR, MRC, STC, and LDC instructions. The *CRn* field of the instruction denotes the register number to be accessed. The *opcode\_1*, and *opcode\_2* fields of the instruction should be zero. The *CRm* field must be set to 0 for the Interrupt Controller Unit and to 1 for the Programmable Timers. Most systems restricts access to coprocessor registers to privileged processes. To control access to a coprocessor register, use the Coprocessor Access Register as described in the *ARM Architecture Reference Manual* - ARM Limited. Order number: ARM DDI 0100E..

#### 17.5 Architecturally Reserved Memory Space

The 80331 provides 4 Gbytes of address space. Portions of this address space is architecturally reserved and users are restricted as to their function. Figure 117 shows the reserved address space.

Addresses 0000 0000H through 0000 001FH are reserved for the exception vectors of the Intel<sup>®</sup> XScale <sup>™</sup> Core.

Addresses FFFF 0000H through FFFF 001FH are reserved for the relocated exception vectors of the Intel $^{\mathbb{R}}$  XScale $^{\mathbb{T}^{\mathsf{M}}}$  Core.  $^{\mathbb{I}}$ 

Addresses FFFF E000H through FFFF E8FFH are allocated to the PMMR interface. These registers are reserved for 80331 use and should not be written by the system designer.

Addresses FFFF E900H through FFFF FFFFH are allocated for future expansion of the PMMR interface. These registers are reserved for 80331 use and should not be written by the system designer.

**Document Number: 273942-002** October, 2003 727

By enabling the Exception Vector Relocation mode (bit 13, CP15, Register 1), the Exception Vectors (except Reset Vector at 0000 0000H) can be relocated to be based at FFFF 0000H rather than 0000 0000H. (i.e., FIQ Vector located at FFFF 001CH)



Figure 117 shows the  $Intel^{\textcircled{8}}$  XScale  $^{TM}$  Core address space and addresses available to the applications.

Figure 117. Memory Address Space



For a full description of the address space for the Intel<sup>®</sup>  $XScale^{TM}$  core Reset and Exception Vectors, refer to the *ARM Architecture Reference Manual*.

728



#### 17.6 PCI Configuration Register Address Space

The PCI Configuration space is accessible via configuration transactions from the Primary PCI bus interface. The  $Intel^{\circledR}$  XScale core of 80331 does not have access to the bridge configuration space.

Table 397. PCI Configuration Register Locations (Sheet 1 of 2)

| PCI Device        | Register Description (Name)                      | Register<br>Size in<br>Bits | Register<br>Access                                                | PCI<br>Configuration<br>Space Register<br>Number |
|-------------------|--------------------------------------------------|-----------------------------|-------------------------------------------------------------------|--------------------------------------------------|
|                   | Identifiers Register                             | 32                          |                                                                   | 00H                                              |
|                   | Primary Command Register                         | 16                          |                                                                   | 01H                                              |
|                   | Primary Status Register                          | 16                          |                                                                   | 01H                                              |
|                   | Revision ID Register                             | 8                           |                                                                   | 02H                                              |
|                   | Class Code Register                              | 24                          |                                                                   | 02H                                              |
|                   | Cacheline Size Register                          | 8                           |                                                                   | 03H                                              |
|                   | Latency Timer Register                           | 8                           |                                                                   | 03H                                              |
|                   | Header Type Register                             | 8                           |                                                                   | 03H                                              |
|                   | Reserved                                         | 8                           | PCI Standard<br>Configuration<br>Header<br>Device 0<br>Function 0 | 03H                                              |
| 0                 | Reserved                                         | 32                          |                                                                   | 04H                                              |
| PCI-to-PCI Bridge | Reserved                                         | 32                          |                                                                   | 05H                                              |
| Bri               | Bus Number Register                              | 24                          |                                                                   | 06H                                              |
| ပ္                | Secondary Latency Timer Register                 | 8                           |                                                                   | 06H                                              |
| tο-Ε              | I/O Base and Limit Register                      | 16                          |                                                                   | 07H                                              |
| $\dot{\varsigma}$ | Secondary Status Register                        | 16                          |                                                                   | 07H                                              |
| <u>L</u>          | Memory Base and Limit Register                   | 32                          |                                                                   | 08H                                              |
|                   | Prefetchable Memory Base and Limit Register      | 32                          |                                                                   | 09H                                              |
|                   | Prefetchable Memory Base Upper 32-bits Register  | 32                          |                                                                   | 0AH                                              |
|                   | Prefetchable Memory Limit Upper 32-bits Register | 32                          |                                                                   | 0BH                                              |
|                   | I/O Base and Limit Upper 16-bits Register        | 32                          |                                                                   | 0CH                                              |
|                   | Capabilities Pointer Register                    | 8                           |                                                                   | 0DH                                              |
|                   | Reserved                                         | 24                          |                                                                   | 0DH                                              |
|                   | Reserved                                         | 32                          |                                                                   | 0EH                                              |
|                   | Interrupt Information Register                   | 16                          |                                                                   | 0FH                                              |
|                   | Bridge Control Register                          | 16                          |                                                                   | 0FH                                              |



Table 397. PCI Configuration Register Locations (Sheet 2 of 2)

| PCI Device        | Register Description (Name)                              | Register<br>Size in<br>Bits | Register<br>Access                                                | PCI<br>Configuration<br>Space Register<br>Number |
|-------------------|----------------------------------------------------------|-----------------------------|-------------------------------------------------------------------|--------------------------------------------------|
|                   | Diagnostic Control Register                              | 8                           |                                                                   | 10H                                              |
|                   | Secondary Arbiter Control/Status Register                | 16                          |                                                                   | 10H                                              |
|                   | Bridge Control Register 0                                | 8                           |                                                                   | 10H                                              |
|                   | Bridge Control Register 1                                | 16                          |                                                                   | 11H                                              |
|                   | Bridge Control Register 2                                | 16                          |                                                                   | 11H                                              |
|                   | Bridge Status Register                                   | 16                          |                                                                   | 12H                                              |
|                   | Reserved                                                 | 32                          |                                                                   | 13H                                              |
|                   | Bridge Multi-Transaction Timer Register                  | 16                          |                                                                   | 14H                                              |
|                   | Read Prefetch Policy Register                            | 16                          |                                                                   | 14H                                              |
|                   | P_SERR# Assertion Control Register                       | 16                          |                                                                   | 15H                                              |
|                   | Pre-boot Status Register                                 | 8                           |                                                                   | 15H                                              |
|                   | Reserved                                                 | 8                           | PCI Extended<br>Configuration<br>Header<br>Device 0<br>Function 0 | 15H                                              |
|                   | Reserved                                                 | 32                          |                                                                   | 16H                                              |
|                   | Secondary IDSEL Select Register                          | 16                          |                                                                   | 17H                                              |
| ge                | Secondary Decode Enable Register                         | 16                          |                                                                   | 17H                                              |
| 3rid              | Primary Bridge Interrupt Status Register                 | 32                          |                                                                   | 18H                                              |
| <u> </u>          | Secondary Bridge Interrupt Status Register               | 32                          |                                                                   | 19H                                              |
| PCI-to-PCI Bridge | Reserved                                                 | х                           |                                                                   | 20H through<br>36H                               |
| PC                | Power Management Capabilities Identifier Register        | 8                           |                                                                   | 37H                                              |
|                   | Power Management Next Item Pointer Register              | 8                           |                                                                   | 37H                                              |
|                   | Power Management Capabilities Register                   | 16                          | <del>-</del>                                                      | 37H                                              |
|                   | Power Management Control/Status Register                 | 16                          |                                                                   | 38H                                              |
|                   | Power Management Extended Bridge Control/Status Register | 8                           |                                                                   | 38H                                              |
|                   | Reserved                                                 | 8                           |                                                                   | 38H                                              |
|                   | Reserved                                                 | 32                          |                                                                   | 39H                                              |
|                   | Reserved                                                 | 32                          |                                                                   | 3AH                                              |
|                   | Reserved                                                 | 32                          |                                                                   | 3BH                                              |
|                   | PCI-X Capabilities Identifier Register                   | 8                           |                                                                   | 3CH                                              |
|                   | PCI-X Capabilities Next Item Pointer Register            | 8                           | 1                                                                 | 3CH                                              |
|                   | PCI-X Secondary Status Register                          | 16                          | 1                                                                 | 3CH                                              |
|                   | PCI-X Bridge Status Register                             | 32                          |                                                                   | 3DH                                              |
|                   | PCI-X Upstream Split Transaction Control Register        | 32                          | 1                                                                 | 3EH                                              |
|                   | PCI-X Downstream Split Transaction Control Register      | 32                          | 1                                                                 | 3FH                                              |



#### 17.7 Peripheral Memory-Mapped Register Address Space

The PMMR address space is divided to support the integrated peripherals on the 80331. Table 400 shows all of the 80331 integrated peripheral memory-mapped registers and their internal bus addresses.

Table 398. Intel<sup>®</sup> XScale<sup>™</sup> Core Local Addresses Assigned to Integrated Peripherals

| Integrated Peripheral                                          | Internal Address Block        |
|----------------------------------------------------------------|-------------------------------|
| Address Translation Unit                                       | FFFF E100H through FFFF E1FFH |
| Reserved                                                       | FFFF E200H through FFFF E2FFH |
| Messaging Unit                                                 | FFFF E300H through FFFF E3FFH |
| DMA Controller                                                 | FFFF E400H through FFFF E4FFH |
| Memory Controller                                              | FFFF E500H through FFFF E5FFH |
| Intel <sup>®</sup> XScale <sup>™</sup> Core Bus Interface Unit | FFFF E600H through FFFF E67FH |
| Peripheral Bus Interface Unit                                  | FFFF E680H through FFFF E6FFH |
| Peripheral Performance Monitoring Unit                         | FFFF E700H through FFFF E77FH |
| Interrupt Controller Unit                                      | FFFF E780H through FFFF E7EFH |
| Internal Arbitration Unit                                      | FFFF E7F0H through FFFF E7FFH |
| Application Accelerator Unit                                   | FFFF E800H through FFFF E8FFH |
| Reserved                                                       | FFFF E900H through FFFF F4FFH |
| DDR I/O Control                                                | FFFF F500H through FFFF F5FFH |
| Reserved                                                       | FFFF F600H through FFFF F67FH |
| I <sup>2</sup> C Bus Interface Units                           | FFFF F680H through FFFF F6FFH |
| UART Units                                                     | FFFF F700H through FFFF F77FH |
| GPIO Unit                                                      | FFFF F780H through FFFF F7BFH |
| Reserved                                                       | FFFF F7C0H through FFFF F7FFH |
| I/O Pad Control                                                | FFFF F800H through FFFF F8FFH |
| Reserved                                                       | FFFF F900H through FFFF FFFFH |

The memory-mapped registers that are also accessible via PCI configuration transactions are:

• Address Translation Unit

The registers which must have the address translation logic configured to translate PCI addresses into the Intel<sup>®</sup> XScale TM Core address space, to access the memory-mapped registers from the PCI interface are:

- DMA Controllers
- Memory Controller
- I<sup>2</sup>C Bus Interface Unit
- Synchronous Serial Port UART Unit
- Messaging Unit
- Application Accelerator Unit
- Internal Arbitration Unit
- Peripheral Bus Interface Unit
- Performance Monitoring
- Interrupt Controller and General Purpose I/O Unit
- Interface Pad Control Registers



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 1 of 13)

| Peripheral               | Register Description (Name)               | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number |
|--------------------------|-------------------------------------------|-----------------------------|-------------------------------------|--------------------------------------------------|
|                          | Reserved                                  | х                           | FFFF E000H<br>through<br>FFFF E0FFH |                                                  |
|                          | ATU Vendor ID Register                    | 16                          | FFFF E100H                          | 00H                                              |
|                          | ATU Device ID Register                    | 16                          | FFFF E102H                          | 00H                                              |
|                          | ATU Command Register                      | 16                          | FFFF E104H                          | 01H                                              |
|                          | ATU Status Register                       | 16                          | FFFF E106H                          | 01H                                              |
|                          | ATU Revision ID Register                  | 8                           | FFFF E108H                          | 02H                                              |
|                          | ATU Class Code Register                   | 24                          | FFFF E109H                          | 02H                                              |
|                          | ATU Cacheline Size Register               | 8                           | FFFF E10CH                          | 03H                                              |
|                          | ATU Latency Timer Register                | 8                           | FFFF E10DH                          | 03H                                              |
|                          | ATU Header Type Register                  | 8                           | FFFF E10EH                          | 03H                                              |
|                          | BIST Register                             | 8                           | FFFF E10FH                          | 03H                                              |
| nit                      | Inbound ATU Base Address Register 0       | 32                          | FFFF E110H                          | 04H                                              |
| n ∪                      | Inbound ATU Upper Base Address Register 0 | 32                          | FFFF E114H                          | 05H                                              |
| Address Translation Unit | Inbound ATU Base Address Register 1       | 32                          | FFFF E118H                          | 06H                                              |
| ans                      | Inbound ATU Upper Base Address Register 1 | 32                          | FFFF E11CH                          | 07H                                              |
| s Tr                     | Inbound ATU Base Address Register 2       | 32                          | FFFF E120H                          | 08H                                              |
| dres                     | Inbound ATU Upper Base Address Register 2 | 32                          | FFFF E124H                          | 09H                                              |
| Adc                      | Reserved                                  | 32                          | FFFF E128H                          | 0AH                                              |
|                          | ATU Subsystem Vendor ID Register          | 16                          | FFFF E12CH                          | 0BH                                              |
|                          | ATU Subsystem ID Register                 | 16                          | FFFF E12EH                          | 0BH                                              |
|                          | Expansion ROM Base Address Register       | 32                          | FFFF E130H                          | 0CH                                              |
|                          | ATU Capabilities Pointer Register         | 8                           | FFFF E134H                          | 0DH                                              |
|                          | Reserved                                  | 24                          | FFFF E135H                          | 0DH                                              |
|                          | Reserved                                  | 32                          | FFFF E138H                          | 0EH                                              |
|                          | ATU Interrupt Line Register               | 8                           | FFFF E13CH                          | 0FH                                              |
|                          | ATU Interrupt Pin Register                | 8                           | FFFF E13DH                          | 0FH                                              |
|                          | ATU Minimum Grant Register                | 8                           | FFFF E13EH                          | 0FH                                              |
|                          | ATU Maximum Latency Register              | 8                           | FFFF E13FH                          | 0FH                                              |



Table 399. Peripheral Memory-Mapped Register Locations (Sheet 2 of 13)

| Peripheral                                                | Register Description (Name)                          | Register<br>Size in<br>Bits | Internal Bus<br>Address | PCI<br>Configuration<br>Space Register<br>Number |
|-----------------------------------------------------------|------------------------------------------------------|-----------------------------|-------------------------|--------------------------------------------------|
|                                                           | Inbound ATU Limit Register 0                         | 32                          | FFFF E140H              | 10H                                              |
|                                                           | Inbound ATU Translate Value Register 0               | 32                          | FFFF E144H              | 11H                                              |
|                                                           | Expansion ROM Limit Register                         | 32                          | FFFF E148H              | 12H                                              |
|                                                           | Expansion ROM Translate Value Register               | 32                          | FFFF E14CH              | 13H                                              |
|                                                           | Inbound ATU Limit Register 1                         | 32                          | FFFF E150H              | 14H                                              |
|                                                           | Inbound ATU Limit Register 2                         | 32                          | FFFF E154H              | 15H                                              |
|                                                           | Inbound ATU Translate Value Register 2               | 32                          | FFFF E158H              | 16H                                              |
|                                                           | Outbound I/O Window Translate Value Register         | 32                          | FFFF E15CH              | 17H                                              |
|                                                           | Outbound Memory Window Value Register 0              | 32                          | FFFF E160H              | 18H                                              |
|                                                           | Outbound Upper 32-bit Memory Window Value Register 0 | 32                          | FFFF E164H              | 19H                                              |
| Ø                                                         | Outbound Memory Window Value Register 1              | 32                          | FFFF E168H              | 1AH                                              |
| Address Translation Unit Extended Configuration Registers | Outbound Upper 32-bit Memory Window Value Register 1 | 32                          | FFFF E16CH              | 1BH                                              |
| egi                                                       | Reserved                                             | 32                          | FFFF E170H              | 1CH                                              |
| Ε<br>Έ                                                    | Reserved                                             | 32                          | FFFF E174H              | 1DH                                              |
| ratic                                                     | Outbound Upper 32-bit Direct Window Value Register   | 32                          | FFFF E178H              | 1EH                                              |
| ngij                                                      | Reserved                                             | 8                           | FFFF E17CH              | 1FH                                              |
| Con                                                       | Reserved                                             | 8                           | FFFF E17DH              | 1FH                                              |
| o pe                                                      | Reserved                                             | 8                           | FFFF E17EH              | 1FH                                              |
| end                                                       | Reserved                                             | 8                           | FFFF E17FH              | 1FH                                              |
| ŤΧ̈́                                                      | ATU Configuration Register                           | 32                          | FFFF E180H              | 20H                                              |
| Jnit                                                      | PCI Configuration and Status Register                | 32                          | FFFF E184H              | 21H                                              |
| on L                                                      | ATU Interrupt Status Register                        | 32                          | FFFF E188H              | 22H                                              |
| slati                                                     | ATU Interrupt Mask Register                          | 32                          | FFFF E18CH              | 23H                                              |
| rans                                                      | Inbound ATU Base Address Register 3                  | 32                          | FFFF E190H              | 24H                                              |
| ⊥ ss ⊥                                                    | Inbound ATU Upper Base Address Register 3            | 32                          | FFFF E194H              | 25H                                              |
| dres                                                      | Inbound ATU Limit Register 3                         | 32                          | FFFF E198H              | 26H                                              |
| Aq                                                        | Inbound ATU Translate Value Register 3               | 32                          | FFFF E19CH              | 27H                                              |
|                                                           | Reserved                                             | 32                          | FFFF E1A0H              | 28H                                              |
|                                                           | Outbound Configuration Cycle Address Register        | 32                          | FFFF E1A4H              | 29H                                              |
|                                                           | Reserved                                             | 32                          | FFFF E1A8H              | 2AH                                              |
|                                                           | Outbound Configuration Cycle Data Register           | 32                          | FFFF E1ACH              | 2BH                                              |
|                                                           | Reserved                                             | 32                          | FFFF E1B0H              | 2CH                                              |
|                                                           | Reserved                                             | 32                          | FFFF E1B4H              | 2DH                                              |
|                                                           | VPD Capabilities Identifier Register                 | 8                           | FFFF E1B8H              | 2EH                                              |
|                                                           | VPD Next Item Pointer Register                       | 8                           | FFFF F1B9H              | 2EH                                              |
|                                                           | VPD Address Register                                 | 16                          | FFFF F1BAH              | 2EH                                              |
|                                                           | VPD Data Register                                    | 32                          | FFFF F1BCH              | 2FH                                              |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 3 of 13)

| Peripheral             | Register Description (Name)                     | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number |
|------------------------|-------------------------------------------------|-----------------------------|-------------------------------------|--------------------------------------------------|
|                        | Power Management Capability Identifier Register | 8                           | FFFF E1C0H                          | 30H                                              |
|                        | Power Management Next Item Pointer Register     | 8                           | FFFF E1C1H                          | 30H                                              |
|                        | Power Management Capabilities Register          | 16                          | FFFF E1C2H                          | 30H                                              |
|                        | Power Management Control/Status Register        | 16                          | FFFF E1C4H                          | 31H                                              |
|                        | Reserved                                        | 16                          | FFFF E1C6H                          | 31H                                              |
|                        | Reserved                                        | 32                          | FFFF E1C8H                          | 32H                                              |
|                        | Reserved                                        | 32                          | FFFF E1CCH                          | 33H                                              |
|                        | MSI Capability Identifier Register              | 8                           | FFFF E1D0H                          | 34H                                              |
|                        | MSI Next Item Pointer Register                  | 8                           | FFFF E1D1H                          | 34H                                              |
| Address<br>Translation | MSI Message Control Register                    | 16                          | FFFF E1D2H                          | 34H                                              |
| Unit                   | MSI Message Address Register                    | 32                          | FFFF E1D4H                          | 35H                                              |
| Extended<br>Configu-   | MSI Message Upper Address Register              | 32                          | FFFF E1D8H                          | 36H                                              |
| ration                 | MSI Message Data Register                       | 16                          | FFFF E1DCH                          | 37H                                              |
| Registers              | Reserved                                        | 16                          | FFFF E1DEH                          | 37H                                              |
|                        | PCI-X Capability Identifier Register            | 8                           | FFFF E1E0H                          | 38H                                              |
|                        | PCI-X Next Item Pointer Register                | 8                           | FFFF E1E1H                          | 38H                                              |
|                        | PCI-X Command Register                          | 16                          | FFFF E1E2H                          | 38H                                              |
|                        | PCI-X Status Register                           | 32                          | FFFF E1E4H                          | 39H                                              |
|                        | Reserved                                        | 32                          | FFFF E1E8H                          | 3AH                                              |
|                        | PCI Interrupt Routing Select Register           | 32                          | FFFF E1ECH                          | 3BH                                              |
|                        | Reserved                                        |                             | FFFF E1F0H<br>through<br>FFFF E1FFH |                                                  |
|                        | Reserved                                        | х                           | FFFF E200H<br>through<br>FFFF E2FFH |                                                  |



Table 399. Peripheral Memory-Mapped Register Locations (Sheet 4 of 13)

| Peripheral     | Register Description (Name)         | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                                                                                |
|----------------|-------------------------------------|-----------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
|                | Reserved                            | х                           | FFFF E300H<br>through<br>FFFF E30CH | Available through ATU Inbound Translation Window or must translate PCI address to the Intel® XScale™ Core Memory-Mapped Address |
|                | Inbound Message Register 0          | 32                          | FFFF E310H                          | indc<br>s to<br>s to                                                                                                            |
|                | Inbound Message Register 1          | 32                          | FFFF E314H                          | h<br>Ires<br>ore<br>dre                                                                                                         |
|                | Outbound Message Register 0         | 32                          | FFFF E318H                          | Available through<br>I Inbound Translation Winc<br>Ist translate PCI address t<br>Intel® XScale™ Core<br>Memory-Mapped Address  |
|                | Outbound Message Register 1         | 32                          | FFFF E31CH                          | thr<br>nnslans<br>oCl                                                                                                           |
|                | Inbound Doorbell Register           | 32                          | FFFF E320H                          | able<br>Tra<br>ate F<br>XSc<br>Map                                                                                              |
|                | Inbound Interrupt Status Register   | 32                          | FFFF E324H                          | vail<br>und<br>insla<br>el®                                                                                                     |
|                | Inbound Interrupt Mask Register     | 32                          | FFFF E328H                          | nbo<br>t tra<br>Int                                                                                                             |
|                | Outbound Doorbell Register          | 32                          | FFFF E32CH                          | I UI<br>M                                                                                                                       |
|                | Outbound Interrupt Status Register  | 32                          | FFFF E330H                          | AT<br>or n                                                                                                                      |
|                | Outbound Interrupt Mask Register    | 32                          | FFFF E334H                          |                                                                                                                                 |
| Messaging Unit | Reserved                            | х                           | FFFF E338H<br>through<br>FFFF E34FH |                                                                                                                                 |
| agin           | MU Configuration Register           | 32                          | FFFF E350H                          |                                                                                                                                 |
| 9886           | Queue Base Address Register         | 32                          | FFFF E354H                          |                                                                                                                                 |
| Š              | Reserved                            | 32                          | FFFF E358H                          | the                                                                                                                             |
|                | Reserved                            | 32                          | FFFF E35CH                          | s to                                                                                                                            |
|                | Inbound Free Head Pointer Register  | 32                          | FFFF E360H                          | Zore<br>ddr                                                                                                                     |
|                | Inbound Free Tail Pointer Register  | 32                          | FFFF E364H                          | adc<br>P                                                                                                                        |
|                | Inbound Post Head Pointer Register  | 32                          | FFFF E368H                          | PCI                                                                                                                             |
|                | Inbound Post Tail Pointer Register  | 32                          | FFFF E36CH                          | ate XS                                                                                                                          |
|                | Outbound Free Head Pointer Register | 32                          | FFFF E370H                          | ansla<br>itel <sup>®</sup><br>nory                                                                                              |
|                | Outbound Free Tail Pointer Register | 32                          | FFFF E374H                          | t Translate PCI address to<br>Intel® XScale™ Core<br>Memory-Mapped Address                                                      |
|                | Outbound Post Head Pointer Register | 32                          | FFFF E378H                          | Must Translate PCI address to the<br>Intel <sup>®</sup> XScale <sup>™</sup> Core<br>Memory-Mapped Address                       |
|                | Outbound Post Tail Pointer Register | 32                          | FFFF E37CH                          |                                                                                                                                 |
|                | Index Address Register              | 32                          | FFFF E380H                          | 1                                                                                                                               |
|                | Reserved                            | х                           | FFFF E384H<br>through<br>FFFF E3FFH |                                                                                                                                 |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 5 of 13)

| Peripheral     | Register Description (Name)                | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                                                       |
|----------------|--------------------------------------------|-----------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------|
|                | Channel 0 Channel Control Register         | 32                          | FFFF E400H                          |                                                                                                        |
|                | Channel 0 Channel Status Register          | 32                          | FFFF E404H                          |                                                                                                        |
|                | Reserved                                   | 32                          | FFFF E408H                          |                                                                                                        |
|                | Channel 0 Descriptor Address Register      | 32                          | FFFF E40CH                          |                                                                                                        |
|                | Channel 0 Next Descriptor Address Register | 32                          | FFFF E410H                          |                                                                                                        |
|                | Channel 0 PCI Address Register             | 32                          | FFFF E414H                          |                                                                                                        |
|                | Channel 0 PCI Upper Address Register       | 32                          | FFFF E418H                          | -                                                                                                      |
|                | Channel 0 Internal Bus Address Register    | 32                          | FFFF E41CH                          |                                                                                                        |
|                | Channel 0 Byte Count Register              | 32                          | FFFF E420H                          | Must Translate PCI address to the Intel <sup>®</sup> XScale <sup>™</sup> Core<br>Memory-Mapped Address |
|                | Channel 0 Descriptor Control Register      | 32                          | FFFF E424H                          |                                                                                                        |
| DMA Controller | Reserved                                   | х                           | FFFF E428H<br>through<br>FFFF E43FH |                                                                                                        |
| ပိ             | Channel 1 Channel Control Register         | 32                          | FFFF E440H                          |                                                                                                        |
| ΜĀ             | Channel 1 Channel Status Register          | 32                          | FFFF E444H                          | slate<br> ® X<br>ry-N                                                                                  |
|                | Reserved                                   | 32                          | FFFF E448H                          | rang                                                                                                   |
|                | Channel 1 Descriptor Address Register      | 32                          | FFFF E44CH                          | st T                                                                                                   |
|                | Channel 1 Next Descriptor Address Register | 32                          | FFFF E450H                          | M                                                                                                      |
|                | Channel 1 PCI Address Register             | 32                          | FFFF E454H                          | 1                                                                                                      |
|                | Channel 1 PCI Upper Address Register       | 32                          | FFFF E458H                          | 1                                                                                                      |
|                | Channel 1 Internal Bus Address Register    | 32                          | FFFF E45CH                          |                                                                                                        |
|                | Channel 1 Byte Count Register              | 32                          | FFFF E460H                          |                                                                                                        |
|                | Channel 1 Descriptor Control Register      | 32                          | FFFF E464H                          | 1                                                                                                      |
|                | Reserved                                   | х                           | FFFF E468H<br>through<br>FFFF E4FFH |                                                                                                        |



Table 399. Peripheral Memory-Mapped Register Locations (Sheet 6 of 13)

| Peripheral                                           | Register Description (Name)                 | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                            |
|------------------------------------------------------|---------------------------------------------|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------|
|                                                      | SDRAM Initialization Register               | 32                          | FFFF E500H                          |                                                                             |
|                                                      | SDRAM Control Register 0                    | 32                          | FFFF E504H                          |                                                                             |
|                                                      | SDRAM Control Register 1                    | 32                          | FFFF E508H                          |                                                                             |
|                                                      | SDRAM Base Register                         | 32                          | FFFF E50CH                          |                                                                             |
|                                                      | SDRAM Bank 0 Size Register                  | 32                          | FFFF E510H                          |                                                                             |
|                                                      | SDRAM Bank 1 Size Register                  | 32                          | FFFF E514H                          |                                                                             |
|                                                      | SDRAM 32-bit Region Size Register           | 32                          | FFFF E518H                          | -                                                                           |
|                                                      | ECC Control Register                        | 32                          | FFFF E51CH                          |                                                                             |
|                                                      | ECC Log 0 Register                          | 32                          | FFFF E520H                          |                                                                             |
|                                                      | ECC Log 1 Register                          | 32                          | FFFF E524H                          | Φ                                                                           |
|                                                      | ECC Address 0 Register                      | 32                          | FFFF E528H                          | o t                                                                         |
| _                                                    | ECC Address 1 Register                      | 32                          | FFFF E52CH                          | ss t<br>re<br>res                                                           |
| Memory Controller                                    | ECC Test Register                           | 32                          | FFFF E530H                          | Must Translate PCI address to the Intel® XScale™ Core Memory-mapped Address |
| ontr                                                 | Memory Controller Interrupt Status Register | 32                          | FFFF E534H                          |                                                                             |
| O<br>>                                               | Reserved                                    | 32                          | FFFF E538H                          |                                                                             |
| ШОШ                                                  | MCU Port Transaction Count Register         | 32                          | FFFF E53CH                          |                                                                             |
| Me                                                   | MCU Preemption Control Register             | 32                          | FFFF E540H                          |                                                                             |
|                                                      | Refresh Frequency Register                  | 32                          | FFFF E548H                          | St Ti                                                                       |
|                                                      | Reserved                                    | 32                          | FFFF E550H                          | Μ̈́                                                                         |
|                                                      | Reserved                                    | 32                          | FFFF E554H                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E558H                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E55CH                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E560H                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E564H                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E568H                          |                                                                             |
|                                                      | Reserved                                    | 32                          | FFFF E56CH                          |                                                                             |
|                                                      | Reserved                                    | х                           | FFFF E58CH<br>through<br>FFFF E5FFH |                                                                             |
| ē Ħ                                                  | BIU Status Register                         | 32                          | FFFF E600H                          |                                                                             |
| 00 e                                                 | BIU Error Address Register                  | 32                          | FFFF E604H                          |                                                                             |
| cale                                                 | BIU Control Register                        | 32                          | FFFF E608H                          |                                                                             |
| Intel <sup>®</sup> XScale core<br>Bus Interface Unit | Reserved                                    | х                           | FFFF E60CH<br>through<br>FFFF E67FH |                                                                             |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 7 of 13)

| Peripheral                             | Register Description (Name)                | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Registe<br>Number                                   |
|----------------------------------------|--------------------------------------------|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------------|
|                                        | PBI Control Register                       | 32                          | FFFF E680H                          |                                                                                   |
|                                        | Reserved                                   | 32                          | FFFF E684H                          |                                                                                   |
|                                        | PBI Base Address Register 0                | 32                          | FFFF E688H                          |                                                                                   |
|                                        | PBI Limit Register 0                       | 32                          | FFFF E68CH                          | Φ                                                                                 |
| Ξ                                      | PBI Base Address Register 1                | 32                          | FFFF E690H                          | o th                                                                              |
| ë<br>C                                 | PBI Limit Register 1                       | 32                          | FFFF E694H                          | ss t<br>re<br>res                                                                 |
| s Interfac                             | Reserved                                   | х                           | FFFF E698H<br>through<br>FFFF E6BCH | t Translate PCI address to Intel® XScale™ Core Memory-mapped Address              |
| Bu                                     | PBI Memory-less Boot Register 0            | 32                          | FFFF E6C0H                          | XSc<br>mag                                                                        |
| Peripheral Bus Interface Unit          | Reserved                                   | х                           | FFFF E6C4H<br>through<br>FFFF E6DFH | Must Translate PCI address to the<br>Intel® XScale™ Core<br>Memory-mapped Address |
| ш                                      | PBI Memory-less Boot Register 1            | 32                          | FFFF E6E0H                          | Muŝ                                                                               |
|                                        | PBI Memory-less Boot Register 2            | 32                          | FFFF E6E4H                          | _                                                                                 |
|                                        | Reserved                                   | х                           | FFFF E6E8H<br>through<br>FFFF E6FFH |                                                                                   |
|                                        | Global Timer Mode Register                 | 32                          | FFFF E700H                          |                                                                                   |
|                                        | Event Select Register                      | 32                          | FFFF E704H                          |                                                                                   |
|                                        | Event Monitoring Interrupt Status Register | 32                          | FFFF E708H                          |                                                                                   |
|                                        | Reserved                                   | 32                          | FFFF E70CH                          |                                                                                   |
|                                        | Global Time Stamp Register                 | 32                          | FFFF E710H                          |                                                                                   |
| ij                                     | Programmable Event Counter Register 1      | 32                          | FFFF E714H                          |                                                                                   |
| Ď<br>Ö                                 | Programmable Event Counter Register 2      | 32                          | FFFF E718H                          | the                                                                               |
| orin                                   | Programmable Event Counter Register 3      | 32                          | FFFF E71CH                          | to t                                                                              |
| onit                                   | Programmable Event Counter Register 4      | 32                          | FFFF E720H                          | ress                                                                              |
| Θ                                      | Programmable Event Counter Register 5      | 32                          | FFFF E724H                          | add<br>G Ac                                                                       |
| ance                                   | Programmable Event Counter Register 6      | 32                          | FFFF E728H                          | Must Translate PCI address to the Intel® XScale™ Core<br>Memory-Mapped Address    |
| ŗ.                                     | Programmable Event Counter Register 7      | 32                          | FFFF E72CH                          | te F<br>XSα<br>Mag                                                                |
| <sup>2</sup> erfc                      | Programmable Event Counter Register 8      | 32                          | FFFF E730H                          | nsla<br>el <sup>®</sup><br>ory-                                                   |
| ם                                      | Programmable Event Counter Register 9      | 32                          | FFFF E734H                          | Trai<br>Int                                                                       |
| Peripheral Performance Monitoring Unit | Programmable Event Counter Register 10     | 32                          | FFFF E738H                          | ust<br>N                                                                          |
|                                        | Programmable Event Counter Register 11     | 32                          | FFFF E73CH                          | Σ                                                                                 |
|                                        | Programmable Event Counter Register 12     | 32                          | FFFF E740H                          | l                                                                                 |
|                                        | Programmable Event Counter Register 13     | 32                          | FFFF E744H                          | 1                                                                                 |
|                                        | Programmable Event Counter Register 14     | 32                          | FFFF E748H                          | 1                                                                                 |
|                                        | Reserved                                   |                             | FFFF E74CH<br>through<br>FFFF E77FH |                                                                                   |



Table 399. Peripheral Memory-Mapped Register Locations (Sheet 8 of 13)

| Peripheral                          | Register Description (Name)           | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|-------------------------------------|---------------------------------------|-----------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                     | Processor Device ID Register          | 32                          | FFFF E780H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Reserved                              |                             | FFFF E784H                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                     | Reserved                              |                             | FFFF E788H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Reserved                              |                             | FFFF E78CH                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                     | Interrupt Control Register 0          | 32                          | FFFF E790H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Interrupt Control Register 1          | 32                          | FFFF E794H                          | <u>ə</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                     | Interrupt Steer Register 0            | 32                          | FFFF E798H                          | 5 to 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| ı,                                  | Interrupt Steer Register 1            | 32                          | FFFF E79CH                          | Must Translate PCI address to the<br>Intel <sup>®</sup> XScale <sup>™</sup> Core<br>Memory-mapped Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Interrupt Controller,<br>and Timers | IRQ Interrupt Source Register 0       | 32                          | FFFF E7A0H                          | Add Add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| rrupt Contro<br>and Timers          | IRQ Interrupt Source Register 1       | 32                          | FFFF E7A4H                          | S ale a ped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| ipt C<br>id Ti                      | FIQ Interrupt Source Register 0       | 32                          | FFFF E7A8H                          | e P(<br>(Sc;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| erru                                | IRQ Interrupt Source Register 1       | 32                          | FFFF E7ACH                          | slate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| Int                                 | Interrupt Priority Register 0         | 32                          | FFFF E7B0H                          | rans<br>Inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                     | Interrupt Priority Register 1         | 32                          | FFFF E7B4H                          | St T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                                     | Interrupt Priority Register 2         | 32                          | FFFF E7B8H                          | M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                     | Interrupt Priority Register 3         | 32                          | FFFF E7BCH                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Interrupt Base Register               | 32                          | FFFF E7C0H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Interrupt Size Register               | 32                          | FFFF E7C4H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | IRQ Interrupt Vector Register         | 32                          | FFFF E7C8H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | FIQ Interrupt Vector Register         | 32                          | FFFF E7CCH                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Timer Mode Register 0                 | 32                          | FFFF E7D0H                          | <u>ə</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                     | Timer Mode Register 1                 | 32                          | FFFF E7D4H                          | to the sign of the |  |
|                                     | Timer Count Register 0                | 32                          | FFFF E7D8H                          | ess e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| <b>±</b>                            | Timer Count Register 1                | 32                          | FFFF E7DCH                          | Add C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| Timer Unit                          | Timer Reload Register 0               | 32                          | FFFF E7E0H                          | Sla<br>ale ale                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| mer                                 | Timer Reload Register 1               | 32                          | FFFF E7E4H                          | Sc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| F                                   | Timer Interrupt Status Register       | 32                          | FFFF E7E8H                          | slate<br>® Xt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                                     | Watch Dog Timer Control Register      | 32                          | FFFF E7ECH                          | Must Translate PCI address to the Intel® XScale ™ Core Memory-mapped Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                     | Internal Arbitration Control Register | 32                          | FFFF E7F0H                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                     | Multi-Transaction Timer Register 1    | 32                          | FFFF E7F4H                          | s the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| Internal Arbitration Unit           | Multi-Transaction Timer Register 2    | 32                          | FFFF E7F8H                          | iss tre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                                     | Reserved                              | х                           | FFFF E7FCH<br>through<br>FFFF E7FFH | Must Translate PCI address to the<br>Intel <sup>®</sup> XScale <sup>™</sup> Core<br>Memory-mapped Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 9 of 13)

| Peripheral                   | Register Description (Name)                  | Register<br>Size in<br>Bits | Internal Bus<br>Address | PCI<br>Configuration<br>Space Register<br>Number                            |
|------------------------------|----------------------------------------------|-----------------------------|-------------------------|-----------------------------------------------------------------------------|
|                              | Accelerator Control Register                 | 32                          | FFFF E800H              |                                                                             |
|                              | Accelerator Status Register                  | 32                          | FFFF E804H              | 1                                                                           |
|                              | Accelerator Descriptor Address Register      | 32                          | FFFF E808H              | 1                                                                           |
|                              | Accelerator Next Descriptor Address Register | 32                          | FFFF E80CH              | -                                                                           |
|                              | Accelerator Source Address 1 Register        | 32                          | FFFF E810H              | 1                                                                           |
|                              | Accelerator Source Address 2 Register        | 32                          | FFFF E814H              | 1                                                                           |
|                              | Accelerator Source Address 3 Register        | 32                          | FFFF E818H              | 1                                                                           |
|                              | Accelerator Source Address 4 Register        | 32                          | FFFF E81CH              | -                                                                           |
|                              | Destination Address Register                 | 32                          | FFFF E820H              | -                                                                           |
|                              | Accelerator Byte Count Register              | 32                          | FFFF E824H              | -                                                                           |
|                              | Accelerator Descriptor Control Register      | 32                          | FFFF E828H              | 1                                                                           |
|                              | Accelerator Source Address 5 Register        | 32                          | FFFF E82CH              | -                                                                           |
|                              | Accelerator Source Address 6 Register        | 32                          | FFFF E830H              | Must Translate PCI address to the Intel® XScale™ Core Memory-mapped Address |
| Application Accelerator Unit | Accelerator Source Address 7 Register        | 32                          | FFFF E834H              |                                                                             |
| ator                         | Accelerator Source Address 8 Register        | 32                          | FFFF E838H              |                                                                             |
| ele ra                       | Extended Descriptor Control Register 0       | 32                          | FFFF E83CH              |                                                                             |
| Acce.                        | Accelerator Source Address 9 Register        | 32                          | FFFF E840H              | PCI<br>scale                                                                |
| on /                         | Accelerator Source Address 10 Register       | 32                          | FFFF E844H              | ate<br>XS<br>-m.                                                            |
| cati                         | Accelerator Source Address 11 Register       | 32                          | FFFF E848H              | ansk<br>tel®<br>nory                                                        |
| ilda                         | Accelerator Source Address 12 Register       | 32                          | FFFF E84CH              | t Tra                                                                       |
| ⋖                            | Accelerator Source Address 13 Register       | 32                          | FFFF E850H              | Aust                                                                        |
|                              | Accelerator Source Address 14 Register       | 32                          | FFFF E854H              |                                                                             |
|                              | Accelerator Source Address 15 Register       | 32                          | FFFF E858H              |                                                                             |
|                              | Accelerator Source Address 16 Register       | 32                          | FFFF E85CH              |                                                                             |
|                              | Extended Descriptor Control Register 1       | 32                          | FFFF E860H              |                                                                             |
|                              | Accelerator Source Address 17 Register       | 32                          | FFFF E864H              |                                                                             |
|                              | Accelerator Source Address 18 Register       | 32                          | FFFF E868H              |                                                                             |
|                              | Accelerator Source Address 19 Register       | 32                          | FFFF E86CH              | ]                                                                           |
|                              | Accelerator Source Address 20 Register       | 32                          | FFFF E870H              |                                                                             |
|                              | Accelerator Source Address 21 Register       | 32                          | FFFF E874H              |                                                                             |
|                              | Accelerator Source Address 22 Register       | 32                          | FFFF E878H              |                                                                             |
|                              | Accelerator Source Address 23 Register       | 32                          | FFFF E87CH              |                                                                             |
|                              | Accelerator Source Address 24 Register       | 32                          | FFFF E880H              |                                                                             |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 10 of 13)

| Peripheral  | Register Description (Name)            | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                                       |
|-------------|----------------------------------------|-----------------------------|-------------------------------------|----------------------------------------------------------------------------------------|
|             | Extended Descriptor Control Register 2 | 32                          | FFFF E884H                          |                                                                                        |
|             | Accelerator Source Address 25 Register | 32                          | FFFF E888H                          | the                                                                                    |
|             | Accelerator Source Address 26 Register | 32                          | FFFF E88CH                          | s to                                                                                   |
|             | Accelerator Source Address 27 Register | 32                          | FFFF E890H                          | ldress<br>Core<br>Addre                                                                |
| Application | Accelerator Source Address 28 Register | 32                          | FFFF E894H                          | address to the<br>Core<br>d Address                                                    |
| Accelerator | Accelerator Source Address 29 Register | 32                          | FFFF E898H                          | t Translate PCI address to<br>Intel <sup>®</sup> XScale" Core<br>Memory-mapped Address |
| Unit        | Accelerator Source Address 30 Register | 32                          | FFFF E89CH                          | XSc<br>XSc<br>ma                                                                       |
|             | Accelerator Source Address 31 Register | 32                          | FFFF E8A0H                          | nsla<br>tel®<br>ory-                                                                   |
|             | Accelerator Source Address 32 Register | 32                          | FFFF E8A4H                          | Tra<br>Int                                                                             |
|             | Reserved                               | х                           | FFFF E8A8H<br>through<br>FFFF E8FFH | Must Translate PCI g<br>Intel <sup>®</sup> XScale<br>Memory-mappe                      |
|             | Reserved                               | х                           | FFFF E900H<br>through<br>FFFF EFFFH |                                                                                        |
|             | Reserved                               | х                           | FFFF F000H<br>through<br>FFFF F4FFH |                                                                                        |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 11 of 13)

| Peripheral      | Register Description (Name)                   | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                               |
|-----------------|-----------------------------------------------|-----------------------------|-------------------------------------|--------------------------------------------------------------------------------|
|                 | DCAL Control and Status Register              | 32                          | FFFF F500H                          |                                                                                |
|                 | DCAL Address Register                         | 32                          | FFFF F504H                          |                                                                                |
|                 | DCAL Data Register 0                          | 32                          | FFFF F508H                          |                                                                                |
|                 | DCAL Data Register 1                          | 32                          | FFFF F50CH                          |                                                                                |
|                 | DCAL Data Register 2                          | 32                          | FFFF F510H                          |                                                                                |
|                 | DCAL Data Register 3                          | 32                          | FFFF F514H                          |                                                                                |
|                 | DCAL Data Register 4                          | 32                          | FFFF F518H                          |                                                                                |
|                 | DCAL Data Register 5                          | 32                          | FFFF F51CH                          |                                                                                |
|                 | DCAL Data Register 6                          | 32                          | FFFF F520H                          |                                                                                |
|                 | DCAL Data Register 7                          | 32                          | FFFF F524H                          |                                                                                |
|                 | DCAL Data Register 8                          | 32                          | FFFF F528H                          |                                                                                |
|                 | DCAL Data Register 9                          | 32                          | FFFF F52CH                          | <u>ə</u>                                                                       |
|                 | DCAL Data Register 10                         | 32                          | FFFF F530H                          | to t                                                                           |
| _               | DCAL Data Register 11                         | 32                          | FFFF F534H                          | ess i                                                                          |
| ntrol           | DCAL Data Register 12                         | 32                          | FFFF F538H                          | Must Translate PCI address to the Intel® XScale™ Core<br>Memory-mapped Address |
| DDR I/O Control | DCAL Data Register 13                         | 32                          | FFFF F53CH                          |                                                                                |
| 9               | DCAL Data Register 14                         | 32                          | FFFF F540H                          |                                                                                |
| DR.             | DCAL Data Register 15                         | 32                          | FFFF F544H                          |                                                                                |
|                 | DCAL Data Register 16                         | 32                          | FFFF F548H                          |                                                                                |
|                 | DCAL Data Register 17                         | 32                          | FFFF F54CH                          |                                                                                |
|                 | Receive Enable Delay Register                 | 32                          | FFFF F550H                          |                                                                                |
|                 | Slave Low Mix 0                               | 32                          | FFFF F554H                          |                                                                                |
|                 | Slave Low Mix 1                               | 32                          | FFFF F558H                          |                                                                                |
|                 | Slave High Mix 0                              | 32                          | FFFF F55CH                          |                                                                                |
|                 | Slave High Mix 1                              | 32                          | FFFF F560H                          |                                                                                |
|                 | Slave Length                                  | 32                          | FFFF F564H                          |                                                                                |
|                 | Master Mix                                    | 32                          | FFFF F568H                          |                                                                                |
|                 | Master Length                                 | 32                          | FFFF F56CH                          |                                                                                |
|                 | DDR Drive Strength Status Register            | 32                          | FFFF F570H                          |                                                                                |
|                 | DDR Drive Strength Control Register           | 32                          | FFFF F574H                          |                                                                                |
|                 | DDR Miscellaneous Pad Control Register        | 32                          | FFFF F578H                          | 1                                                                              |
|                 | Reserved                                      | 32                          | FFFF F57CH                          | 1                                                                              |
|                 | PBI Drive Strength Control Register           | 32                          | FFFF F580H                          |                                                                                |
|                 | Reserved                                      | х                           | FFFF F584H<br>through<br>FFFF F5BFH |                                                                                |
| ō               | Secondary PCI Drive Strength Control Register | 32                          | FFFF F5C0H                          |                                                                                |
| onti            | Reserved                                      | 32                          | FFFF F5C4H                          |                                                                                |
| 0               | Primary PCI Drive Strength Control Register   | 32                          | FFFF F5C8H                          | 1                                                                              |
| PCI I/O Control | Reserved                                      | 32                          | FFFF F5CCH                          |                                                                                |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 12 of 13)

| Peripheral                        | Register Description (Name)                            | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Registe<br>Number                                   |  |
|-----------------------------------|--------------------------------------------------------|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------------|--|
|                                   | Reserved                                               | х                           | FFFF F5D0H<br>through<br>FFFF F67FH |                                                                                   |  |
|                                   | I <sup>2</sup> C Control Register 0                    | 32                          | FFFF F680H                          |                                                                                   |  |
|                                   | I <sup>2</sup> C Status Register 0                     | 32                          | FFFF F684H                          |                                                                                   |  |
|                                   | I <sup>2</sup> C Data Buffer Register 0                | 32                          | FFFF F68CH                          |                                                                                   |  |
|                                   | Reserved                                               | 32                          | FFFF F690H                          | фe                                                                                |  |
|                                   | I <sup>2</sup> C Bus Monitor Register 0                | 32                          | FFFF F694H                          | to                                                                                |  |
|                                   | Reserved                                               | 32                          | FFFF F698H                          | ress                                                                              |  |
| 120.5                             | Reserved                                               | 32                          | FFFF F69CH                          | A Ac                                                                              |  |
| I <sup>2</sup> C Bus<br>Interface | I <sup>2</sup> C Control Register 1                    | 32                          | FFFF F6A0H                          | CL                                                                                |  |
| Units                             | I <sup>2</sup> C Status Register 1                     | 32                          | FFFF F6A4H                          | t Translate PCI address to<br>Intel® XScale™ Core<br>Memory-mapped Address        |  |
|                                   | I <sup>2</sup> C Slave Address Register 1              | 32                          | FFFF F6A8H                          | nsla<br>el <sup>®</sup><br>ory-                                                   |  |
|                                   | I <sup>2</sup> C Data Buffer Register 1                | 32                          | FFFF F6ACH                          | Trar<br>Int                                                                       |  |
|                                   | Reserved                                               | 32                          | FFFF F6B0H                          | Must Translate PCI address to the Intel® XScale™ Core Memory-mapped Address       |  |
|                                   | I <sup>2</sup> C Bus Monitor Register 1                | 32                          | FFFF F6B4H                          |                                                                                   |  |
|                                   | Reserved                                               | х                           | FFFF F6B8H<br>through<br>FFFF F6FFH |                                                                                   |  |
|                                   | UART 0 Receive Buffer Register (Read Only) (DLAB=0)    | 32                          |                                     |                                                                                   |  |
|                                   | UART 0 Transmit Holding Register (Write Only) (DLAB=0) | 32                          | FFFF F700H                          |                                                                                   |  |
|                                   | UART 0 baud Divisor Latch Low byte (DLAB=1)            | 8                           |                                     |                                                                                   |  |
|                                   | UART 0 Interrupt Enable Register (DLAB=0)              | 8                           | EEEE E30.411                        | o the                                                                             |  |
|                                   | UART 0 baud Divisor Latch High byte (DLAB=1)           | 8                           | FFFF F704H                          |                                                                                   |  |
|                                   | UART 0 Interrupt ID Register (Read Only)               | 8                           |                                     |                                                                                   |  |
|                                   | UART 0 FIFO Control Register (Write Only)              | 8                           | FFFF F708H                          | ss to                                                                             |  |
| 0   0                             | UART 0 Line Control Register                           | 8                           | FFFF F70CH                          | dre<br>Cor                                                                        |  |
| UART Channel 0                    | UART 0 Modem Control Register                          | 8                           | FFFF F710H                          | ad<br>_ed<br>ed ,                                                                 |  |
| Č                                 | UART 0 Line Status Register                            | 8                           | FFFF F714H                          | PC<br>Scal<br>app                                                                 |  |
| Ä                                 | UART 0 Modem Status Register                           | 8                           | FFFF F718H                          | ® X X Y-m X                                                                       |  |
| N                                 | UART 0 Scratch Pad Register                            | 8                           | FFFF F71CH                          | Must Translate PCI address to the<br>Intel® XScale™ Core<br>Memory-mapped Address |  |
|                                   | Reserved                                               | 32                          | FFFF F720H                          |                                                                                   |  |
|                                   | UART 0 FIFO Occupancy Register                         | 8                           | FFFF F724H                          |                                                                                   |  |
|                                   | UART 0 Autobaud Control Register                       | 8                           | FFFF F728H                          | 1 _                                                                               |  |
|                                   | UART 0 Autobaud Count Register                         | 16                          | FFFF F72CH                          | 1                                                                                 |  |
|                                   | Reserved                                               |                             | FFFF F730H<br>through<br>FFFF F73FH |                                                                                   |  |



 Table 399.
 Peripheral Memory-Mapped Register Locations (Sheet 13 of 13)

| Peripheral     | Register Description (Name)                            | Register<br>Size in<br>Bits | Internal Bus<br>Address             | PCI<br>Configuration<br>Space Register<br>Number                                  |
|----------------|--------------------------------------------------------|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------------|
|                | UART 1 Receive Buffer Register (Read Only) (DLAB=0)    | 32                          |                                     |                                                                                   |
|                | UART 1 Transmit Holding Register (Write Only) (DLAB=0) | 32                          | FFFF F740H                          |                                                                                   |
|                | UART 1 baud Divisor Latch Low byte (DLAB=1)            | 8                           |                                     |                                                                                   |
|                | UART 1 Interrupt Enable Register (DLAB=0)              | 8                           | FFFF F744H                          |                                                                                   |
|                | UART 1 baud Divisor Latch High byte (DLAB=1)           | 8                           | FFFF F/44FI                         |                                                                                   |
|                | UART 1 Interrupt ID Register (Read Only)               | 8                           | FFFF F74011                         |                                                                                   |
|                | UART 1 FIFO Control Register (Write Only)              | 8                           | FFFF F748H                          |                                                                                   |
| UART Channel 1 | UART 1 Line Control Register                           | 8                           | FFFF F74CH                          | d)                                                                                |
| ann            | UART 1 Modem Control Register                          | 8                           | FFFF F750H                          | #                                                                                 |
| <u>ප</u>       | UART 1 Line Status Register                            | 8                           | FFFF F754H                          | Must Translate PCI address to the<br>Intel® XScale™ Core<br>Memory-mapped Address |
| ۱              | UART 1 Modem Status Register                           | 8                           | FFFF F758H                          |                                                                                   |
| á              | UART 1 Scratch Pad Register                            | 8                           | FFFF F75CH                          |                                                                                   |
|                | Reserved                                               | 32                          | FFFF F760H                          |                                                                                   |
|                | UART 1 FIFO Occupancy Register                         | 8                           | FFFF F764H                          |                                                                                   |
|                | UART 1 Autobaud Control Register                       | 8                           | FFFF F768H                          |                                                                                   |
|                | UART 1 Autobaud Count Register                         | 16                          | FFFF F76CH                          |                                                                                   |
|                | Reserved                                               | х                           | FFFF F770H<br>through<br>FFFF F77FH | Mus                                                                               |
|                | GPIO Output Enable Register                            | 32                          | FFFF F780H                          |                                                                                   |
|                | GPIO Input Data Register                               | 32                          | FFFF F784H                          |                                                                                   |
|                | GPIO Output Data Register                              | 32                          | FFFF F788H                          |                                                                                   |
| GPIO           | Reserved                                               | 32                          | FFFF F78CH                          |                                                                                   |
|                | Reserved                                               | х                           | FFFF F790H<br>through<br>FFFF F7FFH | 1                                                                                 |
|                | Reserved                                               | х                           | FFFF F800H<br>through<br>FFFF F9FFH |                                                                                   |



#### 17.8 Coprocessor Register Space

The CCR address space is assigned to support the integrated peripherals on the 80331 that require low latency register access. Table 400 shows all of the 80331 integrated coprocessor registers and assigned coprocessor space. The *ARM Architecture Reference Manual* - ARM Limited. Order number: ARM DDI 0100E. provides for a total of 16 coprocessors each of which can contain up to 256 32 bit registers. For completeness, the coprocessor space reserved by the *ARM Architecture Reference Manual* - ARM Limited. Order number: ARM DDI 0100E. is shown.

All accesses to coprocessor registers that are not implemented have 'unpredictable' behavior and are designated as 'undefined' in the register table. Accesses to these registers results in an undefined instruction exception.

#### Table 400. Intel<sup>®</sup> XScale<sup>™</sup> Core Coprocessor Registers Assigned to Integrated Peripherals

| Integrated Peripheral            | Coprocessor |
|----------------------------------|-------------|
| Interrupt Control Unit           | CP6         |
| Programmable Timers              | CP6         |
| Core Performance Monitoring Unit | CP14        |
| System Control <sup>a</sup>      | CP15        |

a. Reserved by the ARM Architecture Reference Manual - ARM Limited. Order number: ARM DDI 0100E..



 Table 401.
 Coprocessor Register Locations (Sheet 1 of 2)

| Peripheral               | Register Description (Name)      | Coprocessor | Field CR <sub>m</sub> | Coprocessor<br>Register<br>(Field <i>CR<sub>n</sub></i> ) |
|--------------------------|----------------------------------|-------------|-----------------------|-----------------------------------------------------------|
|                          | Interrupt Control Register 0     |             |                       | Register 0                                                |
|                          | Interrupt Control Register 1     |             |                       | Register 1                                                |
|                          | Interrupt Steering Register 0    |             |                       | Register 2                                                |
|                          | Interrupt Steering Register 1    |             |                       | Register 3                                                |
|                          | IRQ Interrupt Source Register 0  |             |                       | Register 4                                                |
| nit                      | IRQ Interrupt Source Register 1  |             |                       | Register 5                                                |
| n<br>o                   | FIQ Interrupt Source Register 0  |             |                       | Register 6                                                |
| Interrupt Control Unit   | FIQ Interrupt Source Register 1  |             | 0                     | Register 7                                                |
| ŏ                        | Interrupt Priority Register 0    |             | 0                     | Register 8                                                |
| rrup                     | Interrupt Priority Register 1    |             |                       | Register 9                                                |
| Inte                     | Interrupt Priority Register 2    |             |                       | Register 10                                               |
|                          | Interrupt Priority Register 3    |             |                       | Register 11                                               |
|                          | Interrupt Base Register          |             |                       | Register 12                                               |
|                          | Interrupt Size Register          | CP6         |                       | Register 13                                               |
|                          | IRQ Interrupt Vector Register    |             |                       | Register 14                                               |
|                          | FIQ Interrupt Vector Register    |             |                       | Register 15                                               |
|                          | Timer Mode Register 0            |             |                       | Register 0                                                |
| . <del>±</del>           | Timer Mode Register 1            |             |                       | Register 1                                                |
| n<br>L                   | Timer Count Register 0           |             |                       | Register 2                                                |
| ners                     | Timer Count Register 1           |             |                       | Register 3                                                |
| Η̈́                      | Timer Reload Register 0          |             |                       | Register 4                                                |
| able                     | Timer Reload Register 1          |             | 1                     | Register 5                                                |
| шű                       | Timer Interrupt Status Register  |             |                       | Register 6                                                |
| grar                     | Watch Dog Timer Control Register |             |                       | Register 7                                                |
| Programmable Timers Unit | Undefined                        |             |                       | Register 8<br>through<br>Register 15                      |



Table 401. Coprocessor Register Locations (Sheet 2 of 2)

| Peripheral                       | Register Description (Name)                            | Coprocessor | Field CR <sub>m</sub>       | Coprocessor<br>Register<br>(Field <i>CR<sub>n</sub></i> ) |
|----------------------------------|--------------------------------------------------------|-------------|-----------------------------|-----------------------------------------------------------|
|                                  | Performance Monitor Control Register                   |             |                             | Register 0                                                |
|                                  | Clock Count Register                                   | 1           |                             | Register 1                                                |
|                                  | Performance Count Register 0                           |             |                             | Register 2                                                |
|                                  | Performance Count Register 1                           | 1           |                             | Register 3                                                |
| Core Performance Monitoring Unit | Reserved                                               |             |                             | Register 4<br>and<br>Register 5                           |
| itori                            | Core Clock Configuration Register (CCLKCFG)            |             |                             | Register 6                                                |
| Mon                              | Reserved                                               |             |                             | Register 7                                                |
| ce<br>Ce                         | Access Transmit Debug Register (TX)                    | CP14        | CP14 Function               | Register 8                                                |
| nan                              | Access Receive Debug Register (RX)                     |             |                             | Register 9                                                |
| Perforr                          | Access Debug Control and Status Register (DBGCSR)      |             |                             | Register 10                                               |
| ore F                            | Access Trace Buffer Register (TBREG)                   |             |                             | Register 11                                               |
|                                  | Access Checkpoint 0 Register (CHKPT0)                  |             |                             | Register 12                                               |
|                                  | Access Checkpoint 1 Register (CHKPT1)                  |             |                             | Register 13                                               |
|                                  | Access Transmit and Receive Debug Control Register     |             |                             | Register 14                                               |
|                                  | Debug Saved Program Status Register                    |             |                             | Register 15                                               |
|                                  | ID and Cache Type Registers                            |             |                             | Register 0                                                |
|                                  | Control and Auxiliary Control Registers                |             |                             | Register 1                                                |
|                                  | Translation Table Base Register                        | •           |                             | Register 2                                                |
|                                  | Domain Access Control Register                         |             |                             | Register 3                                                |
|                                  | Undefined                                              |             |                             | Register 4                                                |
|                                  | Fault Status Register                                  |             |                             | Register 5                                                |
| <u>s</u>                         | Fault Address Register                                 | ]           |                             | Register 6                                                |
| ontro                            | Cache Operations Register                              | 1           |                             | Register 7                                                |
| ဝိ                               | TLB Operations Register                                | CP15        | CP 15 Function <sup>a</sup> | Register 8                                                |
| System Controls                  | Cache Lock Down                                        | 1           |                             | Register 9                                                |
| Sys                              | TLB Lock Down                                          | 1           |                             | Register 10                                               |
|                                  | Reserved                                               |             |                             | Register 11<br>and<br>Register 12                         |
|                                  | Process ID Register                                    | 1           |                             | Register 13                                               |
|                                  | Breakpoint Registers                                   | 1           |                             | Register 14                                               |
|                                  | CP Access (PID) Coprocessor Access Control<br>Register |             |                             | Register 15                                               |

a. Some of the CP15 registers are differentiated by the Opcode\_2 field. For CP15, the CR<sub>m</sub> is used in some cases to denote different control functions for a given coprocessor register rather than a distinct register decode. Please refer to the Intel<sup>®</sup> 80200 Processor based on Intel<sup>®</sup> XScale<sup>™</sup> Microarchitecture Developer's Manual (Order Number: 273411), for more details on the operation of CP15.



### This Page Intentionally Left Blank



# intel® Clocking and Reset

This chapter describes the clocking and reset function. The intent of this chapter is to elaborate and clarify descriptions of the clocking and reset mechanisms.

#### 18.1 **Clocking Overview**

The Intel® 80331 I/O processor (80331) contains various clocking boundaries internally. The clocks for all of the units within the 80331 are generated from a single input clock. Clock regions are buffered or PLL versions of this clock input for the processor design. This input feeds the Phase Lock Loop (PLL) circuitry which generates the internal clocks for all clock regions.

The block diagram of the 80331 shown in Figure 118, highlights the six clocking regions for this processor.

Intel® 80331 I/O Processor Clocking Regions Diagram Figure 118.



Within each of the clocking regions identified exist various clock requirements for the 80331 units and for the output clocks pins provided for the external subsystem.



#### 18.1.1 Clocking Theory of Operation

Each region within the 80331 contains different clocking requirements. These requirements are summarized in the following sections.

#### 18.1.2 Clocking Region 1

Region 1 is the Intel<sup>®</sup> XScale<sup>™</sup> core (ARM\* architecture compliant). It supports clock frequencies up to a maximum of 800 MHz operation. Region 1 also incudes the core interface of the Intel<sup>®</sup> XScale<sup>™</sup> core Bus Interface Unit. The region 1 clock is an integer multiple of one-half the frequency of the DDR SDRAM clocks of Region 2. The creates a synchronous architecture between the Bus Interface Unit and Memory Controller Unit for minimal latency between the Core processor and DDR SDRAM.

#### 18.1.3 Clocking Region 2

Region 2 provides six DDR SDRAM output clocks, and the clocking for the Memory Controller Unit. The clocking unit contains three output clocks, called **M\_CLK[2:0]**, and three complement clock outputs called **M\_CLK[2:0]**#. The **M\_CLK[2:0]** and **M\_CLK[2:0]**# outputs are used by the DDR SDRAM memory subsystem. It supports clock frequencies up to a maximum of 333 MHz operation for DDR333 SDRAM.

#### 18.1.4 Clocking Region 3

Region 3 covers the 80331 internal bus. It supports clock frequencies up to 266 MHz. The IOP units interface to or reside in this region. Units which interface to this clock region include the Intel<sup>®</sup> XScale <sup>™</sup> core Bus Interface Unit, the Memory Controller Unit, Interrupt Controller, Timers, ATU, MU, Performance Monitor Unit and the bridge interface to the AHB bus. Units which reside in this clock region, and are based entirely on clock region 3 clocking include DMA units, AAU unit, and the Peripheral Bus interface. The peripheral bus interface operates at one-quarter of the Internal Bus frequency or 66MHz.

#### 18.1.5 Clocking Region 4

Region 4 obtains its input clock from the clocking unit specified in clocking region 3. This region is for use by low-speed peripheral units. Currently, these include the I<sup>2</sup>C bus interface, the General Purpose I/O unit and the UART serial bus interface.

Region 4 contains an output clock (SCL) used for the I<sup>2</sup>C bus interface (see Chapter 10, "I<sup>2</sup>C Bus Interface Units"). The SCL clock frequency for I<sup>2</sup>C operation is 100 KHz or 400 KHz. SCL is generated from the internal bus clock. In order to use the I<sup>2</sup>C interface, a clock divider value must be written into the I<sup>2</sup>C Clock Count Register. The UART input clock is driven at 33.334 MHz, and divided within the unit for the serial interface baud rate.



#### 18.1.6 Clocking Region 5

Region 5 covers the Secondary PCI bus, and obtains its input clock **S\_CLKIN** as the board level feedback of from the **S\_CLKOUT** output clock. Region 5 also generates four secondary PCI bus segment output clocks the 80331 based on a dedicated PLL. Eight of these output clocks, **S\_CLKO[3:0]** are used to drive the Primary PCI input clocks of secondary PCI devices attached to the 80331 secondary PCI interfaces and the, **S\_CLKOUT** used as the reference clock to this region's PCI interface. This region is the secondary PCI interface for 80331 and meets clocking requirements as specified in *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a. This region supports clock frequencies up to 133 MHz.

This region also includes the PCI interface of the ATU.

#### 18.1.7 Clocking Region 6

Region 6 covers the Primary PCI bus, and obtains its input clock **P\_CLK** as the Primary PCI interface reference clock. This region is the primary PCI interface for 80331 and meets clocking requirements as specified in *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0a. This region supports clock frequencies up to 133 MHz.

Region 6 is the main input clock for the Intel<sup>®</sup> 80331 I/O processor. The clocks for all regions one through 6 are generated by the **P\_CLK** input clock of this region.



#### 18.1.8 Output Clocks

Table 402 shows the loading requirements for each of the output clocks. Refer to the respective JEDEC specifications for the DDR and DDR-II clock skew and loading requirements for the DDR and DDR-II SDRAM devices. Refer to the *PCI Local Bus Specification*, Revision 2.3 (e.g., 33 MHz, 66 MHz) and the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0 (e.g., 66 MHz, 100 MHz, 133 MHz) for details on PCI bus clock loading requirements.

#### **Table 402.** Output Clocks Loading Summary

| Pin         | Minimum        | Maximum        |
|-------------|----------------|----------------|
| M_CLK[2:0]  | tbd pF + Trace | tbd pF + Trace |
| M_CLK[2:0]# | tbd pF + Trace | tbd pF + Trace |
| P_CLK       | tbd pF + Trace | tbd pF + Trace |
| S_CLKOUT    | tbd pF + Trace | tbd pF + Trace |
| S_CLKO[3:0] | tbd pF + Trace | tbd pF + Trace |
| SCL         | tbd pF + Trace | tbd pF + Trace |



#### 18.1.9 Clocking Region Summary

Table 403 summarizes all of the input clock pins, output clock pins, and clock strapping option pins used in the .

#### Table 403. Clock Pin Summary

| Pin              | Input/Output | Description                                                                            |
|------------------|--------------|----------------------------------------------------------------------------------------|
| P_CLK            | Input        | Primary PCI Input Clock                                                                |
| S_CLKO[3:0]      | Output       | Secondary PCI Output Clocks                                                            |
| S_CLKOUT         | Output       | Secondary PCI Output Reference Clock                                                   |
| S_CLKIN          | Input        | Secondary PCI Reference Clock Input                                                    |
| P_M66EN, S_M66EN | Input        | PCI 66 MHz Enable                                                                      |
| S_PCIX133EN      | Input        | Reset Strap to Limit Secondary Clock<br>Frequency to 100MHz or 133MHz in PCI-X<br>Mode |
| M_CLK[2:0]       | Output       | SDRAM Output Clocks                                                                    |
| M_CLK[2:0]#      | Output       | Complementary SDRAM Output Clocks                                                      |
| SCL[1:0]         | Output       | I <sup>2</sup> C Output Clocks                                                         |



Table 404 summarizes all of the clocks generated to the six regions within the 80331. The clock units initializes appropriately based on the PCI-X initialization pattern driven during the rising edge of **P\_RST#**.

#### Table 404. Intel® 80331 I/O Processor Clock Region Summary

| Region | Interface                   | Unit                                        | Frequencies                                                               |         |         |  |
|--------|-----------------------------|---------------------------------------------|---------------------------------------------------------------------------|---------|---------|--|
| 1      |                             | Intel <sup>®</sup> XScale <sup>™</sup> core | 500 MHz                                                                   | 667 MHz | 800 MHz |  |
| 2      | DDR SDRAM                   | MCU                                         | 333 MHz                                                                   | 333 MHz | N/A     |  |
| 2      | DDR-II SDRAM                | MCO                                         | 400 MHz                                                                   | N/A     | 400 MHz |  |
| 3      | Internal Bus                | DMA[1:0], AAU,<br>ATU                       | 266 MHz                                                                   |         |         |  |
| 3      | Peripheral Bus<br>Interface | PBI                                         | 66 MHz                                                                    |         |         |  |
|        |                             | I <sup>2</sup> C                            | 33 MHz                                                                    |         |         |  |
| 4      | AHB                         | UART                                        | 33.334 MHz                                                                |         |         |  |
|        |                             | GPIO                                        | 33 MHz                                                                    |         |         |  |
| 5      | Secondary PCI               | Secondary PCI side of Bridge                | 33, 66, 100, 133MHz based on PCI reset strapping and initiation sequence. |         |         |  |
| 6      | Primary PCI                 | Primary PCI side of Bridge                  | 33, 66, 100, 133MHz based on PCI reset strapping and initiation sequence. |         |         |  |



#### 18.2 Reset Overview

There are four levels of reset for the 80331. The main reset is controlled through the Primary PCI bus reset signal (**P\_RST#**). When this signal is asserted, the entire 80331 is placed in a reset state. In addition to the reset pin, the 80331 provides software control of internal units such as the PCI-to-PCI Bridge, Internal Bus, and Intel<sup>®</sup> XScale<sup>TM</sup> core.

The 80331 four levels of reset are:

- P\_RST# this is an asynchronous reset to 80331 resets the entire chip. All reset straps are sampled at the falling edge of P\_RST#.
- Software PCI Reset this reset is initiated by writing to bridge control register of the PCI configuration space. This is also commonly referred to as the SBR (Secondary Bus Reset). As the I/O processor is integrated to the secondary PCI bus of 80331, all I/O processor units and registers are also reset by the Secondary Bus Reset.
- Internal Bus Reset this reset is initiated by writing to ATU control register in PCI configuration space. This reset is specific to the integrated I/O processor and the associated peripheral units. This reset may also be generated by the expiration of the Watch Dog Timer as described in Section 14.1.2, "Watch Dog Timer Operation" on page 662.
- Intel<sup>®</sup> XScale<sup>™</sup> core reset this reset is initiated by two mechanisms. First is the
   CORE\_RST# reset strap, and the other is via software through ATU control register in PCI
   configuration space.

Figure 119 shows the logical block diagram of the reset conditions.

Figure 119. Intel® 80331 I/O Processor Reset Block Diagram



755



#### 18.2.1 Primary PCI Bus Reset Mechanism

The **P\_RST**# reset clears all internal state machines and logic, and initialize all registers to their default states. The assertion and deassertion of the PCI reset signal **P\_RST**# is asynchronous with respect to P\_CLK. The rising edge of the **P\_RST**# signal must be monotonic through the input switching range and must meet the minimum slew rate. The PCI local bus specifications define the assertion of **P\_RST**# for a period of 1 ms after power is stable.

Upon the assertion of **P\_RST#**, all units within the 80331 are reset including the bridge and I/O processor units. The affects on the units beyond the bridge are described in Section 18.2.3, "I/O Processor Reset" on page 757.

Upon the deassertion of **P\_RST#**, the 80331 samples a series of strapping pins to set configuration modes (refer to Section 18.3, "Reset Strapping Options" on page 762).

#### 18.2.2 Software PCI Reset Mechanism

This reset is initiated by a write to the bridge control register and resets the secondary PCI segment and is often referred to as the Secondary Bus Reset (SBR). This reset can be used for various reasons in including recovering from error conditions on the secondary bus, to redo enumeration, to change the operating frequency of the bus (33/66/100/133 MHz), to change the operating mode of the bus (PCI or PCI-X) etc. This reset is synchronous to the PCI clock domain. Writes to the bridge control register with a new frequency etc, has no effect until the SBR happens. The power up frequency of the PCI bus is shown in Table 2.2.4, "Bus Mode and Frequency Initialization" on page 46. The frequency depends on the M66EN and the PCIXCAP pins.

The I/O processor units of 80331, as a device on the secondary PCI bus segment, is completely reset by a SBR. Refer to Section 18.2.3, "I/O Processor Reset" on page 757 for details of the I/O processor reset.



## 18.2.3 I/O Processor Reset

Those reset mechanisms which assert secondary bus reset, results in a reset of the I/O processor in addition to the additional reset actions described in the respective reset mechanism descriptions above.

When the I/O processor is reset by the Secondary Bus Reset signal S\_RST#, the I/O processor:

- resets the internal bus, refer to Section 18.2.4, "Internal Bus Reset" on page 758.
- resets the Intel<sup>®</sup> XScale<sup>TM</sup> core, refer to Section 18.2.5, "Intel<sup>®</sup> XScale<sup>TM</sup> core Reset Mechanism" on page 761
- resets all internal units
- · resets all Memory Mapped Registers
- all configuration straps are not affected by S\_RST#, refer to Section 18.3.

The assertion and deassertion of the PCI reset signal (S\_RST#) is asynchronous with respect to **P\_CLK**. The rising edge of the S\_RST# signal must be monotonic through the input switching range and must meet the minimum slew rate. The *PCI Local Bus Specification*, Revision 2.3 defines the assertion of S\_RST# for a period of 1 ms after power is stable.

Upon the assertion of S\_RST#, all units within the 80331, excluding the bridge are reset. This reset resets all internal memory mapped registers (MMRs) to their default configuration state. The reset value for each register is defined within each register description.

Upon the deassertion of S\_RST#, the 80331 samples a series of strapping pins to set configuration modes (refer to Section 18.3, "Reset Strapping Options" on page 762). One strap which alters the behavior of the 80331 on the deassertion of S\_RST# is the CORE\_RST# strap (refer to Section 18.2.5, "Intel<sup>®</sup> XScale<sup>TM</sup> core Reset Mechanism" on page 761).



## 18.2.4 Internal Bus Reset

The Reset Internal Bus bit in the PCI Configuration and Status Register (see Table 125, "PCI Configuration and Status Register - PCSR" on page 253) resets the Intel<sup>®</sup> XScale <sup>™</sup> core and all units on the internal bus. Expiration of the Watch Dog Timer as described in Section 14.1.2, "Watch Dog Timer Operation" on page 662 also results in the same internal bus reset.

Before resetting, the ATU shall gracefully halt all PCI bus transactions when operating in PCI mode. Following an Internal Bus Reset when the PCI Bus is operating in PCI-X mode, the ATU may allow Split Completion transactions due to Outbound Split Requests to Master Abort. Also, the ATU may not initiate all of the Split Completion transactions required by any outstanding Inbound Split Requests at the time of the Internal Bus Reset.

While the *PCI-X Addendum to the PCI Local Bus Specification*, Revision 1.0 requires host software to gracefully handle both these cases without reinitializing the PCI bus, the user may want to avoid this scenario. This can be done by taking the following steps:

- 1. Disable the ATU from either claiming or initiating new transactions by clearing the *Bus Master Enable* and the *Memory Enable* in the ATU Command Register (see Section 3.10.3, "ATU Command Register ATUCMD" on page 214).
- 2. Monitor the *Inbound Read Transaction Queue Status* and the *Outbound Read Transaction Queue Status* in the PCSR.
- 3. When both the Inbound Read Transaction queue and the Outbound Read Transaction queue are empty, software writes to the PCSR to initiate the Internal Bus Reset.

It is the responsibility of the software to ensure that the  $I^2C$  bus and UART are idle before the reset occurs. The Intel<sup>®</sup> XScale<sup>TM</sup> core may or may not be held in reset when the Reset Internal Bus bit is cleared by software. This depends on the **CORE\_RST**# strap as described in section Section 18.2.5.

Expiration of the Watch Dog Timer does not result in a graceful Internal Bus Reset, as the queues, I<sup>2</sup>C bus and UART may be active when the reset occurs.

When the Internal Bus Reset is initiated there are sideband signals notifying the ATU that a reset is coming. The following describes the operation of each unit:



# Table 405. Internal Bus Reset Summary (Sheet 1 of 2)

| Unit    | Preparation for Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset Status                                                                              |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| UM/MU   | Preparation for Reset  The ATU and MU detect via a sideband signal that a internal bus reset is coming. Upon detecting this signal, the ATU and MU complete the following:  PCI Interface Outbound Transaction:  When the ATU has already asserted its PCI request signal, and not yet started a transaction, the ATU deasserts its request and not start its transaction.  When the ATU has not yet requested the PCI bus, the ATU never asserts its request for the PCI bus.  When the ATU is in the middle of a transaction, the ATU performs the existing transaction. This means that an outbound write, the ATU transfers as much data as available in the queue. When an outbound read, the ATU reads the data until the transaction stops naturally (meaning that the target has ended the transaction or the ATU has read all of the data it has been requested to read). Once terminated by the ATU or the target, the ATU no longer requests the PCI bus.  In PCI-X mode, the ATU allows any outstanding split completions due to prior outstanding Split Requests to Master-Abort on the PCI Bus. Since, the IOP is only accessing Prefetchable Memory on the host, no error condition is created in the system.  PCI Interface Inbound Transaction:  Once the ATU and MU have detected that an internal bus reset is coming, they no longer claim any new transactions on the PCI bus. This results in a master abort to the initiating master.  In PCI-X mode, this may mean that data from an outstanding split request may not be returned to the host. It is the responsibility of the host software to handle this condition as a consequence of writing to the Internal Bus Reset bit.  The other requirement for the inbound ATU is to complete the configuration space. In PCI-X Mode this means returning a Split Completion Message to the host indicating that the write has completed.  Internal Bus Interface: Inbound Transaction:  The ATU and MU go ahead and assert their IB request | Clear all ATU and MU interrupts and HPIs. All ATU and MU MMRs reset to the default value. |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                           |
|         | Internal Bus Interface: Outbound Transaction:  • For all ATU and MU outbound transactions, there are no special requirements since the BIU/Core/DMA is reset.  Upon meeting both the outbound and inbound transaction requirements, the ATU and MU assert the sideband signal to the reset unit notifying ready-for-reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                           |
| DMA0/1/ | No special requirements. DMA can be reset at any time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Clear all interrupts and HPIs. All DMA MMRs reset to the default value.                   |



# Table 405. Internal Bus Reset Summary (Sheet 2 of 2)

| Unit             | Preparation for Reset                                                                                                                                                   | Reset Status                                                                                                                                                                                                        |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| BIU              | No special requirements. BIU can be reset at any time.                                                                                                                  | Clear all interrupts and HPIs. The<br>BIU behaves as the Core after<br>reset. Meaning, the CORE_RST#<br>reset strap determines when the<br>core is to be held in reset. All BIU<br>mmrs reset to the default value. |  |
| AA               | No special requirements. AA can be reset at any time.                                                                                                                   | Clear all interrupts and HPIs. All AA MMRs reset to the default value.                                                                                                                                              |  |
| IB-ARB           | No special requirements. IB-ARB can be reset at any time.                                                                                                               | Clear all interrupts and HPIs. All IB-ARB MMRs reset to the default value.                                                                                                                                          |  |
| I <sup>2</sup> C | No special requirements. $I^2C$ can be reset at any time. When the $I^2C$ is in the middle of a transmission, the protocol may be violated when the $I^2C$ unit resets. | Clear all interrupts and HPIs. All I <sup>2</sup> C MMRs reset to the default value.                                                                                                                                |  |
| UART             | No special requirements. UART can be reset at any time. When the UART is in the middle of a transmission, the protocol may be violated when the UART unit resets.       | Clear all interrupts and HPIs. All UART MMRs reset to the default value.                                                                                                                                            |  |
| MCU              | No special requirements. MCU can be reset at any time.                                                                                                                  | Clear all interrupts and HPIs. All MCU MMRs reset to the default value. <b>M_RST#</b> is asserted.                                                                                                                  |  |
| PBI              | No special requirements. PBI can be reset at any time.                                                                                                                  | Clear all interrupts and HPIs. All PBI MMRs reset to the default value.                                                                                                                                             |  |



# 18.2.5 Intel<sup>®</sup> XScale<sup>™</sup> core Reset Mechanism

This reset is initiated the **CORE\_RST#** reset strap, and exited via software through ATU PCSR register in PCI configuration space. Upon the de-assertion of the reset signal, the **CORE\_RST#** is sampled as described in Section 18.3, "Reset Strapping Options" on page 762. When asserted, the Intel<sup>®</sup> XScale core processor is held in the reset state. Software is required to clear this bit to deassert Intel<sup>®</sup> XScale core reset. Software cannot set this bit.

# 18.2.6 Reset Summary

### Table 406. Reset Summary

| Reset Source                  | Affected Resets                                   | Affected Units                                                                                                          |
|-------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| P_RST#                        | All                                               | Full Chip including Reset Straps                                                                                        |
| Secondary Bus Reset           | S_RST#, <b>I_RST#</b>                             | Secondary bridge logic (not configuration register) and all IOP units.                                                  |
| Internal Bus Reset bit in ATU | I_RST#                                            | All IOP units                                                                                                           |
| Watch Dog Timer Expiration    | P_RST#                                            | Full chip. Applies only in no bridge mode with arbiter and central resources enabled (BRG_EN is low and ARB_EN is high) |
|                               | I_RST#                                            | All IOP units. Applies to all other modes for 80331                                                                     |
| CORE_RST#                     | Intel <sup>®</sup> XScale <sup>™</sup> core reset | Intel <sup>®</sup> XScale <sup>™</sup> core                                                                             |



# 18.3 Reset Strapping Options

There are many initialization modes that can be selected when the processor is reset. Table 407 shows the configuration modes. All of the configuration modes defined are determined on the rising edge of **P\_RST#**.

Upon the deassertion of **P\_RST**#, the 80331 samples a series of strapping pins to set configuration modes. One strap which alters the behavior of the 80331 on the deassertion of **P\_RST**# is the **CORE\_RST**# strap. When the **CORE\_RST**# pin is asserted on the rising edge of **P\_RST**#, the 80331 continues to assert the individual reset to the Intel<sup>®</sup> XScale core. This mode, holds the Intel<sup>®</sup> XScale core in reset until the Core Processor Reset Bit in the PCI Configuration and Status Register (ATU) is cleared, thus allowing the Intel<sup>®</sup> XScale core to enter its initialization procedure.

The Primary PCI interface of the 80331 samples the **P\_REQ64#** signal to determine when 80331 is connected to a 64-bit data path. The central resource is required to drive the **P\_REQ64#** signal low during the time that **P\_RST#** is asserted. The state of **P\_REQ64#** on the rising edge of the **P\_RST#** signal notifies 80331 PCI-to-PCI Bridge primary bus interface it is connected to a 64-bit or 32-bit PCI bus. Similarly, the PCI interface of the ATU is integrated to the Secondary PCI bus of 80331 and therefore samples the **S\_REQ64#** signal to determine when the secondary bus is connected to a 64-bit external data path.



The remaining reset straps are sampled similarly and are described in Table 407 below.

# Table 407. Reset Strap Signals (Sheet 1 of 2)

| NAME                       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| AD[4] / <b>P_BOOT16#</b>   | Bus Width: <b>P_BOOT16#</b> is latched at the rising edge of <b>P_RST#</b> and it indicates the default bus width for the PBI Memory Boot window.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| AD[4]/1_BOOTIO#            | 0 = 16 bits wide (Default mode).<br>1 = 8 bits wide (Requires pull-up resistor).                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| AD[6] / RETRY              | Configuration Retry Mode: <b>RETRY</b> is latched at the rising edge of <b>P_RST#</b> and it determines when the PCI interface of the ATU disables PCI configuration cycles by signaling a Retry until the Configuration Cycle Retry bit is cleared in the PCI Configuration and Status Register.                                                                                                                                                                                                                                     |  |  |
|                            | 0 = Configuration Cycles enabled (Requires pull-down resistor). 1 = Configuration Retry enabled (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| AD[5] / CORE_RST#          | RESET MODE is latched at the rising edge of <b>P_RST#</b> and it determines when the Intel <sup>®</sup> XScale <sup>™</sup> core is held in reset until the Intel <sup>®</sup> XScale Processor Reset bit is cleared in the PCI Configuration and Status Register.                                                                                                                                                                                                                                                                    |  |  |
|                            | 0 = Hold in reset (Requires pull-down resistor).<br>1 = Don't hold in reset (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| ADIOL/MEM TYPE             | Memory Frequency: <b>MEM_TYPE</b> is latched at the rising edge of <b>P_RST#</b> and it indicates the speed of the DDR SDRAM interface.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| AD[2] / MEM_TYPE           | 0 = DDR-II SDRAM @ 400MHz (Requires pull-down resistor).<br>1 = DDR SDRAM @ 333MHz (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| AD[3] / <b>S_PCIX133EN</b> | Secondary PCI Bus Segment 133MHz Enable: <b>S_PCIX133EN</b> is latched at the rising edge of <b>P_RST#</b> and it determines the maximum PCI-X mode operating frequency.                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                            | 0 = 100MHz enabled (Requires pull-down resistor).<br>1 = 133MHz enabled (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| AD[1]/ARB_EN               | Internal Arbiter Enable: ARB_EN is latched at the rising edge of P_RST# and it determines when the PCI interface enables the integrated arbiter and central resource support, or use an external arbiter and external clock input. This arbiter and central resource support includes the four S_REQ#/S_GNT# arbitration pairs, the four S_CLKO[3:0] output clocks, the S_CLKOUT/S_CLKIN reference clock output/input signals and driving the appropriate PCI interface reset pattern. Applicable only when the BRG_EN is pulled low. |  |  |
|                            | 0 = Internal Arbiter/Central Resource disabled (Requires pull-down resistor). 1 = Internal Arbiter/Central Resource enabled (Default mode).                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| AD[20] / PCIODT_EN         | PCI Bus ODT ENABLE: PCIODT_EN is latched on the rising edge of P_RST# and it determines when the PCI-X interface has On Die Termination enabled. PCI ODT enable is valid for 80331 secondary PCI bus only.                                                                                                                                                                                                                                                                                                                            |  |  |
|                            | 0 = ODT disabled (Requires pull-down resistor).<br>1 = ODT enabled (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| A[2]/ <b>P_32BITPCI#</b>   | 32 BIT PCI: <b>P_32BITPCI#</b> is latched at the rising edge of <b>P_RST#</b> and it indicates the width of the Primary PCI-X bus to the PCI-X Status Register.                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                            | 0 = 32 Bit PCI-X Bus (Requires pull-down resistor).<br>1 = 64 Bit PCI-X Bus (Default mode).                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |



# Table 407. Reset Strap Signals (Sheet 2 of 2)

| NAME                  | DESCRIPTION                                                                                                                                                                                                     |  |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| A[1] / PRIVMEM        | Private Memory Enable: <b>PRIVMEM</b> is latched at the rising edge of <b>P_RST#</b> and it determines when the 80331 operates with the Private Memory Space on the secondary PCI bus of the PCI-to-PCI Bridge. |  |  |
|                       | <ul><li>0 = Normal addressing mode. (Requires pull-down resistor)</li><li>1 = Private Addressing enable in PCI-to-PCI Bridge. (Default mode).</li></ul>                                                         |  |  |
| A[0] / PRIVDEV        | Private Device Enable: <b>PRIVDEV</b> is latched at the rising edge of <b>P_RST#</b> and it determines when the 80331 operates with Private Device enabled on the secondary PCI bus of the PCI-to-PCI Bridge.   |  |  |
|                       | <ul> <li>0 = All Secondary PCI devices are accessible to Primary PCI configure cycles.<br/>(Requires pull-down resistor)</li> <li>1 = Private Devices enabled in PCI-to-PCI Bridge. (Default mode).</li> </ul>  |  |  |
| AD[0] / <b>BRG_EN</b> | No Bridge Mode: <b>BRG_EN</b> is latched at the rising edge of <b>P_RST#</b> and it determines when the 80331 operates with the PCI-to-PCI Bridge.                                                              |  |  |
|                       | <ul> <li>0 = Disable bridge, enable external arbiter on S_REQ0#/S_GNT[0]# pins, enable P_CLK input on S_CLKIN input. (Requires pull-down resistor).</li> <li>1 = Normal 80331 mode (Default mode).</li> </ul>   |  |  |



# Test Logic Unit and Testability

19

# 19.1 Overview

This chapter summarizes the testability features (DFT) that are incorporated in theIntel<sup>®</sup> 80331 I/O processor. The Test Logic Unit (TLU) is based on the IEEE 1149.1a *Standard Test Access Port and Boundary-Scan Architecture* and supports boundary scan.

# 19.2 Test Control/Observe Pins

The following table lists the complete set of test pins required.

#### Table 408. Test Control/Observe Pins

| Pin Name | I/O | Test Purpose                                                                                                                             |
|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| тск      | I   | Test Clock. Input clock for the test logic defined by IEEE1149.1Std. Maximum frequency: 200 MHz                                          |
| TDI      | I   | Test Data Input. TAP controller defined by IEEE1149.1 Std receives serial test instructions and data via this pin.                       |
| TDO      | 0   | Test Data Output. TAP controller defined by IEEE1149.1 Std sends the serial output from the instruction and data registers via this pin. |
| тмѕ      | I   | Test Mode Select. TAP controller defined by IEEE1149.1 decodes the signal received at this pin to <b>TMS</b> to control test operations. |
| TRST#    | I   | Test Reset. The optional TRST# input provides for asynchronous initialization of the TAP controller.                                     |

**Document Number: 273942-002** October, 2003 765



# 19.3 IEEE 1149.1 Standard Test Access Port (TAP)

The IOP contains test logic that is compatible with the IEEE Standard 1149.1-1990 Test Access Port (TAP) and Boundary Scan Architecture. Logic that conforms to this standard contains the following:

- 1. A Test Access Port (TAP) four inputs (**TDI**, **TMS**, **TRST**# and TCLK) and a single output (**TDO**).
- 2. A TAP controller.
- 3. An instruction register.
- 4. A group of test data registers.

Each of these is described in more detail below. Figure 120 shows a generic diagram for logic conforming to the IEEE 1149.1 test standard.

Figure 120. IEEE 1149.1 Standard. Block Diagram





# 19.3.1 TAP Pin Description

The internal test logic is accessed through the TAP pins. The following sections describe some of the rules and permissions of the IEEE 1149.1a Standard for the TAP pins.

# **19.3.1.1 Test Clock (TCK)**

This is the clock input for the test logic defined by this standard, i.e. the TAP controller and associated registers. The TLU is a fully static design, thus all registers retain their states indefinitely when **TCK** is stopped at "0" or "1".

## 19.3.1.2 Test Mode Select (TMS)

This pin is used to control the operation of the TAP controller. The signal received at **TMS** is decoded by the TAP controller to control test operations. The state of **TMS** is sampled on the rising edge of **TCK**. Internally, there is a weak pull-up on this pin to provide a logic high when not driven, per standard definition.

### 19.3.1.3 Test Data Input (TDI)

This pin is used to provide serial input data to the instruction and test data registers. Data at **TDI** is sampled on the rising edge of **TCK**. Data shifted from **TDI** through a register to **TDO** appears non-inverted at **TDO** after a number of rising and falling edges of **TCK** determined by the length of the instruction or test data register selected. Internally, there is a weak pull-up on this pin to provide a logic high when not driven, per standard definition.

# 19.3.1.4 Test Data Output (TDO)

This is the serial data output pin. Changes in the state of **TDO** occur only following the falling edge of **TCK** while performing a shift operation. This pin is only driven while scanning (in SHDR or SHIR states) otherwise it is in inactive (high Z) state. The non-shift inactive state is provided to support parallel connection of **TDO** outputs at the board or module level.

#### 19.3.1.5 Asynchronous Reset (TRST#)

The **TRST**# signal is used to asynchronously reset the TAP controller and boundary-scan registers. The TAP controller is not initialized by any other system input, including system reset. The TAP controller initializes asynchronously on the falling edge of **TRST**# to the Test-Logic-Reset (initial) state. The TAP controller is initialized at power-up by cirrostrati built into the test logic. Upon reset, the TAP instruction register initializes to the IDCODE instruction. Internally, there is a weak pull-up on this pin to provide a logic high when not driven.



## 19.3.2 TAP Controller

The TAP controller, shown in Figure 122, is a sixteen-state synchronous finite state machine that changes state on the rising edge of **TCK**. The controller's next state is controlled by the state present at the **TMS** input. The TAP controller generates control signals, which together with **TCK** and control signals decoded from the instruction active in the instruction register, determine the operation of the test circuitry as defined by the IEEE Standard.

All state transitions occur based on the values of TMS on the rising edge of TCK Actions of the test logic (instruction register, data registers, etc.) occur on either the rising or falling edge of TCK, as show in Figure 121.. See the description of each state to learn which.

Figure 121. Timing of Actions in a TAP Controller State



For greater detail on the state machine and the public instructions, refer to IEEE 1149.1a Standard Test Access Port and Boundary-Scan Architecture Specification.



Figure 122. TAP Controller State Diagram



# 19.3.2.1 Test-Logic-Reset State

In this state, test logic is disabled to allow normal operation of the IOP. This is achieved by loading the instruction register with the IDCODE instruction. No matter what he state of the controller, it enters Test-Logic-Reset state when the **TMS** input is held high for at least five rising edges of **TCK**. The controller remains in this state while **TMS** is high. The TAP controller is also forced to enter this state by enabling **TRST**#.

When the controller exits the Test-Logic-Reset controller state as a result of an erroneous low signal on the **TMS** line at the time of a rising edge on **TCK** (for example, a glitch due to external interference), it returns to the Test-Logic-Reset state following three rising edges of **TCK** with the **TMS** line at the intended high logic level. Test logic operation is such that no disturbance is caused to on-chip system logic operation as the result of such an error.

Transition to next state: On the rising edge of **TCK**, when **TMS** is low move to Run-Test/Idle, else **TMS** remains high so stay in Reset.



#### 19.3.2.2 Run-Test/Idle State

This state is a controller state between scan operations. The controller remains in this state as long as TMS is held low. In the Run-Test/Idle state, activity in selected test logic occurs only when certain instructions are present. Instructions that do not cause functions to execute generate no activity in the test logic while the controller is in this state.

The instruction register and all test data registers retain their current value in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, move to Select-DR-Scan, else remain in Idle.

#### 19.3.2.3 Select-DR-Scan State

This is a temporary controller state. Here the decision is made to enter the Capture-DR column and initiate a scan sequence for the selected test data register.

All test data registers selected by the current instruction retain their previous value in this state.

Transition to next state: When **TMS** is low on the rising edge of **TCK**, move to Capture-DR, else move to Select-IR.

## 19.3.2.4 Capture-DR State

When the controller is in this state data is parallel-loaded into test data registers selected by the current instruction on the rising edge of **TCK**. Test data registers that do not have parallel inputs are not changed. Also when capturing is not required for the selected instruction, the register retains its previous state.

The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is low on the rising edge of **TCK**, move to Shift-DR, else move to Exit1-DR.

#### 19.3.2.5 Shift-DR State

In this controller state, the test data register, which is connected between **TDI** and **TDO** as a result of the current instruction, shifts data one bit position nearer to its serial output on each rising edge of **TCK**. Test data registers that the current instruction select but do not place in the serial path, retain their previous value during this state.

The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, move to Exit1-DR, else remain at Shift-DR.

Document Number: 273942-002



#### 19.3.2.6 Exit1-DR State

This is a temporary controller state.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is held high on the rising edge of **TCK**, the controller enters the Update-DR state and the scanning process terminates. When **TMS** is held low on the rising edge of **TCK**, the controller enters the Pause-DR state.

#### 19.3.2.7 Pause-DR State

The Pause-DR state allows the test controller to temporarily halt the shifting of data through the test data register in the serial path between **TDI** and **TDO**.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, move to the Exit2-DR, else remain at Pause-DR.

#### 19.3.2.8 Exit2-DR State

This is a temporary state.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, the controller enters the Update-DR state and the scanning process terminates. When TMS is held low on the rising edge of **TCK**, the controller re-enters the Shift-DR state

#### 19.3.2.9 Update-DR State

Data is latched into the parallel output of shift registers from the shift register path, on the falling edge of **TCK**.

All of the test data register's shift-register bit positions selected by the current instruction retain their previous values. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** remains high on the rising edge of **TCK**, then the controller moves to the Select-DR state, else the controller moves to the Run-Test/Idle state.

#### 19.3.2.10 Select-IR-Scan State

This is a temporary controller state. Here the decision is made to enter the Capture-IR column and initiate a scan sequence for the instruction register or to return to Test-Logic-Reset.

All test data registers selected by the current instruction retain their previous value during this state.

Transition to next state: When **TMS** is low on the rising edge of **TCK**, move to Capture-IR, else move to Test-Logic-Reset.



## 19.3.2.11 Capture-IR State

In this state, the shift register contained in the instruction register loads the fixed value  $0000001_2$  on the rising edge of **TCK**.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is low on the rising edge of **TCK**, move to Shift-IR, else move to Exit1-IR.

#### 19.3.2.12 Shift-IR State

In this state, the shift register contained in the instruction register is connected between **TDI** and **TDO** and shifts data one bit position nearer to its serial output on each rising edge of **TCK**.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, move to Exit1-IR, else remain at Shift-IR.

## 19.3.2.13 Exit1-IR State

This is a temporary state.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high during the next rising edge of **TCK**, the controller enters the Update-IR state and the scanning process terminates. When **TMS** is held low during the next rising edge of **TCK**, the controller enters the Pause-IR state.

#### 19.3.2.14 Pause-IR State

This state allows the TAP controller to temporarily halt the shifting of data through the instruction register.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is high on the rising edge of **TCK**, move to Exit2-IR, else remain in the Pause-IR state.

#### 19.3.2.15 Exit2-IR State

This is a temporary state.

All test data registers selected by the current instruction retain their previous value during this state. The instruction does not change while the TAP controller is in this state.

Transition to next state: When **TMS** is held high during the next rising edge of **TCK**, the controller enters the Update-IR state and the scanning process terminates. When **TMS** is held low during the next rising edge of **TCK**, the controller re-enters the Shift-IR state



# 19.3.2.16 Update-IR State

The instruction shifted into the instruction register is latched onto the parallel output from the shift-register path on the falling edge of **TCK**. Once latched, the new instruction becomes the current instruction.

All test data registers selected by the current instruction retain their previous values in this state.

Transition to next state: When **TMS** remains high on the rising edge of **TCK**, then the controller moves to the Select-DR state, else the controller moves to the Run-Test/Idle state.



#### **TAP Controller Configuration** 19.3.3

The Test Logic Unit (TLU) and the  $Intel^{\textcircled{8}}$  XScale  $^{\texttt{TM}}$  core each contain a separate TAP controller. They are connected in series through the TDI-TDO stream as shown in Figure 123.

**TAP Controller Configuration** Figure 123.





# 19.3.4 TAP Controller Registers

The IEEE 1149.1 architecture specifies an instruction register and a minimum of two test data registers: bypass and boundary scan. The IOP TAP controller meets this requirement.

## 19.3.4.1 Instruction Register

Each of the TAP controllers in the design contain an instruction register (IR). Each IR is a 7-bit, master/slave-configured, parallel-loadable, serial-shift register with latched outputs. They are used in each unit to select the test data register to be accessed.

When the TAP controller is in the Shift-IR state, instructions are loaded serially via **TDI** clocked by the rising edge of **TCK**. The shifted-in instruction becomes active upon latching from the serial-stages to the parallel-stages in the Update-IR state. At that time the IR outputs, along with the TAP finite state machine outputs, are decoded to select and control the test data register selected by that instruction. Upon latching, all actions caused by any previous instructions must terminate.

On activation of **TRST**#, the latched instruction asynchronously changes to the IDCODE instruction. Additionally, upon entering the Test-Logic-Reset state, the IDCODE instruction is latched and becomes active on the falling edge of **TCK**.

Because the TAP controllers are connected in series, each unit must receive its own 7-bit instruction during the Shift-IR state. The BYPASS instruction should be loaded into the unit that is not to be accessed.

For example, to load the IDCODE instruction into the TLUs IR, the data shifted into TDI during the Shift-IR state is:

```
1 1 1 1 1 1 1 1 1 1 1 1 0 -----> TDI

| BYPASS into | IDCODE |

| X-Scale core | into TLU |
```

As another example, to load the IDCODE instruction into the Intel<sup>®</sup> XScale<sup>TM</sup>, s instruction register, the data shifted into TDI during the Shift-IR state is:



#### 19.3.4.2 **Instructions**

Since the instruction set for each TAP controllers is independent of one another, each is listed separately below.

#### **Table 409. TLU TAP Controller Instruction Set**

| Instruction        | Opcode   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|--------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | 00000002 | Intended for supporting the boundary-scan feature for testing device interconnects at the board/system level, the EXTEST instruction connects only the boundary-scan register between TDI and TDO in the Shift-DR state. When EXTEST is selected, all output signal pin values are driven by values shifted into the boundary-scan register and may change only on the falling-edge of TCK in the Update_DR state.                                                                                                                                   |  |
| EXTEST             |          | Also, when extest is selected, all system input pin states must be loaded into the boundary-scan register on the rising-edge of <b>TCK</b> in the Capture_DR state.                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                    |          | Note: Data would typically be loaded onto the latched parallel outputs of boundary-scan shift registers using the SAMPLE/PRELOAD instruction prior to selection of the EXTEST instruction.                                                                                                                                                                                                                                                                                                                                                           |  |
|                    |          | SAMPLE/PRELOAD performs two functions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| SAMPLE/<br>PRELOAD | 00000012 | When the TAP controller is in the Capture-DR state, the sample instruction occurs on the rising edge of TCK and provides a snapshot of the component's normal operation without interfering with that normal operation. The instruction causes Boundary-Scan register cells associated with outputs to sample the value being driven by or to the processor.      When the TAP controller is in the Update-DR state, the preload instruction occurs on the falling edge of TCK. This instruction occurs on the falling edge of TCK. This instruction |  |
|                    |          | causes the transfer of data held in the boundary-scan cells to the slave register cells. Typically the slave latched data is then applied to the system outputs by means of the extest instruction.                                                                                                                                                                                                                                                                                                                                                  |  |
| HIGHZ              | 01100012 | HIGHZ puts all output pins into a tri-state mode. When this instruction is active, the bypass register is connected between <b>TDI</b> and <b>TDO</b> .                                                                                                                                                                                                                                                                                                                                                                                              |  |
| IDCODE             | 11111102 | IDCODE is used in conjunction with the device identification register. When selected, IDCODE parallel-loads the hard-wired identification code (32 bits) into the identification register on the rising edge of TCK following entry into the Capture-DR state. The instruction selects only the identification register for connection between TDI and TDO in the Shift-DR state for serial access.  NOTE: The device identification register is not altered by data being shifted in on TDI.                                                        |  |
| BYPASS             | 11111112 | BYPASS selects the bypass register between TDI and TDO while in Shift-DR state, effectively bypassing the processor's test logic. '0' is captured in the Capture-DR state. While this instruction is in effect, all other test data registers have no effect on the operation of the system.                                                                                                                                                                                                                                                         |  |



#### 19.3.4.2.1 High-Z

High-Z aids in board-level testing. A mounted device effectively removes itself electrically from a circuit board. This allows for system-level testing where a remote tester exercises the processor system.

"HIGH-Z" is an instruction defined by the IEEE 1149.1 Standard. The requirement for this instruction are 1) all system logic outputs are high impedance; 2) the TAP controller continues to operate with the bypass register connected between TDI and TDO. The part may have other settings, as long as they do not interfere with these two requirements.

*Note:* Following the use of High-Z the part may be in an indeterminate state. Therefore, the IOP requires a reset in order to continue normal operation.

Table 410. Intel<sup>®</sup> XScale<sup>™</sup> Core TAP Controller Instruction Set

| Instruction | Opcode                    | Description                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DBGRXx      | 00000102                  | Used by the Intel <sup>®</sup> XScale <sup>™</sup> core debugger during software debug. See core EAS Ch 9 for more information.                                                                                                                                                                                                                                                                                          |  |
| LDIC        | 00001112                  | Used by the Intel <sup>®</sup> XScale <sup>™</sup> core to load the instruction cache. Used during core burn-in testing. See core EAS Ch 9 for more information.                                                                                                                                                                                                                                                         |  |
| DCSR        | 00010012                  | Used by the Intel <sup>®</sup> XScale <sup>™</sup> core debugger during software debug. See core EAS Ch 9 for more information.                                                                                                                                                                                                                                                                                          |  |
| DBGTXx      | 00100002                  | Used by the Intel <sup>®</sup> XScale <sup>™</sup> core debugger during software debug. See core EAS Ch 9 for more information.                                                                                                                                                                                                                                                                                          |  |
| TRACE       | 00100012                  | Selects ETM registers.                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| IDCODE      | ODE 11111110 <sub>2</sub> | IDCODE is used in conjunction with the device identification register. When selected, IDCODE parallel-loads the hard-wired identification code (32 bits) into the identification register on the rising edge of <b>TCK</b> following entry into the Capture-DR state. The instruction selects only the identification register for connection between <b>TDI</b> and <b>TDO</b> in the Shift-DR state for serial access. |  |
|             |                           | NOTE: The device identification register is not altered by data being shifted in on <b>TDI</b> .                                                                                                                                                                                                                                                                                                                         |  |
| BYPASS      | 1111111 <sub>2</sub>      | BYPASS selects the bypass register between TDI and TDO while in Shift-DR state, effectively bypassing the processor's test logic.'0' is captured in the Capture-DR state. While this instruction is in effect, all other test data registers have no effect on the operation of the system.                                                                                                                              |  |



# 19.3.4.3 Boundary-Scan Register

The boundary-scan register is a set of serial-shiftable register cells, connected between each of the system pins and the on-chip system logic (power, ground and TAP pins excluded). This forms a single shift-register between TDI and TDO of all the system pins.

This is the most extensive, complex register in the test circuitry. This register allows testing of circuitry external to the component (e.g. board interconnect) in addition to device system logic. It permits the system signals (into and out of the system logic) to be sampled and examined without causing interference with the normal operation of the system logic. Further definition, rules, and specifics of the boundary-scan register can be found in the IEEE Std, 1149.1-1990, Chapter 10.

# 19.3.4.4 Bypass Register

The bypass register is a single-bit, serial-shift register that connects **TDI** and **TDO** when the BYPASS instruction is in effect. This allows rapid movement of test data to and from other components on the board, since this register provides the shortest path between **TDI** and **TDO**. This path can be selected when no test operation is being performed. While the bypass register is selected, data is transferred from **TDI** to **TDO** without inversion.



# 19.3.4.5 Device Identification Register

The device identification (ID) register is a 32-bit register used for storing the manufacturer identification, part number, and the version of the processor. It is a dedicated part of the test logic and is not usable in system functionality.

The identification register is selected only by the IDCODE instruction. When the Test-Logic-Reset state of the TAP controller is entered, the IDCODE instruction is automatically loaded into the instruction register. The generic format of the register is discussed in chapter 11 of the IEEE 1149.1 Standard.

## Figure 124. Device ID Register



#### Table 411. Device ID Register Field Definitions

| Field           | Definition                                                       |  |
|-----------------|------------------------------------------------------------------|--|
| Version         | Indicates stepping changes.                                      |  |
| Part Number     | part number                                                      |  |
| Manufacturer ID | Manufacturer ID assigned by IEEE. (00000001001h indicates Intel) |  |
| 1               | IEEE 1149.1 requirement                                          |  |

# Table 412. Intel<sup>®</sup> XScale<sup>™</sup> Core Device ID Register Settings

| Intel <sup>®</sup> 80331 I/O processor | 0x09279013 | 0000 1001 0010 0111 1001 0000 0001 0011 |
|----------------------------------------|------------|-----------------------------------------|

## Table 413. TLU Device ID Register Settings

| _ |                                        |            |                                         |
|---|----------------------------------------|------------|-----------------------------------------|
|   | Intel <sup>®</sup> 80331 I/O processor | 0x09279013 | 0000 1001 0010 0111 1001 0000 0001 0011 |

The TLU and the Intel<sup>®</sup> XScale<sup>™</sup> core both have the same device ID number.



# This Page Intentionally Left Blank