# PowerPC 405GP Embedded Processor

User's Manual, Volume 1

Preliminary









IBM

# PowerPC 405GP Embedded Processor User's Manual

# Preliminary

Volume 1



GK10-3118-03

#### Sixth Preliminary Edition (June 2000)

This edition of *IBM PowerPC 405GP Embedded Processor User's Manual* applies to the IBM PowerPC<sup>TM</sup> 405GP 32-bit embedded processor, until otherwise indicated in new versions or application notes.

The following paragraph does not apply to the United Kingdom or any country where such provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS MANUAL "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or implied warranties in certain transactions; therefore, this statement may not apply to you.

IBM does not warrant that the products in this publication, whether individually or as one or more groups, will meet your requirements or that the publication or the accompanying product descriptions are error-free.

This publication could contain technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s) and/or program(s) described in this publication at any time.

It is possible that this publication may contain references to, or information about, IBM products (machines and programs), programming, or services that are not announced in your country. Such references or information must not be construed to mean that IBM intends to announce such IBM products, programming, or services in your country. Any reference to an IBM licensed program in this publication is not intended to state or imply that you can use only IBM's licensed program. You can use any functionally equivalent program instead.

While the information contained herein is believed to be accurate, such information is preliminary, and should not be relied upon for accuracy or completeness, and no representations or warranties of accuracy or completeness are made.

No part of this publication may be reproduced or distributed in any form or by any means, or stored in a data base or retrieval system, without the written permission of IBM.

Requests for copies of this publication and for technical information about IBM products should be made to your IBM Authorized Dealer or your IBM Marketing Representative.

Address technical queries about this product to ppcsupp@us.ibm.com

Address comments about this publication to:

IBM Corporation Department YM5A P.O. Box 12195 Research Triangle Park, NC 27709

IBM may use or distribute whatever information you supply in any way it believes appropriate without incurring any obligation to you.

© Copyright International Business Machines Corporation 1996, 2000. All rights reserved

4321

Notice to U.S. Government Users – Documentation Related to Restricted Rights – Use, duplication, or disclosure is subject to restrictions set forth in GSA ADP Schedule Contract with IBM Corporation.

#### **Patents and Trademarks**

IBM may have patents or pending patent applications covering the subject matter in this publication. The furnishing of this publication does not give you any license to these patents. You can send license inquiries, in writing, to the IBM Director of Licensing, IBM Corporation, North Castle Drive, Armonk, NY 10504, United States of America.

The following terms are trademarks of IBM Corporation:

IBM CodePack CoreConnect PowerPC PowerPC Architecture RISCTrace . RISCWatch

Other terms which are trademarks are the property of their respective owners.

Preliminary

### Contents

| Figures                                             | xxix           |
|-----------------------------------------------------|----------------|
| Tables                                              | xli            |
| About This Book                                     |                |
| Who Should Use This Book                            |                |
| How to Use This Book                                | XIVII<br>vivii |
| Conventions                                         |                |
|                                                     |                |
| Part I. Introducing the PPC405GP Embedded Processor |                |
| Chapter 1. Overview                                 |                |
| PPC405GP Features                                   |                |
| Bus and Peripheral Features                         |                |
| PowerPC Processor Core Features                     | 1-3            |
| PowerPC Architecture                                |                |
| The PPC405GP as a PowerPC Implementation            |                |
| RISC Processor Core Organization                    |                |
| Instruction and Data Cache Controllers              | 1-5            |
| Instruction Cache Unit                              | 1-6            |
| Data Cache Unit                                     |                |
| Memory Management Unit                              | 1-6            |
| Timer Facilities                                    | 1-8            |
| Debug                                               | 1-8            |
| Development Tool Support                            | 1-8            |
| Debug Modes                                         |                |
| Processor Core Interfaces                           | 1-9            |
| Processor Local Bus                                 |                |
| Device Control Register Bus                         |                |
| Clock and Power Management                          | 1-9            |
| JTAG                                                | 1-9            |
| Interrupts                                          |                |
| On-Chip Memory                                      | 1-9            |
| Processor Core Programming Model                    | 1-9            |
| Data Types                                          | 1-10           |
| Processor Core Register Set Summary                 | 1-10           |
| General Purpose Registers                           | 1-10           |
| Special Purpose Registers                           |                |
| Machine State Register                              | 1-10           |
| Condition Register                                  | 1-11           |
| Device Control Registers                            | 1-11           |
| Memory-Mapped I/O Registers                         | 1-11           |
| Addressing Modes                                    | 1-11           |
| Chapter 2. On-Chip Buses                            | 2-1            |
| Processor Local Bus                                 |                |
| PLB Features                                        |                |
| PLB Masters and Slaves                              |                |
| PLB Master Assignments                              |                |
| PLB Transfer Protocol                               |                |
| Overlapped PLB Transfers                            |                |
| PLB Arbiter Registers                               |                |
| PLB Arbiter Control Register (PLB0_ACR)             |                |
| PLB Error Address Register (PLB0_BEAR)              |                |

•

v

| PLB Error Status Register (PLB0_BESR)                          |       |
|----------------------------------------------------------------|-------|
| PLB to OPB Bridge Registers                                    | 2-8   |
| Bridge Error Address Register (POB0_BEAR)                      | 2-8   |
| Bridge Error Status Registers (POB0_BESR0–POB0_BESR1)          | 2-8   |
| On-Chip Peripheral Bus                                         | 2-11  |
| OPB Features                                                   | 2-11  |
| OPB Master Assignments                                         | 2-12  |
| OPB Arbiter Registers                                          |       |
| OPB Arbiter Control Register (OPBA0_CR)                        | 2-12  |
| OPB Arbiter Priority Register (OPBA0_PR)                       | 2-13  |
| Part II. The PPC405GP RISC Processor                           | .11-1 |
| Chapter 3. Programming Model                                   | .3-1  |
| User and Privileged Programming Models                         | 3-1   |
| Memory Organization and Addressing                             |       |
| Physical Address Map                                           |       |
| Storage Attributes                                             | 3-3   |
| Registers                                                      | 3-3   |
| General Purpose Registers (R0-R31)                             | 3-6   |
| Special Purpose Registers                                      | 3-6   |
| Count Register (CTR)                                           |       |
| Link Register (LR)                                             |       |
| Fixed Point Exception Register (XER)                           |       |
| Special Purpose Register General (SPRG0–SPRG7)                 | 2.11  |
| Processor Version Register (PVR)                               | 0 10  |
| Condition Register (CR)                                        | 012   |
| CR Fields after Compare Instructions                           | 0.10  |
|                                                                |       |
| The CR0 Field                                                  |       |
| The Time Base                                                  |       |
| Machine State Register (MSR)                                   |       |
| Device Control Registers                                       | 3-16  |
| Directly Accessed DCRs                                         |       |
| Indirectly Accessed DCRs                                       | 3-19  |
| Indirect Access of SDRAM Controller DCRs                       | 3-19  |
| Indirect Access of External Bus Controller DCRs                |       |
| Indirect Access of Decompression Controller DCRs               |       |
| Memory-Mapped Input/Output Registers                           | 3-22  |
| Directly Accessed MMIO Registers                               | 3-22  |
| Indirectly Accessed MMIO Registers                             | 3-25  |
| Data Types and Alignment                                       | 3-26  |
| Alignment for Storage Reference and Cache Control Instructions |       |
| Alignment and Endian Operation                                 | 3-27  |
| Summary of Instructions Causing Alignment Exceptions           |       |
| Byte Ordering                                                  | 3-28  |
| Structure Mapping Examples                                     | 3-29  |
| Big Endian Mapping                                             |       |
| Little Endian Mapping                                          |       |
| Support for Little Endian Byte Ordering                        | 3-30  |
| Endian (E) Storage Attribute                                   | 3-30  |
| Fetching Instructions from Little Endian Storage Regions       |       |
| Accessing Data in Little Endian Storage Regions                |       |
| PowerPC Byte-Reverse Instructions                              |       |
| Instruction Processing                                         |       |
| Branch Processing                                              |       |
| Unconditional Branch Target Addressing Options                 | 3-34  |
| Conditional Branch Target Addressing Options                   | 3-35  |
|                                                                |       |

vi

| Conditional Branch Condition Register Testing                         |      |
|-----------------------------------------------------------------------|------|
| BO Field on Conditional Branches                                      |      |
| Branch Prediction                                                     |      |
| Speculative Accesses                                                  | 3-37 |
| Speculative Accesses in the PPC405GP                                  | 3-37 |
| Prefetch Distance Down an Unresolved Branch Path                      |      |
| Prefetch of Branches to the CTR and Branches to the LR                |      |
| Preventing Inappropriate Speculative Accesses                         |      |
| Fetching Past an Interrupt-Causing or Interrupt-Returning Instruction |      |
| Fetching Past tw or twi Instructions                                  |      |
| Fetching Past an Unconditional Branch                                 | 3-40 |
| Suggested Locations of Memory-Mapped Hardware                         |      |
| Summary                                                               |      |
| Privileged Mode Operation                                             |      |
| MSR Bits and Exception Handling                                       |      |
| Privileged Instructions                                               |      |
| Privileged SPRs                                                       |      |
| Privileged DCRs                                                       |      |
| Synchronization                                                       |      |
| Context Synchronization                                               |      |
| Execution Synchronization                                             | 3-46 |
| Storage Synchronization                                               |      |
| Instruction Set                                                       | 3-47 |
| Instructions Specific to IBM PowerPC Embedded Processors              |      |
| Storage Reference Instructions                                        |      |
| Arithmetic Instructions                                               |      |
| Logical Instructions                                                  |      |
| Compare Instructions                                                  |      |
| Branch Instructions                                                   |      |
| CR Logical Instructions                                               |      |
| Rotate Instructions                                                   |      |
| Shift Instructions                                                    |      |
| Cache Management Instructions                                         |      |
| Interrupt Control Instructions                                        |      |
| TLB Management Instructions                                           |      |
| Processor Management Instructions                                     |      |
| Extended Mnemonics                                                    |      |
| Chapter 4. Cache Operations                                           | 4-1  |
| ICU Organization                                                      |      |
| ICU Operations                                                        | 4-3  |
| Instruction Cachability Control                                       |      |
| Instruction Cache Synonyms                                            |      |
| ICU Coherency                                                         |      |
| DCU Organization                                                      |      |
| DCU Operations                                                        |      |
| DCU Write Strategies                                                  |      |
| DCU Load and Store Strategies                                         |      |
| Data Cachability Control                                              |      |
| DCU Coherency                                                         |      |
| Cache Instructions                                                    |      |
| ICU Instructions                                                      |      |
| DCU Instructions                                                      |      |
| Cache Control and Debugging Features                                  |      |
| CCR0 Programming Guidelines                                           |      |
| ICU Debugging                                                         |      |
|                                                                       |      |

| DCU Debugging                                                    | 4-15  |
|------------------------------------------------------------------|-------|
| DCU Performance                                                  | 4-16  |
| Pipeline Stalls                                                  | 4-16  |
| Cache Operation Priorities                                       | 4-17  |
| Simultaneous Cache Operations                                    | 4-18  |
| Sequential Cache Operations                                      |       |
| Chapter 5. On-Chip Memory                                        | .5-1  |
| OCM Addressing                                                   | . 5-1 |
| OCM Programming Guidelines                                       |       |
| Store Data Bypass Behavior and Memory Coherency                  |       |
| Registers                                                        |       |
| OCM Instruction-Side Address Range Compare Register (OCM0_ISARC) |       |
| OCM Instruction-Side Control Register (OCM0_ISCNTL)              | . 5-6 |
| OCM Data-Side Address Range Compare Register (OCM0_DSARC)        | . 5-6 |
| OCM Data-Side Control Register (OCM0_DSCNTL)                     |       |
| Chapter 6. Memory Management                                     | . 6-1 |
| MMU Overview                                                     |       |
|                                                                  |       |
| Address Translation<br>Translation Lookaside Buffer (TLB)        |       |
| Unified TLB                                                      |       |
| TLB Fields                                                       |       |
| Page Identification Fields                                       |       |
| Translation Field                                                |       |
| Access Control Fields                                            |       |
| Storage Attribute Fields                                         |       |
| Shadow Instruction TLB                                           |       |
| ITLB Accesses                                                    |       |
| Shadow Data TLB                                                  |       |
| DTLB Accesses                                                    |       |
| Shadow TLB Consistency                                           |       |
| TLB-Related Interrupts                                           | . 6-9 |
| Data Storage Interrupt                                           |       |
| Instruction Storage Interrupt                                    |       |
| Data TLB Miss Interrupt                                          |       |
| Instruction TLB Miss Interrupt                                   | 6-10  |
| TLB Management                                                   |       |
| TLB Search Instructions (tlbsx/tlbsx.)                           |       |
| TLB Read/Write Instructions (tlbre/tlbwe)                        |       |
| TLB Invalidate Instruction (tlbia)                               | 6-11  |
| TLB Sync Instruction (tlbsync)                                   | 6-11  |
| Recording Page References and Changes                            | 6-11  |
| Access Protection                                                |       |
| Access Protection Mechanisms in the TLB                          | 6-12  |
| General Access Protection                                        | 6-12  |
| Execute Permissions                                              |       |
| Write Permissions                                                |       |
| Zone Protection                                                  |       |
| Access Protection for Cache Control Instructions                 |       |
| Access Protection for String Instructions                        |       |
| Real-mode Storage Attribute Control                              |       |
| Storage Attribute Control Registers                              |       |
| Data Cache Write-through Register (DCWR)                         |       |
| Data Cache Cachability Register (DCCR)                           |       |
| Instruction Cache Cachability Register (ICCR)                    |       |
| Storage Guarded Register (SGR)                                   | 0-19  |

-

| Storage User-defined 0 Register (SU0R)<br>Storage Little-Endian Register (SLER)                  | 6-19<br>6-19 |
|--------------------------------------------------------------------------------------------------|--------------|
| Part III. PPC405GP System Operations                                                             |              |
| Chapter 7. Clocking                                                                              |              |
| PLL Overview                                                                                     | 7-1          |
| Input Reference Clock (SysClk)                                                                   |              |
| External Clock Strapping Setup                                                                   |              |
| Sample Clock Ratios                                                                              | 7-4          |
| PCI Clocking                                                                                     | 7 <b>-</b> 7 |
| PCI Clocks                                                                                       | 7-8          |
| PCI Adapter Applications                                                                         |              |
| Serial Port Clocking                                                                             |              |
| Clocking Registers                                                                               |              |
| PLL Mode Register (CPC0_PLLMR)                                                                   |              |
| Chip Control Register 0 (CPC0_CR0)                                                               |              |
| Chapter 8. Reset and Initialization                                                              |              |
| Reset Signals                                                                                    |              |
| Reset Types                                                                                      |              |
| Core Reset                                                                                       |              |
| Chip Reset                                                                                       |              |
| System Reset                                                                                     |              |
| PCI Power Management Initiated Resets                                                            |              |
| Processor Initiated Resets                                                                       |              |
| Processor State After Reset                                                                      |              |
| Processor Register Contents After Reset                                                          |              |
| Machine State Register Contents after Reset<br>Contents of Special Purpose Registers after Reset |              |
| DCR Contents after Reset                                                                         |              |
| MMIO Register Contents After Reset                                                               |              |
| PPC405GP Chip Initialization                                                                     |              |
| OCM Initialization                                                                               |              |
| Initializing Instruction-Side OCM                                                                | 8-13         |
| Initializing Data-Side OCM                                                                       | 8-13         |
| UIC Initialization                                                                               |              |
| UART Initialization                                                                              |              |
| PPC405GP Initial Processor Sequencing                                                            | 8-14         |
| Initialization Requirements                                                                      |              |
| Initialization Code Example                                                                      | 8-16         |
| Chapter 9. Pin Strapping and Sharing                                                             | 9-1          |
| Pin Strapping                                                                                    | 9-1          |
| Chip Pin Strapping Register (CPC0_PSR)                                                           | 9-1          |
| Pin Sharing                                                                                      | 9-3          |
| Chapter 10. Interrupt Controller Operations                                                      | 10-1         |
| UIC Overview                                                                                     | 10-1         |
| UIC Features                                                                                     | 10-1         |
| UIC Interrupt Assignments                                                                        | 10-1         |
| Interrupt Programmability                                                                        | 10-3         |
| UIC Registers                                                                                    |              |
| UIC Status Register (UIC0_SR)                                                                    |              |
| UIC Enable Register (UICO_ER)                                                                    |              |
| UIC Critical Register (UIC0_CR)                                                                  | 10-8         |
| UIC Polarity Register (UICO_PR)                                                                  |              |
| UIC Trigger Register (UIC0_TR)                                                                   | 10-13        |

| UIC Masked Status Register (UIC0_MSR)                                | 10-16  |
|----------------------------------------------------------------------|--------|
| UIC Vector Configuration Register (UIC0_VCR)                         | 10-18  |
| UIC Vector Register (UIC0_VR)                                        | 10-19  |
| Using the Value in UIC0_VR as a Vector Address or Entry Table Lookup | 10-20  |
| Vector Generation Scenarios                                          | 10-20  |
| Interrupt Handling in the Processor Core                             |        |
| Architectural Definitions and Behavior                               | 10-22  |
| Behavior of the PPC405GP Implementation                              | 10-23  |
| Interrupt Handling Priorities                                        |        |
| Critical and Noncritical Interrupts                                  | 10-26  |
| General Interrupt Handling Registers                                 | 10-27  |
| Machine State Register (MSR)                                         | 10-28  |
| Save/Restore Registers 0 and 1 (SRR0-SRR1)                           | 10-29  |
| Save/Restore Registers 2 and 3 (SRR2-SRR3)                           | 10-30  |
| Exception Vector Prefix Register (EVPR)                              |        |
| Exception Syndrome Register (ESR)                                    |        |
| Data Exception Address Register (DEAR)                               |        |
| Critical Input Interrupts                                            |        |
| Machine Check Interrupts                                             |        |
| Instruction Machine Check Handling                                   |        |
| Data Machine Check Handling                                          |        |
| Data Storage Interrupt                                               |        |
| Instruction Storage Interrupt                                        |        |
| External Interrupt                                                   |        |
| External Interrupt Handling                                          |        |
| Alignment Interrupt                                                  |        |
| Program Interrupt                                                    |        |
| System Call Interrupt                                                |        |
| Programmable Interval Timer (PIT) Interrupt                          |        |
| Fixed Interval Timer (FIT) Interrupt                                 |        |
|                                                                      |        |
| Watchdog Timer Interrupt                                             |        |
| Data TLB Miss Interrupt                                              |        |
| Instruction TLB Miss Interrupt                                       |        |
| Debug Interrupt                                                      |        |
| Chapter 11. Timer Facilities                                         |        |
| Time Base                                                            | . 11-2 |
| Reading the Time Base                                                | . 11-3 |
| Writing the Time Base                                                | . 11-3 |
| Programmable Interval Timer (PIT)                                    | . 11-4 |
| Fixed Interval Timer (FIT)                                           |        |
| Watchdog Timer                                                       |        |
| Timer Status Register (TSR)                                          | . 11-8 |
| Timer Control Register (TCR)                                         |        |
| Chapter 12. Debugging                                                |        |
|                                                                      |        |
| Development Tool Support                                             |        |
| Debug Interfaces                                                     | . 12-1 |
| IEEE 1149.1 Test Access Port (JTAG Debug Port)                       |        |
| JTAG Connector                                                       |        |
| JTAG Instructions                                                    |        |
| JTAG Boundary Scan                                                   |        |
| JTAG Implementation                                                  |        |
| JTAG ID Register (CPC0_JTAGID)                                       |        |
| Trace Port                                                           |        |
| Debug Modes                                                          |        |
| Internal Debug Mode                                                  | . 12-6 |

| External Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Debug Wait Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 12-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Real-time Trace Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Processor Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Processor Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Debug Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Debug Control Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Debug Control Register 0 (DBCR0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Debug Control Register1 (DBCR1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 12-11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Debug Status Register (DBSR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12-12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Instruction Address Compare Registers (IAC1-IAC4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Data Address Compare Registers (DAC1–DAC2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Data Value Compare Registers (DVC1–DVC2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 12-15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Debug Events                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12-16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Instruction Complete Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Branch Taken Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 12-17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Exception Taken Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Trap Taken Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Unconditional Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 12-17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| IAC Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 12-17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| IAC Exact Address Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| IAC Range Address Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DAC Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DAC Exact Address Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 12-19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DAC Range Address Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Data Address Compare (DAC) Applied to Cache Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 12-20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DAC Applied to String Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 12-21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Data Value Compare Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 12-21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Imprecise Debug Event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 12-23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Chapter 13. Clock and Power Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .13-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Chapter 13. Clock and Power Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>.13-1</b><br>. 13-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>. 13-1</b><br>. 13-1<br>. 13-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>. 13-1</b><br>. 13-1<br>. 13-3<br>. 13-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b>. 13-1</b><br>. 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 13-1<br>. 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | .13-1<br>.13-3<br>.13-3<br>.13-3<br>.13-3<br>.13-3<br>.14-1<br>.14-1<br>.14-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Compression                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | .13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>.13-3<br>.14-1<br>. 14-1<br>. 14-1<br>. 14-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Instruction Fetches to Compressed Pages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>.13-3<br>.13-3<br>.13-3<br>.14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | .13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>.13-3<br>.13-3<br>.14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Chapter 13. Clock and Power Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>.13-3<br>.13-3<br>.14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Chapter 13. Clock and Power Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>.13-3<br>.14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Configuration Register (DCP0_CFG)                                                                                                                                                                                                                                                                                                                                                                                                 | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-5<br>. 14-5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression Code Compression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_ID)                                                                                                                                                                                                                                                                                                                                                                                                     | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5<br>. 14-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression Controller Operation<br>Code Compression and Decompressed Pages<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_CFG)                                                                                                                                                                                                                                                                                                                                                                                               | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5<br>. 14-6<br>. 14-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_CFG)<br>Decompression Controller ID Register (DCP0_ID)<br>Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)                                                                                                                                                                                                                                                                       | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-5<br>. 14-6<br>. 14-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_CFG)<br>Decompression Controller ID Register (DCP0_ID)<br>Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)<br>Decompression Controller PLB Error Address Register (DCP0_MEMBEAR)                                                                                                                                                                                                 | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-5<br>. 14-6<br>. 14-6<br>. 14-7<br>. 14-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_CFG)<br>Decompression Controller ID Register (DCP0_ID)<br>Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)                                                                                                                                                                                                                                                                       | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-5<br>. 14-6<br>. 14-6<br>. 14-7<br>. 14-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Chapter 13. Clock and Power Management<br>CPM Registers<br>CPM Enable Register (CPC0_ER)<br>CPM Force Register (CPC0_FR)<br>CPM Status Register (CPC0_SR)<br>Chapter 14. Decompression Controller Operation<br>Code Compression and Decompression<br>Code Compression<br>Code Decompression<br>Code Decompression<br>Code Decompression<br>Instruction Fetches to Compressed Pages<br>Instruction Fetches to Uncompressed Pages<br>Performance<br>Decompression Controller Registers<br>Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)<br>Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)<br>Decompression Controller ID Register (DCP0_CFG)<br>Decompression Controller ID Register (DCP0_ID)<br>Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)<br>Decompression Controller PLB Error Address Register (DCP0_MEMBEAR)                                                                                                                                                                                                 | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5<br>. 14-6<br>. 14-7<br>. 14-7<br>. 14-7<br>. 14-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Chapter 13. Clock and Power Management         CPM Registers         CPM Enable Register (CPC0_ER)         CPM Force Register (CPC0_FR)         CPM Status Register (CPC0_SR)         Chapter 14. Decompression Controller Operation         Code Compression and Decompression         Code Decompression         Instruction Fetches to Compressed Pages         Instruction Fetches to Uncompressed Pages         Performance         Decompression Controller Registers         Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)         Decompression Controller Registers (DCP0_ADDR0-DCP0_ADDR1)         Decompression Configuration Register (DCP0_CFG)         Decompression Controller ID Register (DCP0_LID)         Decompression Controller Version Register (DCP0_VER)         Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)         Decompression Controller Ruge Sterror Address Register (DCP0_MEMBEAR)         Decompression Controller Ruge Sterror Status Register 0 (DCP0_ESR)         Part IV. PPC405GP External Interfaces | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5<br>. 14-5<br>. 14-6<br>. 14-7<br>. 14-7<br>. 14-7<br>. 14-7<br>. 14-7<br>. 14-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Chapter 13. Clock and Power Management                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .13-1<br>.13-3<br>.13-3<br>.13-3<br>.13-3<br>.13-3<br>.14-1<br>.14-1<br>.14-1<br>.14-2<br>.14-2<br>.14-2<br>.14-2<br>.14-3<br>.14-3<br>.14-3<br>.14-5<br>.14-5<br>.14-6<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-1<br>.14-7<br>.14-7<br>.14-1<br>.14-7<br>.14-7<br>.14-7<br>.14-1<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.14-7<br>.1 |
| Chapter 13. Clock and Power Management         CPM Registers         CPM Enable Register (CPC0_ER)         CPM Force Register (CPC0_FR)         CPM Status Register (CPC0_SR)         Chapter 14. Decompression Controller Operation         Code Compression and Decompression         Code Decompression         Instruction Fetches to Compressed Pages         Instruction Fetches to Uncompressed Pages         Performance         Decompression Controller Registers         Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)         Decompression Controller Registers (DCP0_ADDR0-DCP0_ADDR1)         Decompression Configuration Register (DCP0_CFG)         Decompression Controller ID Register (DCP0_LID)         Decompression Controller Version Register (DCP0_VER)         Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)         Decompression Controller Ruge Sterror Address Register (DCP0_MEMBEAR)         Decompression Controller Ruge Sterror Status Register 0 (DCP0_ESR)         Part IV. PPC405GP External Interfaces | . 13-1<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 13-3<br>. 14-1<br>. 14-1<br>. 14-1<br>. 14-2<br>. 14-2<br>. 14-2<br>. 14-3<br>. 14-3<br>. 14-4<br>. 14-5<br>. 14-5<br>. 14-6<br>. 14-7<br>. 14-7<br>. 14-7<br>. 14-7<br>. 15-1<br>. 15-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| SDRAM Controller Configuration and Status                                                                                                                                                                                                                                             | 15-3                                                                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| Memory Controller Configuration Register (SDRAM0_CFG)                                                                                                                                                                                                                                 |                                                                               |
| Memory Controller Status (SDRAM0_STATUS)                                                                                                                                                                                                                                              | 15-5                                                                          |
| Memory Bank 0-3 Configuration (SDRAM0_B0CR-SDRAM0_B3CR)                                                                                                                                                                                                                               | 15-6                                                                          |
| Page Management                                                                                                                                                                                                                                                                       |                                                                               |
| Logical Address to Memory Address Mapping                                                                                                                                                                                                                                             |                                                                               |
| SDRAM Timing Register (SDRAM0_TR)                                                                                                                                                                                                                                                     |                                                                               |
| Selected Timing Diagrams                                                                                                                                                                                                                                                              |                                                                               |
| Auto (CAS Before RAS) Refresh                                                                                                                                                                                                                                                         |                                                                               |
| Refresh Timer Register (SDRAM0_RTR)                                                                                                                                                                                                                                                   |                                                                               |
| Error Checking and Correction (ECC)                                                                                                                                                                                                                                                   | 15-14                                                                         |
| ECC Configuration Register (SDRAM0_ECCCFG)                                                                                                                                                                                                                                            | 15-14                                                                         |
| Correctable ECC Errors                                                                                                                                                                                                                                                                |                                                                               |
| Uncorrectable ECC Errors                                                                                                                                                                                                                                                              |                                                                               |
| Error Locking                                                                                                                                                                                                                                                                         |                                                                               |
| ECC Error Status Register (SDRAM0_ECCESR)                                                                                                                                                                                                                                             |                                                                               |
| Bus Error Address Register (SDRAM0_BEAR)                                                                                                                                                                                                                                              | 15-17                                                                         |
| Bus Error Syndrome Register 0 (SDRAM0_BESR0)                                                                                                                                                                                                                                          | 15-17                                                                         |
| Bus Error Syndrome Register 1 (SDRAM0_BESR1)                                                                                                                                                                                                                                          |                                                                               |
| Self-Refresh                                                                                                                                                                                                                                                                          |                                                                               |
| Power Management                                                                                                                                                                                                                                                                      |                                                                               |
| Sleep Mode Entry                                                                                                                                                                                                                                                                      | 15-20                                                                         |
| Power Management Idle Timer (SDRAM0_PMIT)                                                                                                                                                                                                                                             | 15-20                                                                         |
| Sleep Mode Exit                                                                                                                                                                                                                                                                       |                                                                               |
| Chapter 16. External Bus Controller                                                                                                                                                                                                                                                   |                                                                               |
| Interface Signals                                                                                                                                                                                                                                                                     | 16-1                                                                          |
| Interfacing to Byte, Halfword and Word Devices                                                                                                                                                                                                                                        | 16-3                                                                          |
| Multiplexed I/Os                                                                                                                                                                                                                                                                      | 16-4                                                                          |
| Driver Enables                                                                                                                                                                                                                                                                        |                                                                               |
| Non-Burst Peripheral Bus Transactions                                                                                                                                                                                                                                                 | 16-5                                                                          |
| Single Read Transfer                                                                                                                                                                                                                                                                  | 16-6                                                                          |
| Single Write Transfer                                                                                                                                                                                                                                                                 | 16-7                                                                          |
| Burst Transactions                                                                                                                                                                                                                                                                    |                                                                               |
| Burst Read Transfer                                                                                                                                                                                                                                                                   | 16-9                                                                          |
| Burst Write Transfer                                                                                                                                                                                                                                                                  |                                                                               |
| Device-Paced Transfers                                                                                                                                                                                                                                                                | 16-11                                                                         |
| Device-Paced Single Read Transfer                                                                                                                                                                                                                                                     |                                                                               |
| Device-Paced Single Write Transfer                                                                                                                                                                                                                                                    | 16-13                                                                         |
| Device-Paced Burst Read Transfer                                                                                                                                                                                                                                                      | 16-14                                                                         |
| Device-Paced Burst Write Transfer                                                                                                                                                                                                                                                     |                                                                               |
| External Bus Master Interface                                                                                                                                                                                                                                                         | 16-17                                                                         |
| Arbitration                                                                                                                                                                                                                                                                           | 16-17                                                                         |
| Transaction Overview                                                                                                                                                                                                                                                                  |                                                                               |
| Qineda Danad en di Qineda Minita Transform                                                                                                                                                                                                                                            |                                                                               |
| Single Read and Single Write Transfers                                                                                                                                                                                                                                                | 16-19                                                                         |
| Single Read and Single Write Transfers<br>Burst Read Transfer                                                                                                                                                                                                                         | 16-19<br>16-20                                                                |
| Single Read and Single Write Transfers<br>Burst Read Transfer<br>Burst Write Transfer                                                                                                                                                                                                 | 16-20                                                                         |
| Burst Read Transfer                                                                                                                                                                                                                                                                   | 16-20<br>16-21                                                                |
| Burst Read Transfer                                                                                                                                                                                                                                                                   | 16-20<br>16-21<br>16-22                                                       |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts                                                                                                                                                                                                       | 16-20<br>16-21<br>16-22<br>16-23                                              |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts<br>EBC Registers                                                                                                                                                                                      | 16-20<br>16-21<br>16-22<br>16-23<br>16-23                                     |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts<br>EBC Registers<br>EBC Configuration Register (EBC0_CFG)                                                                                                                                             | 16-20<br>16-21<br>16-22<br>16-23<br>16-23<br>16-25                            |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts<br>EBC Registers<br>EBC Configuration Register (EBC0_CFG)<br>Peripheral Bank Configuration Registers (EBC0_BnCR)<br>Peripheral Bank Access Parameters (EBC0_BnAP)<br>Error Reporting                  | 16-20<br>16-21<br>16-22<br>16-23<br>16-23<br>16-25<br>16-26<br>16-29          |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts<br>EBC Registers<br>EBC Configuration Register (EBC0_CFG)<br>Peripheral Bank Configuration Registers (EBC0_BnCR)<br>Peripheral Bank Access Parameters (EBC0_BnAP)<br>Error Reporting<br>Error Locking | 16-20<br>16-21<br>16-22<br>16-23<br>16-23<br>16-25<br>16-26<br>16-29<br>16-29 |
| Burst Read Transfer<br>Burst Write Transfer<br>External Master Error Interrupts<br>EBC Registers<br>EBC Configuration Register (EBC0_CFG)<br>Peripheral Bank Configuration Registers (EBC0_BnCR)<br>Peripheral Bank Access Parameters (EBC0_BnAP)<br>Error Reporting                  | 16-20<br>16-21<br>16-22<br>16-23<br>16-23<br>16-25<br>16-26<br>16-29<br>16-29 |

xii

| Chapter 17. PCI Interface         17-1           PCI Overview         17-1           PCI Bridge Features         17-1           PCI Bridge Elock Diagram         17-2           Beference Information         17-2           Reference Information         17-3           PCI Bridge Functional Blocks         17-4           PCI Bridge Functional Blocks         17-4           PCI Bridge Functional Blocks         17-4           PCI -D-PCI Hall-Bridge         17-5           PCI Bridge Address Mapping         17-6           PLE-to-PCI Hall-Bridge         17-6           PLE-to-RCI Hall-Bridge         17-7           PCI Bridge Map Configuration         17-7           PCI Bridge Map Configuration         17-7           PCI Target Map Configuration         17-10           PLB-to-PCI Transaction Handling         17-12           PLB Slave Write Handling         17-12           PLB Slave Write Handling         17-12           PLB Slave Write Handling         17-13           PCI-Target PLB Requests         17-14           Handling Vites from PCI Masters         17-15           Handling Vites from PCI Masters         17-16           PCI Producer-Consumer Model         17-17           P                                                                                                                                                                                                                                                                                                                                                                                                 | Peripheral Bus Error Status Register 1 (EBC0_BESR1) | 16-32  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------|
| PCI Bridge Features       17-1         PCI Bridge Block Diagram       17-2         Byte Ordering       17-2         Byte Ordering       17-2         PCI Bridge Block Diagram       17-3         PCI Bridge Innottonal Blocks       17-4         PCI Bridge Innottonal Blocks       17-4         PCI Bridge Address Mapping       17-5         PCI Adviter       17-5         PCI Adviters Mapping       17-6         PCI Bridge Address Mapping       17-6         PCI Traget Map Configuration       17-9         PCI Bridge Transaction Handling       17-10         PLB-to-PCI Address Mapping       17-10         PLB-to-PCI Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-12         PLB-to-BCI Transaction Handling       17-12         PLB-to-BCI Transaction Handling       17-12         PLB-to-BCI Transaction Handling       17-12         PLB-to-BCI Transaction Flandling       17-12         PLB-to-BCI Transaction Handling       17-12         PLB-to-BCI Transaction Handling       17-12         PLB-to-BCI Transaction Handling       17-13         Retried PCI Requests       17-14         Handling Writes from PCI Masters       17-15 <td>•</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                          | •                                                   |        |
| PCI Bridge Block Diagram         17-2           Byte Ordering         17-2           Reference Information         17-3           PCI Bridge Functional Blocks         17-4           PLB-to-PCI Hail-Bridge         17-4           PCI-to-PLB Haif-Bridge         17-5           PCI Bridge Address Mapping         17-6           PCI Bridge Address Mapping         17-6           PCI Bridge Address Mapping         17-7           PCI Bridge Transaction Handling         17-10           PCI Bridge Transaction Handling         17-10           PCI Bridge Stave Write Handling         17-10           PCI Bridge Transaction Handling         17-12           Prefetching         17-12           Prefetching         17-12           Prefetching         17-12           Prefetching         17-12           Aborted PLB Requests         17-13           PLB Master Commands         17-14           Aborted PLB Requests from PCI Masters         17-15           Handling Of Reads from PCI Masters         17-15           Handling Writes from PCI Masters         17-17           Probletion Ordering         17-18           PCI Producer-Consumer Model         17-17           PCI Bridge Local Address Reg                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |        |
| Byte Ordering         17-2           Reference Information         17-3           PCI Bridge Functional Blocks         17-4           PLB-to-PCI Hail-Bridge         17-5           PCI Arbiter         17-5           PCI Arbiter         17-6           PCI Bridge Address Mapping         17-6           PLB-to-PCI Address Mapping         17-6           PCI Bridge Address Mapping         17-7           PCI Bridge Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB-to-PCI Back Peaker Back Mark Peaker Back Mark Peaker Back Peaker Peaker Back Peaker Peaker Back Peaker Back Peaker Back Peaker Back Peaker Back Peaker Peaker Peaker Back Peaker Peaker Peaker Back Peaker Peaker Peaker Backer |                                                     |        |
| Reference Information       17-3         PCI Bridge Functional Blocks       17-4         PLB-to-PCI Hail-Bridge       17-4         PCI-o-PLB Hail-Bridge       17-5         PCI Aribter       17-5         PCI Bridge Address Mapping       17-6         PCI Bridge Address Mapping       17-6         PCI Bridge Address Mapping       17-6         PCI Bridge Transaction Handling       17-9         PCI Bridge Transaction Handling       17-10         PLB-0-PCI Transaction Handling       17-10         PLB Slave Read Handling       17-12         Prefetchring       17-12         PLB Slave Read Handling       17-12         PLB Slave Read Handling       17-12         Aborted PLB Requests       17-13         PCI-to-PLB Transaction Handling       17-14         Aborted PLB Requests       17-13         PCL To-PLB Transaction Handling       17-14         Handling of Reads from PCI Masters       17-16         Handling of Reads from PCI Masters       17-17         Mortellaneous       17-17         PCI Producer-Consumer Model       17-18         PCI Bridge Register Segister (PCILO_PMMOPCILA)       17-22         PMM 0 Local Address Register (PCILO_PMMOPCILA)       17-22 <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |        |
| PCI Bridge Functional Blocks       17-4         PLB-to-PCI Half-Bridge       17-4         PCI bridge Address Mapping       17-5         PCI Bridge Address Mapping       17-6         PCI Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-12         Prefetching       17-12         Prefetching       17-12         Prefetching       17-12         PLB to-PCI Transaction Handling       17-12         PLB Stave Read Handling       17-12         PLB Stave Read Handling       17-13         Retried PCI Reads       17-13         PCI-To-TLB Transaction Handling       17-13         PCI-To-TLB Transaction Handling       17-14         Handling of Reads from PCI Masters       17-13         PCI-To-TLB Transaction PCI Masters       17-17         Miscellaneous       17-17         Miscellaneous       17-17         PCI Bridge Configuration Registers       17-18         PCI Bridge Local Configuration Registers       17-19                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                     |        |
| PLE-to-PCI Half-Bridge         17-4           PCI-to-PLB Half-Bridge         17-5           PCI Bridge Address Mapping         17-6           PLB-to-PCI Address Mapping         17-6           PCI Bridge Address Mapping         17-6           PCI Bridge Transaction Handling         17-9           PCI Bridge Transaction Handling         17-10           PCI Bridge Transaction Handling         17-10           PCI Bridge Transaction Handling         17-12           PCI Bridge Transaction Handling         17-12           PCI Bridge Transaction Handling         17-12           PLB Slave Read Handling         17-12           Aborted PLB Requests         17-13           Retried PCI Reads         17-13           PCI-to-PLB Transaction Handling         17-14           Handling of Reads from PCI Masters         17-13           PLB Master Commands         17-17           Completion Ordering         17-17           Minger PCI Producer-Consumer Model         17-17           Completion Ordering         17-18           PCI Producer-Consumer Model         17-18           PCI Bridge Register Summary         17-19           PCI Bridge Register Configuration Registers         17-19           PCI Bridge Local Configurati                                                                                                                                                                                                                                                                                                                                                              |                                                     |        |
| PCI-to-PLB Half-Bridge         17-5           PCI Arbiter         17-5           PCI Bridge Address Mapping         17-6           PLB-to-PCI Address Mapping         17-6           PCI-to-PLB Address Mapping         17-8           PCI Target Map Configuration         17-9           PCI Bridge Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB tasker Ecad Handling         17-12           Prefetching         17-12           Prefetching         17-12           Prefetching         17-13           PCI-DE Transaction Handling         17-12           Abored PLB Requests         17-13           Retried PCI Reads         17-13           PCL-DE Transaction Handling         17-14           Handling Writes from PCI Masters         17-15           Helb Master Commands         17-17           Miscellaneous         17-17           Miscellaneous         17-17           PCI Producer-Consumer Model         17-18           PCI Bridge Local Configuration Registers         17-19           PCI Bridge Local Configuration Register (PCILO_PMMOLA)         17-22           PMM 0 Local Address Register (PCILO_PMMOPCILA)         17-22                                                                                                                                                                                                                                                                                                                                                                                                        |                                                     |        |
| PCI Arbiter       17-5         PCI Bridge Address Mapping       17-6         PLB-to-PCI Address Mapping       17-7         PCI Target Map Configuration       17-8         PCI Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PLB Stater Commands       17-10         PLB Stater Commands       17-10         PLB Stave Read Handling       17-12         Prefetching       17-12         PLB Stave Read Handling       17-12         PLB Stave Write Handling       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PLB Master Commands       17-14         Aborted PLB Requests       17-13         PLB Master Commands       17-14         Aborted PLB Requests       17-15         Handling Writes from PCI Masters       17-17         Misser Commands       17-17         Misser Commands       17-17         Completion Ordering       17-17         Completion Ordering       17-17         Completion Ordering       17-18         PCI Bridge Register Summary       17-19         PCI Bridge Register Summary       17-19         PCI                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                     |        |
| PCI Bridge Address Mapping       17-6         PLB-to-PCI Address Mapping       17-8         PCI Target Map Configuration       17-9         PCI Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PCI Bridge Transaction Handling       17-10         PCI Bridge Transaction Handling       17-10         PLB Slave Read Handling       17-12         Prefetching       17-12         Prefetching       17-12         PLB Slave Read Handling       17-12         Prefetching       17-13         Retried PCI Reads       17-13         PCI-To-PLB Transaction Handling       17-13         PCI-To-PLB Transaction Handling       17-14         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Miscellaneous       17-17         Collision Resolution       17-18         PCI Bridge Register Summary       17-19         PCI Bridge Register Summary       17-21         PMM 0 Local Address Register (PCIL0_PMMOLA)       17-22         PMM 0 Mask/Attribute Register (PCIL0_PMMOPCILA)       17-22         PMM 0 Mask/Attribute Register (PCIL0_PMMIDPCILA)       17-22         PMM 1 Local Address Register (PCIL0_PMMIDP                                                                                                                                                                                                                                                                                                                                                                                                         | PCI-to-PLB Half-Bridge                              | . 17-5 |
| PLB-to-PCI Address Mapping         17-6           PCI Target Map Configuration         17-8           PCI Target Map Configuration         17-9           PCI Bridge Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB-to-PCI Transaction Handling         17-10           PLB Slave Read Handling         17-12           Prefetching         17-12           PLB Slave Read Handling         17-12           PLB Slave Write Handling         17-12           Aborted PLB Requests         17-13           Retried PCI Reads         17-13           PLB Master Commands         17-14           Handling Vrites from PCI Masters         17-15           Handling Writes from PCI Masters         17-17           Miscellaneous         17-18           PCI Bridge Configuration Registers         17-19           PCI Bridge Configuration Registers         17-19           PCI Bridge Local Configuration Registers         17-21           PMM 0 Local Address Register (PCIL0_PMMOPCILA)         17-22           PMM 0 Local Address Register (PCIL0_PMMOPCILA)         17-22           PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)         17-22           PMM 1 DCI Low Address Register (PCIL0_PMMOPCILA)         17                                                                                                                                                                                                                                                                                                                                    |                                                     |        |
| PCI-to-PLB Address Mapping       17-8         PCI Target Map Configuration       17-9         PL Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PCI Bridge Transaction Handling       17-10         PLB Slave Read Handling       17-10         PLB Slave Read Handling       17-12         Prefetching       17-12         PLB Slave Write Handling       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PCL-to-PLB Transaction Handling       17-13         PCL-to-PLB Transaction Handling       17-13         PCL-to-PLB Transaction Handling       17-14         Handling Writes from PCI Masters       17-14         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         PCI Bridge Local Configuration Registers       17-18         PCI Bridge Configuration Register (PCILO_PMMOPCILA)       17-22         PMM 0 Local Address Register (PCILO_PMMOPCILA)       17-22         PMM 0 Docal Address Register (PCILO_PMMOPCILA)       17-22         PMM 1 Docl High Address Register (PCILO_PMMOPCILA)       17-22         PMM 1 Docl Address Register (PCILO_PMMOPCILA)       17-22         PMM 1 Docl Addres                                                                                                                                                                                                                                                                                                                                                                      |                                                     |        |
| PCI Target Map Configuration       17-9         PCI Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PLB Slave Read Handling       17-10         PLB Slave Read Handling       17-12         Prefetching       17-12         Prefetching       17-12         PLB Slave Write Handling       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PLB Master Commands       17-14         Handling Of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Completion Ordering       17-17         Completion Ordering       17-17         Completion Ordering       17-18         PCI Bridge Local Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-19         PCI Bridge Local Configuration Register (PCILO_PMMOLA)       17-22         PMM 0 Local Address Register (PCILO_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-23         PMM 1 Mask/Attribute Register (PCILO_PMMOPCILA)       17-24         PMM 1 Docal Address Register (PCILO_PMMOPCILA)       17-25         PMM 1 Docal Address Register (PCILO_PMMOPCILA                                                                                                                                                                                                                                                                                                                                                                      |                                                     |        |
| PCI Bridge Transaction Handling       17-10         PLB-to-PCI Transaction Handling       17-10         PCI Master Commands       17-10         PLB Slave Read Handling       17-12         Prefetching       17-12         Prefetching       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PCI-to-PLB Transaction Handling       17-13         PLB Master Commands       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Collision Resolution       17-18         PCI Bridge Local Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMMOLA)       17-22         PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)       17-23         PMM 1 Local Address Register (PCIL0_PMMOPCILA)       17-24         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 Mask                                                                                                                                                                                                                                                                                                                                                                      | PCI-to-PLB Address Mapping                          | . 17-8 |
| PLB-to-PCI Transaction Handling         17-10           PCI Master Commands         17-10           PCI Master Commands         17-12           Prefetching         17-12           Prefetching         17-12           Prefetching         17-12           Aborted PLB Requests         17-13           Retried PCI Reads         17-13           PCI-to-PLB Transaction Handling         17-13           PCI to-PLB Transaction Handling         17-13           PLB Master Commands         17-14           Handling of Reads from PCI Masters         17-17           Miscellaneous         17-17           Miscellaneous         17-17           Completion Ordering         17-17           PCI Bridge Register Summary         17-18           PCI Bridge Register Summary         17-19           PCI Bridge Register Summary         17-21           PMM 0 Local Address Register (PCILO_PMMOLA)         17-22           PMM 0 PCI Low Address Register (PCILO_PMMOPCILA)         17-22           PMM 0 PCI Low Address Register (PCILO_PMMMOPCILA)         17-23           PMM 1 Local Address Register (PCILO_PMMMOPCILA)         17-24           PMM 1 Docal Address Register (PCILO_PMMMOPCILA)         17-25           PMM 1 Docal Address Register                                                                                                                                                                                                                                                                                                                                                               | PCI Target Map Configuration                        | . 17-9 |
| PCI Master Commands       17-10         PLB Slave Read Handling       17-12         Prefetching       17-12         PLB Slave Write Handling       17-12         PLB Slave Write Handling       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PCI-to-PLB Transaction Handling       17-13         PLB Master Commands       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-17         PCI Bridge Configuration Registers       17-18         PCI Bridge Local Configuration Registers       17-19         PCI Bridge Local Configuration Register (PCILO_PMMOLA)       17-22         PMM 0 Local Address Register (PCILO_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-23         PMM 1 Local Address Register (PCILO_PMMIPCILA)       17-24         PMM 1 DCI High Address Register (PCILO_PMMIPCILA)       17-25         PMM 1 Local Address Register (PCILO_PMMIPCILA)       17-25         PMM 1 Local Address Register (PCILO_PMMIPCILA)       17-25         PMM 1 Mask/Attribute Register (PCILO_PMMIPCILA)       17-25                                                                                                                                                                                                                                                                                                                                                               |                                                     |        |
| PLB Slave Read Handling       17-12         Prefetching       17-12         PLB Slave Wite Handling       17-12         Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PCI-to-PLB Transaction Handling       17-13         PLB Master Commands       17-13         PLD PLB Transaction Handling       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-17         PCI Producer-Consumer Model       17-18         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCILO_PMMOLA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-23         PMM 1 DCI Low Address Register (PCILO_PMM1MA)       17-24         PMM 1 PCI Lingh Address Register (PCILO_PMM2PCILA)       17-25         PMM 1 PCI Low Address Register (PCILO_PMM2PCILA)       17-25         PMM 1 PCI Low Address Register (PCILO_PMM2PCILA)       17-25         PMM                                                                                                                                                                                                                                                                                                                                                                       |                                                     |        |
| Prefetching17-12PLB Slave Write Handling17-12Aborted PLB Requests17-13Retried PCI Reads17-13PCI-to-PLB Transaction Handling17-13PLB Master Commands17-14Handling of Reads from PCI Masters17-15Handling Writes from PCI Masters17-17Miscellaneous17-17Completion Ordering17-17Completion Ordering17-18PCI Producer-Consumer Model17-18Collision Resolution17-18PCI Bridge Configuration Registers17-19PCI Bridge Local Configuration Registers17-19PCI Bridge Local Address Register (PCIL0_PMMOLA)17-21PMM 0 Local Address Register (PCIL0_PMMOPCILA)17-22PMM 0 PCI Ligh Address Register (PCIL0_PMMOPCILA)17-23PMM 1 Local Address Register (PCIL0_PMMINA)17-23PMM 1 PCI Low Address Register (PCIL0_PMMINA)17-24PMM 1 PCI Ligh Address Register (PCIL0_PMMINA)17-25PMM 1 PCI Ligh Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Local Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1                                                                                                                                                                                                                                                                                                                                                             |                                                     |        |
| , PLB Slave17-12Aborted PLB Requests17-13Retried PCI Reads17-13PCI-to-PLB Transaction Handling17-13PLB Master Commands17-14Handling of Reads from PCI Masters17-15Handling Writes from PCI Masters17-17Miscellaneous17-17Completion Ordering17-18PCI Producer-Consumer Model17-18Collision Resolution17-18PCI Bridge Register Summary17-19PCI Bridge Register Summary17-19PCI Bridge Local Configuration Registers17-21PMM 0 Dacial Address Register (PCIL0_PMM0LA)17-22PMM 0 PCI Ling Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI Ling Address Register (PCIL0_PMM0PCILA)17-23PMM 1 PCI Ling Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-26PMM 2 Local Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Local Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1 Local Address Register (PCIL0_PTM1PCILA)                                                                                                                                                                                                                                                                                                                                          |                                                     |        |
| Aborted PLB Requests       17-13         Retried PCI Reads       17-13         PCI-to-PLB Transaction Handling       17-13         PL Master Commands       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-17         Collision Resolution       17-18         PCI Producer-Consumer Model       17-18         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Register Summary       17-19         PCI Bridge Local Configuration Register (PCILO_PMMOLA)       17-21         PMM 0 Local Address Register (PCILO_PMMORA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCILO_PMMOPCILA)       17-23         PMM 1 Local Address Register (PCILO_PMMIAA)       17-24         PMM 1 PCI High Address Register (PCILO_PMMIAA)       17-25         PMM 1 PCI High Address Register (PCILO_PMMIAA) <td></td> <td></td>                                                                                                                                                                                                                                                                                                                  |                                                     |        |
| Retried PCI Reads       17-13         PCI-to-PLB Transaction Handling       17-13         PLB Master Commands       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-18         PCI Producer-Consumer Model       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Configuration Registers       17-19         PCI Bridge Register Summary       17-19         PCI Bridge Register Summary       17-21         PMM 0 Local Address Register (PCIL0_PMM0LA)       17-22         PMM 0 Mask/Attribute Register (PCIL0_PMM0PCILA)       17-22         PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)       17-23         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 Mask/Attribute Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2                                                                                                                                                                                                                                                                                                                                   |                                                     |        |
| PCI-to-PLB Transaction Handling       17-13         PLB Master Commands       17-14         Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-17         PCI Producer-Consumer Model       17-18         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMMOLA)       17-22         PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)       17-22         PMM 0 PCI Low Address Register (PCIL0_PMMOPCILA)       17-23         PMM 1 Cocal Address Register (PCIL0_PMMOPCILA)       17-23         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMM2PA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)                                                                                                                                                                                                                                                                                                      |                                                     |        |
| PLB Master Commands       17-14         Handling Of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-17         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Register Summary       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMMOLA)       17-22         PMM 0 Local Address Register (PCIL0_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)       17-23         PMM 1 Local Address Register (PCIL0_PMMMOPCILA)       17-24         PMM 1 PCI High Address Register (PCIL0_PMMMPCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMMMPCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI High Address Regist                                                                                                                                                                                                                                                                                                |                                                     |        |
| Handling of Reads from PCI Masters       17-15         Handling Writes from PCI Masters       17-17         Miscellaneous       17-17         Completion Ordering       17-18         PCI Producer-Consumer Model       17-18         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Register Summary       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMMOLA)       17-22         PMM 0 PCI Low Address Register (PCIL0_PMMOPCILA)       17-22         PMM 0 PCI High Address Register (PCIL0_PMMOPCILA)       17-23         PMM 1 DCI Low Address Register (PCIL0_PMMIPCILA)       17-23         PMM 1 Nocal Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Mask/Attribute Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)       17-26         PMM 2 PCI Low Address                                                                                                                                                                                                                                                                                                 | PCI-to-PLB Transaction Handling                     | 17-13  |
| Handling Writes from PCI Masters17-17Miscellaneous17-17Completion Ordering17-18PCI Producer-Consumer Model17-18Collision Resolution17-18PCI Bridge Configuration Registers17-19PCI Bridge Local Configuration Registers17-19PCI Bridge Local Address Register (PCIL0_PMM0LA)17-21PMM 0 Local Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI Ligh Address Register (PCIL0_PMM0PCILA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-24PMM 1 Local Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI Ligh Address Register (PCIL0_PMM1PCILA)17-26PMM 1 PCI Ligh Address Register (PCIL0_PMM1PCILA)17-27PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)17-26PMM 1 PCI Ligh Address Register (PCIL0_PMM2PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM2PCILA)17-26PMM 2 Local Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2PCILA)17-28PTM 2 Local Address Register (PCIL0_PTM1PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2MS)17-28PCI Configuration Registers17-29PCI Configuration Register (PCIL0_PTM2LA)17-29PCI Configuration Address Register (PC                                                                                                                                                                                                                                                                           |                                                     |        |
| Miscellaneous17-17Completion Ordering17-18PCI Producer-Consumer Model17-18Collision Resolution17-18PCI Bridge Configuration Registers17-19PCI Bridge Local Configuration Registers17-19PCI Bridge Local Configuration Registers17-21PMM 0 Local Address Register (PCILO_PMM0LA)17-22PMM 0 Mask/Attribute Register (PCILO_PMM0MA)17-22PMM 0 PCI Low Address Register (PCILO_PMM0PCILA)17-23PMM 0 PCI High Address Register (PCILO_PMM1PCILA)17-24PMM 1 Local Address Register (PCILO_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCILO_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCILO_PMM1PCILA)17-25PMM 1 PCI Low Address Register (PCILO_PMM1PCILA)17-25PMM 1 PCI Low Address Register (PCILO_PMM2LA)17-25PMM 2 Local Address Register (PCILO_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCILO_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCILO_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCILO_PTM2RS)17-27PTM 1 Local Address Register (PCILO_PTM1LA)17-27PTM 1 Local Address Register (PCILO_PTM2LA)17-28PTM 2 Local Address Register (PCILO_PTM2LA)17-29PCI Configuration Registers17-29PCI Configuration Registers17-29PCI Configuration Address Register (PCILO_CCFGADDR)17-30PCI Vendor ID Register (PCICO_CVENDID)17-31                                                                                                                                                                                                                                                                                                                                                                       |                                                     |        |
| Completion Ordering17-18PCI Producer-Consumer Model17-18Collision Resolution17-18PCI Bridge Configuration Registers17-19PCI Bridge Local Configuration Registers17-19PCI Bridge Local Configuration Registers17-21PMM 0 Local Address Register (PCIL0_PMM0LA)17-21PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Local Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM2PCILA)17-25PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2MS)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2MS)17-28PTM 2 Local Address Register (PCIL0_PTM2MS)17-28PTM 2 Local Address Register (PCIL0_PTM2MS)17-28PTM 2 Local Address Register (PCIL0_PTM2A)17-29PCI Configuration Registers17-29PCI Configuration Register (PCIC0_CFGADDR)17-30PCI Configuration Data Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCI                                                                                                                                                                                                                                                                           |                                                     |        |
| PCI Producer-Consumer Model       17-18         Collision Resolution       17-18         PCI Bridge Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMM0LA)       17-21         PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)       17-22         PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)       17-22         PMM 1 Local Address Register (PCIL0_PMM0PCILA)       17-23         PMM 1 Local Address Register (PCIL0_PMM1LA)       17-24         PMM 1 Local Address Register (PCIL0_PMM1PCILA)       17-24         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI High Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-26         PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM2M3)       17-28         PTM 2 Memory Size/Attribute Register (PCIL0_PTM2M3)       17-27         PTM 1 Local Address Re                                                                                                                                                                                                                                                             | Miscellaneous                                       | 17-17  |
| Collision Resolution17-18PCI Bridge Configuration Registers17-19PCI Bridge Register Summary17-19PCI Bridge Local Configuration Registers17-21PMM 0 Local Address Register (PCIL0_PMM0LA)17-21PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI High Address Register (PCIL0_PMM0PCILA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Local Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM2PA)17-25PMM 2 Local Address Register (PCIL0_PMM2PA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2NA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1A)17-27PTM 2 Memory Size/Attribute Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-29PCI Configuration Registers17-29PCI Configuration Registers17-29PCI Configuration Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                      |                                                     |        |
| PCI Bridge Configuration Registers       17-19         PCI Bridge Register Summary       17-19         PCI Bridge Local Configuration Registers       17-21         PMM 0 Local Address Register (PCIL0_PMM0LA)       17-21         PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)       17-22         PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)       17-22         PMM 0 PCI Ligh Address Register (PCIL0_PMM0PCILA)       17-23         PMM 1 Local Address Register (PCIL0_PMM1LA)       17-23         PMM 1 Mask/Attribute Register (PCIL0_PMM1PCILA)       17-24         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)       17-25         PMM 1 PCI Low Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 Local Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-26         PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28                                                                                                                                                                                                                                                                | PCI Producer-Consumer Model                         | 17-18  |
| PCI Bridge Register Summary17-19PCI Bridge Local Configuration Registers17-21PMM 0 Local Address Register (PCIL0_PMM0LA)17-21PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI High Address Register (PCIL0_PMM0PCIHA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Local Address Register (PCIL0_PMM1PCIHA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI Low Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1NS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Memory Size/Attribute Register (PCIL0_PTM2PCIHA)17-28PTM 2 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-29PCI Configuration Registers17-29PCI Configuration Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                               | Collision Resolution                                | 17-18  |
| PCI Bridge Local Configuration Registers17-21PMM 0 Local Address Register (PCIL0_PMM0LA)17-21PMM 0 Mask/Attribute Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI High Address Register (PCIL0_PMM0PCILA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Local Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM1PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Local Address Register (PCIL0_PMM2A)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2A)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM2A)17-28PTM 2 Local Address Register (PCIL0_PTM2A)17-29PTM 2 Local Address Register (PCIL0_PTM2A)17-29PTM 2 Local Address Register (PCIL0_PTM2A)17-29PTM 2 Local Address Register (PCIL0_PTM2A)17-29PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                           |                                                     |        |
| PMM 0 Local Address Register (PCIL0_PMM0LA)17-21PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-23PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Mask/Attribute Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM1PCILA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2LA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2LA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1NS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-29PCI Configuration Registers17-29PCI Configuration Data Register (PCIC0_CFGADDR)17-29PCI Configuration Data Register (PCIC0_CFGDATA)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                  | PCI Bridge Register Summary                         | 17-19  |
| PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)17-22PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-23PMM 0 PCI High Address Register (PCIL0_PMM0PCIHA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI Ligh Address Register (PCIL0_PMM1PCILA)17-25PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2A)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Mask/Attribute Register (PCIL0_PTM2A)17-28PCI Configuration Registers17-29PCI Configuration Address Register (PCIL0_PTM2A)17-29PCI Configuration Data Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PCI Bridge Local Configuration Registers            | 17-21  |
| PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)17-22PMM 0 PCI High Address Register (PCIL0_PMM0PCIHA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2AA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1NS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM2AA)17-28PTM 2 Local Address Register (PCIL0_PTM2AA)17-27PTM 1 Local Address Register (PCIL0_PTM2AA)17-27PTM 2 Local Address Register (PCIL0_PTM2AA)17-28PCI Configuration Registers17-29PCI Configuration Address Register (PCIL0_PTM2AA)17-29PCI Configuration Data Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | PMM 0 Local Address Register (PCIL0_PMM0LA)         | 17-21  |
| PMM 0 PCI High Address Register (PCIL0_PMM0PCIHA)17-23PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-27PTM 1 Local Address Register (PCIL0_PTM2LA)17-27PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)        | 17-22  |
| PMM 1 Local Address Register (PCIL0_PMM1LA)17-23PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1AS)17-27PTM 1 Local Address Register (PCIL0_PTM2A)17-28PTM 2 Local Address Register (PCIL0_PTM2A)17-27PTM 1 Local Address Register (PCIL0_PTM2AS)17-28PTM 2 Local Address Register (PCIL0_PTM2A)17-28PTM 2 Local Address Register (PCIL0_PTM2A)17-29PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                     |        |
| PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)17-24PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM2NS)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PCI Configuration Registers17-29PCI Configuration Data Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PMM 0 PCI High Address Register (PCIL0_PMM0PCIHA)   | 17-23  |
| PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)17-24PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1PCIHA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1PCIHA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Memory Size/Attribute Register (PCIL0_PTM2PCILA)17-28PTM 2 Local Address Register (PCIL0_PTM2AS)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-29PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PMM 1 Local Address Register (PCIL0_PMM1LA)         | 17-23  |
| PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)        | 17-24  |
| PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)17-25PMM 2 Local Address Register (PCIL0_PMM2LA)17-25PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)17-25PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)17-26PMM 2 PCI High Address Register (PCIL0_PMM2PCILA)17-27PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 1 Local Address Register (PCIL0_PTM1LA)17-27PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)17-28PTM 2 Local Address Register (PCIL0_PTM2LA)17-28PCI Configuration Registers17-29PCI Configuration Address Register (PCIC0_CFGADDR)17-30PCI Vendor ID Register (PCIC0_VENDID)17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)    | 17-24  |
| PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)       17-25         PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-26         PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Local Address Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)   | 17-25  |
| PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)       17-26         PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Local Address Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PMM 2 Local Address Register (PCIL0_PMM2LA)         | 17-25  |
| PMM 2 PCI High Address Register (PCIL0_PMM2PCIHÁ)       17-27         PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Local Address Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM1LA)       17-28         PTM 2 Local Address Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)        | 17-25  |
| PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)       17-27         PTM 1 Local Address Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PMM 2 PCI Low Address Register (PCIL0_PMM2PCILA)    | 17-26  |
| PTM 1 Local Address Register (PCIL0_PTM1LA)       17-27         PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)   | 17-27  |
| PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)       17-28         PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS) | 17-27  |
| PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PTM 1 Local Address Register (PCIL0_PTM1LA)         | 17-27  |
| PTM 2 Local Address Register (PCIL0_PTM2LA)       17-28         PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                     |        |
| PCI Configuration Registers       17-29         PCI Configuration Address Register (PCIC0_CFGADDR)       17-29         PCI Configuration Data Register (PCIC0_CFGDATA)       17-30         PCI Vendor ID Register (PCIC0_VENDID)       17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                     |        |
| PCI Configuration Address Register (PCIC0_CFGADDR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PCI Configuration Registers                         | 17-29  |
| PCI Configuration Data Register (PCIC0_CFGDATA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCI Configuration Address Register (PCIC0_CFGADDR)  | 17-29  |
| PCI Vendor ID Register (PCIC0_VENDID) 17-31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                     |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCI Device ID Register (PCIC0_DEVID)                | 17-31  |

| PCI Command Register (PCIC0_CMD)                               | 17-31 |
|----------------------------------------------------------------|-------|
| PCI Status Register (PCIC0_STATUS)                             | 17-33 |
| PCI Revision ID Register (PCIC0_REVID)                         |       |
| PCI Class Register (PCIC0_CLS)                                 |       |
| PCI Cache Line Size Register (PCIC0_CACHELS)                   |       |
| PCI Latency Timer Register (PCIC0_LATTIM)                      | 17-36 |
| PCI Header Type Register (PCIC0_HDTYPE)                        | 17-36 |
| PCI Built-In Self Test (BIST) Control Register (PCIC0_BIST)    | 17-37 |
| Unused PCI Base Address Register Space                         | 17-37 |
| PCI PTM 1 BAR (PCIC0_PTM1BAR)                                  |       |
| PCI PTM 2 BAR (PCICO_PTM2BAR)                                  | 17-38 |
| PCI Subsystem Vendor ID Register (PCIC0_SBSYSVID)              |       |
| PCI Subsystem ID Register (PCIC0_SBSYSID)                      |       |
| PCI Capabilities Pointer (PCIC0_CAP)                           |       |
| PCI Interrupt Line Register (PCIC0_INTLN)                      | 17-40 |
| PCI Interrupt Pin Register (PCIC0_INTPN)                       | 17-40 |
| PCI Minimum Grant Register (PCIC0_MINGNT)                      | 17-41 |
| PCI Maximum Latency Register (PCIC0_MAXLTNCY)                  |       |
| PCI Interrupt Control/Status Register (PCIC0_ICS)              |       |
|                                                                |       |
| Error Enable Register (PCIC0_ERREN)                            |       |
| Error Status Register (PCIC0_ERRSTS)                           |       |
| Bridge Options 1 Register (PCIC0_BRDGOPT1)                     |       |
| PLB Slave Error Syndrome Register 0 (PCIC0_PLBBESR0)           |       |
| PLB Slave Error Syndrome Register 1 (PCIC0_PLBBESR1)           | 17-47 |
| PLB Slave Error Address Register (PCIC0_PLBBEAR)               | 17-48 |
| Capability Identifier (PCIC0_CAPID)                            | 17-49 |
| Next Item Pointer (PCIC0_NEXTIPTR)                             | 17-49 |
| Power Management Capabilities (PCIC0_PMC)                      | 17-50 |
| Power Management Control/Status Register (PCIC0_PMCSR)         | 17-50 |
| PMCSR PCI-to-PCI Bridge Support Extensions (PCIC0_PMCSRBSE)    | 17-51 |
| PCI Data Register (PCICO_DATA)                                 |       |
| Bridge Options 2 Register (PCIC0_BRDGOPT2)                     | 17-52 |
| Power Management State Change Request Register (PCIC0_PMSCRR)  | 17-54 |
| Error Handling                                                 |       |
| PLB Unsupported Transfer Type                                  |       |
| PCI Master Abort                                               |       |
| Bridge PCI Master Receives Target Abort While PCI Bus Master   | 17-55 |
| Didge FCI Master neceives raiger Abort While FCI bus Master    | 17-50 |
| PCI Target Data Bus Parity Error Detection                     |       |
| PCI Master Data Bus Parity Error Detection                     |       |
| PCI Address Bus Parity Error While PCI Target                  |       |
| PLB Master Bus Error Detection                                 |       |
| PCI Bridge Clocking Configuration                              |       |
| PCI Power Management Interface                                 | 17-59 |
| Capabilities and Power Management Status and Control Registers |       |
| Power State Control                                            | 17-59 |
| Changing Power States                                          | 17-60 |
| PCI Bridge Reset and Initialization                            |       |
| Address Map Initialization                                     | 17-61 |
| Other Configuration Register Initialization                    |       |
| Target Bridge Initialization                                   |       |
| Local Processor Boot from PCI Memory                           |       |
| Type 0 Configuration Cycles for Other Devices                  |       |
|                                                                |       |
| Timing Diagrams                                                | 17.65 |
| PCI Timing Diagram Descriptions                                |       |
| PCI Master Burst Read From SDRAM                               |       |
| PCI Master Burst Write To SDRAM                                | 17-65 |
|                                                                |       |

| CPU Read From PCI Memory Slave, Nonprefetching                      |       |
|---------------------------------------------------------------------|-------|
| CPU Read From PCI Memory Slave, Prefetching                         | 17-65 |
| CPU Write To PCI Memory Slave                                       | 17-65 |
| PCI Memory To SDRAM DMA Transfer                                    | 17-66 |
| SDRAM To PCI Memory DMA Transfer                                    | 17-66 |
| Asynchronous                                                        |       |
| Synchronous                                                         | 17-92 |
| Chapter 18. Direct Memory Access Controller                         |       |
| External Interface Signals                                          |       |
| Functional Overview                                                 | 18-2  |
| Peripheral Mode Transfers                                           | 18-2  |
| Memory-to-Memory Transfers                                          |       |
| Scatter/Gather Transfers                                            | 18-4  |
| Configuration and Status Registers                                  | 18-4  |
| DMA Polarity Configuration Register (DMA0_POL)                      | 18-5  |
| DMA Sleep Mode Register (DMA0_SLP)                                  | 18-6  |
| DMA Status Register (DMA0_SR)                                       | 18-7  |
| DMA Channel Control Registers (DMA0_CR0-DMA0_CR3)                   | 18-8  |
| DMA Source Address Registers (DMA0_SA0-DMA0_SA3)                    | 18-10 |
| DMA Destination Address Registers (DMA0_DA0-DMA0_DA3)               | 18-11 |
| DMA Count Registers (DMA0_CT0-DMA0_CT3)                             |       |
| DMA Scatter/Gather Descriptor Address Registers (DMA0_SG0-DMA0_SG3) | 18-12 |
| DMA Scatter/Gather Command Register (DMA0_SGC)                      |       |
| Channel Priorities                                                  | 18-13 |
| Data Parity During DMA Peripheral Transfers                         |       |
| Errors                                                              |       |
| Address Alignment Error                                             |       |
| PLB Timeout<br>Slave Errors                                         | 10-10 |
| DMA Interrupts                                                      |       |
| Scatter/Gather Transfers                                            |       |
| Programming the DMA Controller                                      |       |
| Peripheral Mode Transfers                                           |       |
| Memory-to-Memory Transfers                                          |       |
| Software-Initiated Memory-to-Memory Transfers (Non-Deviced Paced)   | 18-21 |
| Chapter 19. Ethernet Media Access Controller                        |       |
| EMAC Features                                                       | 19-2  |
| EMAC Operation                                                      |       |
| MAL Slave Logic                                                     |       |
| OPB Slave Logic                                                     |       |
| Ethernet Address Match Logic                                        |       |
| Configuration and Status Registers                                  | 19-4  |
| Wake On LAN Logic                                                   | 19-4  |
| Ethernet MAC                                                        |       |
| EMAC Loop-Back Modes                                                |       |
| EMAC Transmit Operation                                             | 19-5  |
| Arbitration Between TX Channels                                     | 19-6  |
| Independent Mode                                                    |       |
| Dependent Mode                                                      |       |
| MAL TX Descriptor Control/Status Field                              |       |
| Early Packet Termination in Transmit                                | 19-9  |
| Empty Packets                                                       |       |
| Automatic Retransmission of Collided Packets                        |       |
| Inter-Packet Gap (IPG) Tuning                                       |       |
| Full-Duplex Operation                                               | 19-9  |

| Packet Content Configuration Options                                                   | 19-10 |
|----------------------------------------------------------------------------------------|-------|
| EMAC Receive Operation                                                                 | 19-12 |
| EMAC – MAL RX Packet Transfer Flow                                                     | 19-12 |
| MAL RX Descriptor Status                                                               |       |
| Early Packet Termination In Receive                                                    |       |
| Discarding Packets During Receive                                                      | 19-14 |
| WOL Support                                                                            | 19-14 |
| EMAC WOL Support                                                                       |       |
| Flow Control                                                                           |       |
| MAC Control Packet                                                                     |       |
| Control Packet Transmission                                                            |       |
| Integrated Flow Control                                                                |       |
| Control Packet Reception                                                               |       |
| VLAN Support                                                                           |       |
| VLAN Tagged Packet Transmission                                                        | 19-19 |
| VLAN Tagged Packet Reception                                                           | 19-19 |
| Address Match Mechanism                                                                |       |
| Non-WOL Mode                                                                           |       |
| WOL Mode                                                                               |       |
| EMAC Registers                                                                         |       |
| Mode Register 0 (EMAC0_MR0)                                                            |       |
| Mode Register 1 (EMAC0_MR1)                                                            |       |
| Transmit Mode Register 0 (EMAC0_TMR0)                                                  |       |
| Transmit Mode Register 1 (EMAC0_TMR1)                                                  | 19-28 |
| Low-Priority Requests                                                                  |       |
| Urgent-Priority Requests                                                               |       |
| Receive Mode Register (EMACO_RMR)                                                      |       |
| Interrupt Status Register (EMAC0_ISR)<br>Interrupt Status Enable Register (EMAC0_ISER) | 19-30 |
| Individual Address High (EMAC0_IAHR)                                                   |       |
| Individual Address High (EMACO_IAHA)                                                   |       |
| VLAN TPID Register (EMAC0_VTPID)                                                       |       |
|                                                                                        |       |
| VLAN TCI Register (EMAC0_VTCI)<br>Pause Timer Register (EMAC0_PTR)                     |       |
| Individual Address Hash Tables 1–4 (EMAC0_IAHT1–EMAC0_IAHT4)                           |       |
| Group Address Hash Tables 1–4 (EMAC0_GAHT1–EMAC0_IAH14)                                | 19-37 |
| Last Source Address High (EMACO_LSAH)                                                  | 19-37 |
| Last Source Address Low (EMACO_LSAH)                                                   |       |
| Inter-Packet Gap Value Register (EMAC0_LSAL)                                           | 10 20 |
| STA Control Register (EMAC0_STACR)                                                     | 10 20 |
| Transmit Request Threshold Register (EMACO_TRTR)                                       | 19-39 |
| Receive Low/High Water Mark Register (EMACO_RWMR)                                      | 10.41 |
| Number of Octets Transmitted (EMAC0_OCTX)                                              |       |
| Number of Octets Received (EMACO_OCTA)                                                 | 10.42 |
| MII Interface                                                                          |       |
| MII Station Management Interface                                                       |       |
| EMAC – MII Interface                                                                   |       |
| MAL – EMAC Packet Transfer Flow                                                        | 10-43 |
| Programming Notes                                                                      | 19-43 |
| Programming Notes<br>Power-Up and Initialization                                       | 10-44 |
| Reset Options                                                                          | 10-44 |
| Scenario 1                                                                             |       |
| Scenario 2                                                                             |       |
| Scenario 3                                                                             |       |
|                                                                                        | 10 40 |

| Chapter 20. Memory Access Layer                                      |        |
|----------------------------------------------------------------------|--------|
| MAL Features                                                         |        |
| MAL – Internal Structure                                             | . 20-3 |
| PLB Master                                                           | . 20-3 |
| OPB Master                                                           |        |
| TX Channel Handler                                                   |        |
| RX Channel Handler                                                   | 20-3   |
| TX Channel Arbiter                                                   | . 20-4 |
| RX Channel Arbiter                                                   | . 20-4 |
| TX Common Channel Logic                                              | . 20-4 |
| RX Common Channel Logic                                              | . 20-4 |
| Register Map File                                                    |        |
| Transmit and Receive Operations                                      | . 20-4 |
| Buffer Descriptor Overview                                           | . 20-7 |
| Transmit Software Interface                                          | . 20-9 |
| Wrapping the BD Table for Transmit                                   | 20-10  |
| Continuous Mode for Transmit                                         | 20-10  |
| Back Up a Packet for Transmit                                        |        |
| Descriptor Not Valid for Transmit                                    | 20-11  |
| Scroll Descriptors for Transmit                                      |        |
| Receive Software Interface                                           |        |
| Wrapping the BD Table for Receive                                    | 20-12  |
| Continuous Mode for Receive                                          |        |
| Descriptor Not Valid for Receive                                     |        |
| Buffer Length for Receive                                            |        |
| Descriptor Buffer Status/Control Fields                              |        |
| Information from a Software Device Driver Directed To MAL and COMMAC |        |
| Information from MAL and COMMAC Directed to Software                 | 20-14  |
| Status/Control Field Handling                                        |        |
| Status/Control Field Format                                          |        |
| TX Status/Control Field Format                                       | 20-15  |
| Bit 0 – R – Ready                                                    |        |
| Bit 1 – W – Wrap                                                     |        |
| Bit 2 – CM – Continuous Mode                                         |        |
| Bit 3 – L – Last                                                     | 20-15  |
| Bit 4 – Reserved                                                     |        |
| Bit 5 – I – Interrupt                                                |        |
| Bits 6 to 15                                                         |        |
| RX Status/Control Field Format                                       |        |
| Bit 0 – E – Empty                                                    |        |
| Bit 1 – W – Wrap                                                     |        |
| Bit 2 – CM – Continuous Mode                                         |        |
| Bit 3 – L – Last                                                     |        |
| Bit 4 – F – First                                                    |        |
| Bit 5 – I – Interrupt                                                |        |
| Bits 6 to 15                                                         |        |
| MAL Programming Notes                                                |        |
| MAL Initialization                                                   | 20-18  |
| Interrupts                                                           |        |
| Error Handling                                                       |        |
| Error Detection                                                      |        |
| Indicated Errors                                                     |        |
| Error Handling Registers                                             |        |
| Operational Error Modes                                              |        |
| Resolution of an Error Situation                                     |        |
| Interrupts To Software                                               |        |
| ······································                               |        |

| MAL Registers                                                     | 20-24 |
|-------------------------------------------------------------------|-------|
| MAL Configuration Register (MAL0_CFG) 2                           |       |
| Channel Active Set and Reset Registers 2                          | 20-26 |
| End of Buffer Interrupt Status Registers 2                        |       |
| Error Registers                                                   | 20-29 |
| MAL Error Status Register (MAL0_ESR) 2                            | 20-29 |
| MAL Interrupt Enable Register (MAL0_IER) 2                        | 20-31 |
| Descriptor Error Interrupt Registers (MAL0_TXDEIR, MAL0_RXDEIR) 2 |       |
| Channel Table Pointer Registers (MAL0_TXCTPxR, MAL0_RXCTP0R) 2    | 20-33 |
| Chapter 21. Serial Port Operations                                | 21-1  |
| Functional Description                                            | 21-1  |
| Serial Input Clocking                                             |       |
| UART Registers                                                    | 21-4  |
| Receiver Buffer Registers (UARTx_RBR)                             |       |
| Transmitter Holding Registers (UARTx_THR)                         |       |
| Interrupt Enable Registers (UARTx_IER)                            |       |
| Interrupt Identification Registers (UARTx_IIR)                    |       |
| FIFO Control Registers (UARTx_FCR)                                |       |
| Line Control Registers (UARTx_LCR)                                |       |
| Modem Control Registers (UARTx_MCR)                               | 21-10 |
| Line Status Registers (UARTx_LSR)                                 |       |
| Modem Status Registers (UARTx_MSR)                                |       |
| Scratchpad Registers (UARTx_SCR)                                  |       |
| Divisor Latch LSB and MSB Registers (UARTx_DLL, UARTx_DLM)        | 21-14 |
| FIFO Operation                                                    | 21-15 |
| Interrupt Mode                                                    |       |
| Receiver                                                          |       |
| Transmitter                                                       |       |
| Polled Mode                                                       |       |
| UART and Sleep Mode                                               |       |
| DMA Operation                                                     |       |
| Chip Control Register 0 (CPC0_CR0)                                |       |
| Transmitter DMA Mode                                              | 21-17 |
| Receiver DMA Mode                                                 | 21-10 |
|                                                                   |       |
| Chapter 22. IIC Bus Interface                                     |       |
| Addressing                                                        |       |
| Addressing Modes                                                  |       |
| Seven-Bit Addresses                                               |       |
| Ten-Bit Addresses                                                 |       |
| IIC Registers                                                     |       |
| IIC Register Descriptions                                         |       |
| IICO Master Data Buffer                                           |       |
| IICO Slave Data Buffer                                            |       |
| IIC0 Low Master Address Register                                  |       |
| IIC0 High Master Address Register                                 |       |
| IIC0 Control Register                                             |       |
|                                                                   | 22-8  |
| IIC0 Status Register                                              |       |
| IIC0 Extended Status Register                                     |       |
| IIC0 Low Slave Address Register 2                                 |       |
| IIC0 High Slave Address Register                                  |       |
| IIC0 Clock Divide Register 2                                      |       |
| IIC0 Interrupt Mask Register 2                                    |       |
| IIC0 Transfer Count Register                                      |       |
| IIC0 Extended Control and Slave Status Register 2                 | 22-18 |

| IIC0 Direct Control Register                  | 22-20  |
|-----------------------------------------------|--------|
| Interrupt Handling                            | 22-21  |
| General Considerations                        | 22-22  |
| Chapter 23. GPIO Operations                   | .23-1  |
| GPIO Controller Overview                      | . 23-1 |
| Features                                      |        |
| GPIO Interface Signals                        | . 23-2 |
| External Macro Signals                        | . 23-2 |
| External Module Signals                       |        |
| Clock and Power Management                    | . 23-4 |
| GPIO Register Overview                        |        |
| GPIO Register Reset Values                    |        |
| Detailed Register Description                 |        |
| GPIO Output Register (GPIO0_OR)               |        |
| GPIO Three-State Control Register (GPIO0_TCR) |        |
| GPIO Open Drain Register (GPIO0_ODR)          |        |
| GPIO Input Register (GPIO0_IR)                |        |
| Part V. Reference                             | V-1    |
| Chapter 24. Instruction Set                   | .24-1  |
| Instruction Set Portability                   |        |
| Instruction Formats                           |        |
| Pseudocode                                    |        |
| Operator Precedence                           |        |
| Register Usage                                |        |
| Alphabetical Instruction Listing              |        |
| add                                           |        |
| addc                                          |        |
| adde                                          | . 24-8 |
| addi                                          | . 24-9 |
| addic                                         | 24-10  |
| addic.                                        | 24-11  |
| addis                                         |        |
| addme                                         |        |
| addze                                         |        |
| and                                           |        |
| and                                           |        |
| andi                                          |        |
| andis.                                        |        |
| b                                             |        |
| bc                                            |        |
| bctr                                          |        |
| bccir                                         |        |
|                                               |        |
| cmp                                           |        |
|                                               |        |
| cmpl                                          |        |
| cmpli<br>cntlzw                               |        |
|                                               |        |
| crand                                         |        |
| crandc                                        |        |
| Creqv                                         |        |
| crnand                                        |        |
| crnor                                         |        |
| cror                                          | 24-44  |

| crorc    |         |
|----------|---------|
| Crxor    | -       |
| dcba     |         |
| dcbf     | 24-49   |
| dcbi     |         |
| dcbst    | 24-51   |
| dcbt     | 24-52   |
| dcbtst   | 24-53   |
| dcbz     | 24-54   |
| dccci    | 24-56   |
| dcread   | 24-57   |
| divw     |         |
| divwu    |         |
| eieio    |         |
| eqv      |         |
| extsb    |         |
| extsb    |         |
| icbi     |         |
| icbt     |         |
| iccci    |         |
|          |         |
| icread   |         |
| isync    |         |
| lbz      |         |
| lbzu     |         |
| lbzux    |         |
| lbzx     |         |
| lha      |         |
| lhau     |         |
| lhaux    | - · · · |
| lhax     |         |
| lhbrx    |         |
| lhz      |         |
| lhzu     |         |
| lhzux    |         |
| lhzx     |         |
| lmw      |         |
| lswi     |         |
| lswx     |         |
|          |         |
| lwbrx    |         |
| lwz      |         |
| lwzu     |         |
| lwzux    |         |
| lwzx     | 24-94   |
| macchw   | 24-95   |
| macchws  | 24-96   |
| macchwsu | 24-97   |
| macchwu  | 24-98   |
| machhw   | 24-99   |
| machhws  | 24-100  |
| machhwsu | 24-101  |
| machhwu  | 24-102  |
| maclhw   | 24-103  |
| maclhws  | 24-104  |
|          |         |

| maclhwsu   | 94 105    |
|------------|-----------|
| machwu     |           |
| machwo     |           |
| mcrxr      |           |
| mfcr       |           |
| mfdcr      |           |
| mider      |           |
| minisi     |           |
| mispi      |           |
| mtcrf      |           |
| mtder      |           |
| mtaci      |           |
| mtspr      |           |
| mich       |           |
| mulchwu    |           |
| mulhhw     |           |
| mulhhwu    |           |
| mulhw      |           |
| mulhwu     |           |
| mulhw      |           |
| mulihwu    |           |
| mulli      |           |
| muliw      |           |
| nand       |           |
| neg        |           |
| nmacchw    |           |
| nmacchws   |           |
| nmachhw    |           |
| nmachhws   |           |
| nmachws    |           |
| nmachws    |           |
| nor        |           |
| 0r         |           |
| or         |           |
| ori        |           |
| oris       |           |
| rfci       |           |
| fi         |           |
| rlwimi     |           |
| riwinm     |           |
| riwnm      |           |
| SC         |           |
| scslw      |           |
| siw        |           |
| srawi      |           |
| Srawi      | - · · • · |
| siwsib     |           |
| stb        |           |
| stbu       |           |
| stbux      |           |
| stbx       |           |
|            |           |
| sthbrxsthu |           |
| sthux      |           |
| JUIUA      | 2-1-103   |

| sthx                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stmw                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| stswi                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| stswx                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| stw                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                      |
| stwbrx                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                      |
| stwcx.                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                      |
| stwu                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| stwux                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| Stwt                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| subf                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| subfc                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| subic                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                      |
| subfic                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                      |
| subfme                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                      |
| subfze                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                      |
| sync                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| tlbia                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| tlbre                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| tlbsx                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| tlbsync                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                      |
| tlbwe                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| tw                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                      |
| twi                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                      |
| wrtee                                                                                                                                                                                                                                        | 24-196                                                                                                                                                                                                                               |
| wrteei                                                                                                                                                                                                                                       | 24-197                                                                                                                                                                                                                               |
| xor                                                                                                                                                                                                                                          | 24-198                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                      |
| xori                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                      |
| xori<br>xoris                                                                                                                                                                                                                                | 24-199                                                                                                                                                                                                                               |
| xoris                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| xoris Chapter 25. Register Summary                                                                                                                                                                                                           |                                                                                                                                                                                                                                      |
| xoris<br>Chapter 25. Register Summary<br>Reserved Registers                                                                                                                                                                                  |                                                                                                                                                                                                                                      |
| xoris<br>Chapter 25. Register Summary<br>Reserved Registers<br>Reserved Fields                                                                                                                                                               |                                                                                                                                                                                                                                      |
| xoris                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                      |
| xoris Chapter 25. Register Summary Reserved Registers Reserved Fields General Purpose Registers Machine State Register and Condition Register                                                                                                | 24-199<br>24-200<br><b>25-1</b><br>25-1<br>25-1<br>25-1<br>25-1<br>25-1                                                                                                                                                              |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br><b>25-1</b><br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1                                                                                                                                                      |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3                                                                                                                                                     |
| xoris<br>Chapter 25. Register Summary<br>Reserved Registers<br>Reserved Fields<br>General Purpose Registers<br>Machine State Register and Condition Register<br>Special Purpose Registers<br>Time Base Registers<br>Device Control Registers | 24-199<br>24-200<br><b>25-1</b><br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-3<br>25-3<br>25-3                                                                                                                              |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br><b>25-1</b><br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4                                                                                                                      |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6                                                                                                                     |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7                                                                                                                     |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8                                                                                                             |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-8<br>25-9<br>25-9                                                                                     |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10                                                                                                    |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-6<br>25-7<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10                                                                                           |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13                                                                                         |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-14                                                                         |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-13<br>25-14<br>25-14<br>25-15                                                               |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13<br>25-14<br>25-15<br>25-17                                              |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-11<br>25-14<br>25-15<br>25-17<br>25-20                                     |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13<br>25-14<br>25-15<br>25-17<br>25-20<br>25-20                            |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13<br>25-14<br>25-15<br>25-17<br>25-20<br>25-21                            |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13<br>25-14<br>25-15<br>25-17<br>25-20<br>25-21<br>25-22<br>25-23          |
| xoris                                                                                                                                                                                                                                        | 24-199<br>24-200<br>25-1<br>25-1<br>25-1<br>25-1<br>25-3<br>25-4<br>25-4<br>25-4<br>25-4<br>25-6<br>25-7<br>25-8<br>25-9<br>25-10<br>25-10<br>25-10<br>25-13<br>25-14<br>25-15<br>25-17<br>25-20<br>25-21<br>25-22<br>25-23<br>25-24 |

| CPC0_SR                 | 25-28 |
|-------------------------|-------|
| CR                      | 25-29 |
| CTR                     | 25-30 |
| DAC1-DAC2               | 25-31 |
| DBCR0                   | 25-32 |
| DBCR1                   | 25-34 |
| DBSR                    |       |
| DCCR                    | 25-38 |
| DCP0_ADDR0-DCP0_ADDR1   | 25-40 |
| DCP0_CFG                |       |
| DCP0_CFGADDR            |       |
| DCP0_CFGDATA            | 25-43 |
| DCP0_ESR                |       |
| DCP0_ID                 |       |
| DCP0_ITOR0-DCP0_ITOR3   |       |
| DCP0_MEMBEAR            |       |
| DCP0_PLBBEAR            |       |
| DCP0_RAM0-DCP0_RAM3FF   |       |
| DCP0_VER                |       |
| DCWR                    | 25-52 |
| DEAR                    |       |
| DMA0_CR0-DMA0_CR3       |       |
| DMA0_CT0-DMA0_CT3       |       |
| DMA0_DA0-DMA0_DA3       |       |
| DMA0_PAC-DMA0_DA3       |       |
| DMA0_F0L                |       |
| DMA0_SA0-DMA0_SA3       |       |
| DMA0_SGC                |       |
| DMA0_SGC                |       |
| DMA0_SLP                |       |
| DVCR1-DVCR2             |       |
|                         |       |
| EBC0_BEAR               |       |
| EBC0_BESR0              |       |
| EBC0_BESR1              |       |
| EBC0_BnAP               |       |
| EBC0_BnCR               |       |
| EBC0_CFG                |       |
| EBC0_CFGADDR            |       |
| EBC0_CFGDATA            | 25-79 |
| EMAC0_GAHT1-EMAC0_GAHT4 |       |
| EMAC0_IAHR              | 25-81 |
| EMAC0_IAHT1-EMAC0_IAHT4 |       |
| EMAC0_TMR0              |       |
| EMAC0_TMR1              |       |
| EMAC0_TRTR              |       |
| EMAC0_VTCI              |       |
| EMAC0_VTPID             |       |
| ESR                     |       |
| EVPR                    |       |
| GPIO0_IR                |       |
| GPIO0_ODR               |       |
| GPIO0_OR                |       |
| GPIO0_TCR               |       |
| GPR0-GPR31              | 25-94 |

| IAC1-IAC4        | 05.05  |
|------------------|--------|
|                  |        |
|                  |        |
| ICDBDR           |        |
|                  |        |
|                  |        |
| IICO_DIRECTCNTL  |        |
| IICO_EXTSTS      |        |
| IICO_HMADR       |        |
| IICO_HSADR       | 25-105 |
| IICO_INTRMSK     |        |
| IICO_LMADR       |        |
| IICO_LSADR       |        |
| IIC0_MDBUF       |        |
| IICO_MDCNTL      |        |
| IIC0_SDBUF       | 25-111 |
| IIC0_STS         |        |
| IICO_XFRCNT      |        |
| IIC0_XTCNTLSS    | 25-114 |
| LR               | 25-116 |
| MAL0_CFG         | 25-117 |
| MAL0_ESR         | 25-119 |
| MALO_IER         | 25-121 |
| MAL0 RCBS0       | 25-122 |
| MALO_RXCARR      | 25-123 |
| MALO_RXCASR      |        |
| MAL0_RXCTPxR     |        |
| MALO_RXDEIR      |        |
| MAL0_RXEOBISR    |        |
| MALO_TXCARR      |        |
| MAL0_TXCASR      |        |
| MAL0_TXCTPxR     |        |
| MALO_TXDEIR      |        |
| MAL0_TXEOBISR    |        |
| MSR              |        |
| OCM0_DSARC       |        |
| OCMO_DSANC       |        |
| OCM0_ISARC       |        |
| OCM0_ISARC       |        |
| OPBA0_CR         |        |
|                  |        |
| OPBA0_PR         |        |
| PCI_BAR0PCI_BAR0 |        |
| PCICO_BIST       |        |
| PCIC0_BRDGOPT1   |        |
| PCIC0_BRDGOPT2   |        |
| PCIC0_CACHELS    |        |
| PCICO_CAP        |        |
| PCICO_CAPID      |        |
| PCIC0_CFGADDR    |        |
| PCIC0_CFGATA     |        |
| PCIC0_CLS        |        |
| PCIC0_CMD        |        |
| PCIC0_DATA       |        |
| PCIC0_DEVID      |        |
| PCIC0_ERREN      | 25-155 |
|                  |        |

| PCIC0_ERRSTS               | 25-156 |
|----------------------------|--------|
| PCICO_HDTYPE               | 25-157 |
| PCICO_ICS                  |        |
| PCICO_INTLN                |        |
| PCICO_INTPN                |        |
| PCICO_LATTIM               |        |
| PCICO_MAXLTNCY             |        |
| PCICO_MINGNT               |        |
| PCICO_NEXTIPTR             |        |
| PCICO_PLBBEAR              |        |
| PCICO_PLBBESR0             |        |
| PCICO_PLBBESR1             |        |
| PCICO_PLOBESRT             |        |
| PCICO_PMCSR                |        |
|                            |        |
| PCIC0_PMCSRBSE             |        |
| PCIC0_PMSCRR               |        |
| PCICO_PTM1BAR              |        |
| PCICO_PTM2BAR              |        |
| PCIC0_REVID                |        |
| PCIC0_SBSYSID              |        |
| PCIC0_SBSYSVID             |        |
| PCIC0_STATUS               |        |
| PCIC0_VENDID               | 25-181 |
| PCILO_PMMOLA               |        |
| PCIL0_PMM0MA               | 25-183 |
| PCIL0_PMM0PCIHA            |        |
| PCIL0_PMM0PCILA            |        |
| PCIL0_PMM1LA               | 25-186 |
| PCIL0_PMM1MA               | 25-187 |
| PCIL0_PMM1PCIHA            |        |
| PCIL0_PMM1PCILA            | 25-189 |
| PCIL0_PMM2LA               |        |
| PCIL0_PMM2MA               |        |
| PCIL0_PMM2PCIHA            |        |
| PCIL0_PMM2PCILA            |        |
| PCILO_PTM1LA               |        |
| PCILO_PTM1MS               | 25-195 |
| PCILO_PTM2LA               |        |
| PCILO_PTM2MS               |        |
| PID                        |        |
| PIT                        |        |
| PLB0_ACR                   |        |
| PLB0_BEAR                  | 25-201 |
| PLB0_BESR                  |        |
| POB0 BEAR                  |        |
| POB0 BESR0                 |        |
| POB0_BESR1                 |        |
|                            |        |
| PVRSDRAM0_B0CR-SDRAM0_B3CR |        |
|                            |        |
| SDRAM0_BEAR                |        |
| SDRAM0_BESR0               |        |
| SDRAM0_BESR1               |        |
| SDRAM0_CFG                 |        |
| SDRAM0_CFGADDR             | 25-216 |

| SDRAM0_CFGDATA                                        |        |
|-------------------------------------------------------|--------|
| SDRAM0_ECCCFG                                         |        |
| SDRAM0_ECCESR                                         |        |
| SDRAM0_PMIT                                           |        |
| SDRAM0_RTR                                            |        |
| SDRAMO_TR                                             |        |
| SGR                                                   |        |
| SLER                                                  |        |
| SPRG0–SPRG7                                           | 25-228 |
| SRR0                                                  | 25-229 |
| SRR1                                                  | 25-230 |
| SRR2                                                  | 25-231 |
| SRR3                                                  | 25-232 |
| SUOR                                                  | 25-233 |
| TBL                                                   | 25-235 |
| TBU                                                   | 25-236 |
| TCR                                                   |        |
| TSR                                                   |        |
| UARTx_DLL                                             |        |
| UARTx_DLM                                             |        |
| UARTX_FCR                                             |        |
| UARTX_IER                                             |        |
| UARTX_IIR                                             |        |
| UARTx_LCR                                             |        |
| UARTX_LCR                                             |        |
| UARTX_LSR                                             |        |
|                                                       |        |
| UARTx_MSR                                             |        |
|                                                       |        |
|                                                       |        |
| UARTx_THR                                             |        |
| UIC0_CR                                               |        |
|                                                       |        |
| UICO_MSR                                              |        |
| UICO_PR                                               |        |
| UIC0_SR                                               |        |
| UICO_TR                                               |        |
| UIC0_VCR                                              |        |
| UIC0_VR                                               |        |
| USPRG0                                                |        |
| XER                                                   |        |
| ZPR                                                   | 25-274 |
| Chapter 26. Signal Summary                            | 26-1   |
| Signals Listed Alphabetically                         |        |
| Signal Descriptions                                   |        |
|                                                       |        |
| A. Instruction Summary                                |        |
| Instruction Set and Extended Mnemonics - Alphabetical | A-1    |
| Instructions Sorted by Opcode                         | A-33   |
| Instruction Formats                                   |        |
| Instruction Fields                                    |        |
| Instruction Format Diagrams                           | A-43   |
| I-Form                                                |        |
| B-Form                                                |        |
| SC-Form                                               | A-44   |

| D-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A-44                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| X-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A-45                                                                                                                |
| XL-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | A-45                                                                                                                |
| XFX-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A-46                                                                                                                |
| X0-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | A-46                                                                                                                |
| M-Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A-46                                                                                                                |
| B. Instructions by Category                                                                                                                                                                                                                                                                                                                                                                                                                                               | B-1                                                                                                                 |
| Implementation-Specific Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                      | B-1                                                                                                                 |
| Instructions in the IBM PowerPC Embedded Environment                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                     |
| Privileged Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                     |
| Assembler Extended Mnemonics                                                                                                                                                                                                                                                                                                                                                                                                                                              | B-9                                                                                                                 |
| Storage Reference Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| Arithmetic and Logical Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                       | B-33                                                                                                                |
| Condition Register Logical Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                   | B-37                                                                                                                |
| Branch Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                     |
| Comparison Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                   | B-39                                                                                                                |
| Rotate and Shift Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                     |
| Cache Control Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                                | B-41                                                                                                                |
| Interrupt Control Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                            | B-42                                                                                                                |
| Processor Management Instructions                                                                                                                                                                                                                                                                                                                                                                                                                                         | B-42                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                     |
| C. Code Optimization and Instruction Timings                                                                                                                                                                                                                                                                                                                                                                                                                              | C-1                                                                                                                 |
| C. Code Optimization and Instruction Timings<br>Code Optimization Guidelines                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                     |
| Code Optimization Guidelines                                                                                                                                                                                                                                                                                                                                                                                                                                              | C-1                                                                                                                 |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables                                                                                                                                                                                                                                                                                                                                                                                             | C-1<br>C-1                                                                                                          |
| Code Optimization Guidelines                                                                                                                                                                                                                                                                                                                                                                                                                                              | C-1<br>C-1<br>C-1                                                                                                   |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches                                                                                                                                                                                                                                                                                                                                             | C-1<br>C-1<br>C-1<br>C-1                                                                                            |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation                                                                                                                                                                                                                                                                                                                 | C-1<br>C-1<br>C-1<br>C-1<br>C-2                                                                                     |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage                                                                                                                                                                                                                                                                                                  | C-1<br>C-1<br>C-1<br>C-1<br>C-2<br>C-2                                                                              |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies                                                                                                                                                                                                                                                                               | C-1<br>C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2                                                                       |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction                                                                                                                                                                                                                                                          | C-1<br>C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2                                                                |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment                                                                                                                                                                                                                                             | C-1<br>C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-2<br>C-2                                                  |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment                                                                                                                                                                                                                                             | C-1<br>C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3                                           |
| Code Optimization Guidelines                                                                                                                                                                                                                                                                                                                                                                                                                                              | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-4                                    |
| Code Optimization Guidelines                                                                                                                                                                                                                                                                                                                                                                                                                                              | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-4                                    |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment<br>Instruction Timings<br>General Rules<br>Branches<br>Multiplies<br>Scalar Load Instructions<br>Scalar Store Instructions                                                                                                                  | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-4<br>C-5                                    |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment<br>Instruction Timings<br>General Rules<br>Branches<br>Multiplies<br>Scalar Load Instructions<br>Scalar Store Instructions<br>Alignment in Scalar Load and Store Instructions                                                               | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-3<br>C-5<br>C-5                             |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment<br>Instruction Timings<br>General Rules<br>Branches<br>Multiplies<br>Scalar Load Instructions<br>Scalar Store Instructions<br>Alignment in Scalar Load and Store Instructions<br>String and Multiple Instructions                           |                                                                                                                     |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment<br>Instruction Timings<br>General Rules<br>Branches<br>Multiplies<br>Scalar Load Instructions<br>Scalar Store Instructions<br>Alignment in Scalar Load and Store Instructions<br>String and Multiple Instructions<br>Loads and Store Misses | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-3<br>C-4<br>C-5<br>C-5<br>C-5<br>C-6<br>C-6 |
| Code Optimization Guidelines<br>Condition Register Bits for Boolean Variables<br>CR Logical Instruction for Compound Branches<br>Floating-Point Emulation<br>Cache Usage<br>CR Dependencies<br>Branch Prediction<br>Alignment<br>Instruction Timings<br>General Rules<br>Branches<br>Multiplies<br>Scalar Load Instructions<br>Scalar Store Instructions<br>Alignment in Scalar Load and Store Instructions<br>String and Multiple Instructions                           | C-1<br>C-1<br>C-1<br>C-2<br>C-2<br>C-2<br>C-2<br>C-3<br>C-3<br>C-3<br>C-3<br>C-4<br>C-5<br>C-5<br>C-5<br>C-6<br>C-6 |

## Figures

| -           | PPC405GP Block Diagram                                           |      |
|-------------|------------------------------------------------------------------|------|
|             | Overlapped PLB Transfers                                         |      |
|             | PLB Arbiter Control Register (PLB0_ACR)                          |      |
|             | PLB Error Address Register (PLB0_BEAR)                           |      |
| Figure 2-4. | PLB Error Status Register (PLB0_BESR)                            | 2-6  |
|             | Bridge Error Address Register (POB0_BEAR)                        |      |
|             | <b>o o i i j</b>                                                 |      |
|             | Bridge Error Status Register 1 (POB0_BESR1)                      |      |
|             | OPB Arbiter Control Register (OPBA0_CR)                          |      |
| -           | OPB Arbiter Priority Register (OPBA0_PR)                         |      |
|             | PPC405GP Programming Model—Registers                             |      |
| -           | General Purpose Registers (R0-R31)                               |      |
|             | Count Register (CTR)                                             |      |
|             | Link Register (LR)                                               |      |
|             | Fixed Point Exception Register (XER)                             |      |
|             | Special Purpose Register General (SPRG0-SPRG7)                   |      |
| -           | Processor Version Register (PVR)                                 |      |
|             | Condition Register (CR)                                          |      |
|             | Machine State Register (MSR)                                     |      |
|             | PPC405GP Data Types                                              |      |
|             | Normal Word Load or Store (Big Endian Storage Region)            |      |
|             | Byte-Reverse Word Load or Store (Little Endian Storage Region)   |      |
|             | Byte-Reverse Word Load or Store (Big Endian Storage Region)      |      |
| -           | Normal Word Load or Store (Little Endian Storage Region)         |      |
| -           | PPC405GP Instruction Pipeline                                    |      |
|             | Instruction Flow                                                 |      |
|             | Core Configuration Register 0 (CCR0)                             |      |
|             | Instruction Cache Debug Data Register (ICDBDR)                   |      |
|             | OCM Address Usage                                                |      |
|             | OCM Instruction-Side Address Range Compare Register (OCM0_ISARC) |      |
|             | OCM Instruction-Side Control Register (OCM0_ISCNTL)              |      |
| -           | OCM Data-Side Address Range Compare Register (OCM0_DSARC)        |      |
|             | OCM Data-Side Control Register (OCM0_DSCNTL)                     |      |
|             | Effective to Real Address Translation Flow                       |      |
|             | TLB Entries                                                      |      |
|             | ITLB/DTLB/UTLB Address Resolution                                |      |
|             | Process ID (PID)                                                 |      |
|             | Zone Protection Register (ZPR)                                   |      |
| -           | Generic Storage Attribute Control Register                       |      |
| -           | PPC405GP Clocking                                                |      |
|             | PLL Mode Register (CPC0_PLLMR)                                   |      |
| Figure 7-3. | Chip Control Register 0 (CPC0_CR0)                               | 7-12 |
|             |                                                                  |      |

| Figure 9-1. Chip Pin Strapping Register (CPC0_PSR)                                           | 9-1    |
|----------------------------------------------------------------------------------------------|--------|
| Figure 10-1. UIC Status Register (UIC0_SR)                                                   |        |
| Figure 10-2. UIC Enable Register (UIC0_ER)                                                   |        |
| Figure 10-3. UIC Critical Register (UIC0_CR)                                                 |        |
| Figure 10-4. UIC Polarity Register (UIC0_PR)                                                 |        |
| Figure 10-5. UIC Trigger Register (UIC0_TR)                                                  |        |
| Figure 10-6. UIC Masked Status Register (UIC0_MSR)                                           |        |
| Figure 10-7. UIC Vector Configuration Register (UIC0_VCR)                                    |        |
| Figure 10-8. UIC Vector Register (UIC0_VR)                                                   |        |
| Figure 10-9. Machine State Register (MSR)                                                    |        |
| Figure 10-10. Save/Restore Register 0 (SRR0)                                                 |        |
| Figure 10-10. Save/Restore Register 0 (SRR1)                                                 |        |
|                                                                                              |        |
| Figure 10-12. Save/Restore Register 2 (SRR2)<br>Figure 10-13. Save/Restore Register 3 (SRR3) |        |
|                                                                                              |        |
| Figure 10-14. Exception Vector Prefix Register (EVPR)                                        |        |
| Figure 10-15. Exception Syndrome Register (ESR)                                              |        |
| Figure 10-16. Data Exception Address Register (DEAR)                                         |        |
| Figure 11-1. Relationship of Timer Facilities to the Time Base                               |        |
| Figure 11-2. Time Base Lower (TBL)                                                           |        |
| Figure 11-3. Time Base Upper (TBU)                                                           |        |
| Figure 11-4. Programmable Interval Timer (PIT)                                               | •      |
| Figure 11-5. Watchdog Timer State Machine                                                    |        |
| Figure 11-6. Timer Status Register (TSR)                                                     |        |
| Figure 11-7. Timer Control Register (TCR)                                                    |        |
| Figure 12-1. JTAG Connector Physical Layout (Top View)                                       |        |
| Figure 12-2. JTAG ID Register (CPC0_JTAGID)                                                  |        |
| Figure 12-3. RISCTrace Header (Top View)                                                     |        |
| Figure 12-4. Debug Control Register 0 (DBCR0)                                                |        |
| Figure 12-5. Debug Control Register 1 (DBCR1)                                                |        |
| Figure 12-6. Debug Status Register (DBSR)                                                    |        |
| Figure 12-7. Instruction Address Compare Registers (IAC1-IAC4)                               |        |
| Figure 12-8. Data Address Compare Registers (DAC1–DAC2)                                      |        |
| Figure 12-9. Data Value Compare Registers (DVC1–DVC2)                                        |        |
| Figure 12-10. Inclusive IAC Range Address Compares                                           |        |
| Figure 12-11. Exclusive IAC Range Address Compares                                           |        |
| Figure 12-12. Inclusive DAC Range Address Compares                                           |        |
| Figure 12-13. Exclusive DAC Range Address Compares                                           |        |
| Figure 13-1. CPM Registers (CPC0_ER, CPC0_FR, CPC0_SR)                                       |        |
| Figure 14-1. Decompression Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)              |        |
| Figure 14-2. Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1)       | . 14-5 |
| Figure 14-3. Decompression Controller Configuration Register (DCP0_CFG)                      |        |
| Figure 14-4. Decompression Controller ID Register (DCP0_ID)                                  |        |
| Figure 14-5. Decompression Controller Version Register (DCP0_VER)                            |        |
| Figure 14-6. Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)              | . 14-7 |
| Figure 14-7. Decompression Controller Bus Error Address Register (DCP0_MEMBEAR)              |        |
| Figure 14-8. Decompression Controller Error Status Register 0 (DCP0_ESR)                     | . 14-8 |

| Figure 15-1.  | SDRAM Controller Signals                                           |       |
|---------------|--------------------------------------------------------------------|-------|
| Figure 15-2.  | Memory Controller Configuration (SDRAM0_CFG)                       |       |
| Figure 15-3.  | Memory Controller Status (SDRAM0_STATUS)                           |       |
| Figure 15-4.  | Memory Bank 0-3 Configuration Registers (SDRAM0_B0CR-SDRAM0_B3CR)  |       |
| Figure 15-5.  | SDRAM Timing Register (SDRAM0_TR)                                  |       |
| Figure 15-6.  | Activate, Four Word Read, Precharge, Activate                      |       |
| Figure 15-7.  | Activate, Four Word Write, Precharge, Activate                     |       |
|               | Precharge All, Activate                                            |       |
| -             | CAS Before RAS Refresh                                             |       |
| Figure 15-11  | . Refresh Timing Register (SDRAM0_RTR)                             |       |
|               | ECC Configuration Register (SDRAM0_ECCCFG)                         |       |
|               | ECC Error Status Register (SDRAM0_ECCESR)                          |       |
|               | Bus Error Address Register (SDRAM0_BEAR)                           |       |
|               | Bus Error Syndrome Register 0 (SDRAM0_BESR0)                       |       |
|               | Bus Error Status Register 1 (SDRAM0_BESR1)                         |       |
|               | Power Management Idle Timer (SDRAM0_PMIT)                          |       |
| Figure 16-1.  | External Bus Controller Signals                                    |       |
|               | Attachment of Devices of Various Widths to the Peripheral Data Bus |       |
| Figure 16-3.  | Single Read Transfer                                               |       |
| Figure 16-4.  | Single Write Transfer                                              |       |
| -             | Burst Read Transfer                                                |       |
| Figure 16-6.  | Burst Write Transfer                                               |       |
| Figure 16-7.  | Device-Paced Single Read Transfer                                  |       |
| -             | Device-Paced Single Write Transfer                                 |       |
| Figure 16-9.  | Device-Paced Burst Read Transfer                                   |       |
| Figure 16-10. | Device-Paced Burst Write Transfer                                  | 16-16 |
| Figure 16-11. | Sample External Bus Master System                                  | 16-17 |
| Figure 16-12. | External Master Arbitration, Single Read and Single Write          | 16-20 |
| Figure 16-13. | External Master Burst Read                                         | 16-21 |
| Figure 16-14. | External Master Burst Write                                        |       |
| Figure 16-15. | EBC Configuration Register (EBC0_CFG)                              | 16-24 |
| Figure 16-16. | Peripheral Bank Configuration Registers (EBC0_BnCR)                | 16-25 |
| Figure 16-17. | Peripheral Bank Access Parameters (EBC0_BnAP)                      |       |
| Figure 16-18. | Peripheral Bus Error Address Register (EBC0_BEAR)                  |       |
| Figure 16-19. | Peripheral Bus Error Status Register 0 (EBC0_BESR0)                | 16-30 |
| Figure 16-20. | Peripheral Bus Error Status Register 1 (EBC0_BESR1)                |       |
| Figure 17-1.  | PCI Bridge Block Diagram                                           | 17-2  |
| Figure 17-2.  | PLB-to-PCI Half-Bridge Block Diagram                               | 17-4  |
| Figure 17-3.  | PCI-to-PLB Half-Bridge Block Diagram                               | 17-5  |
| Figure 17-4.  | Arbitration Structure                                              | 17-5  |
| Figure 17-5.  | PMM Register Sets Map PLB Address Space to PCI Address Space       | 17-8  |
| Figure 17-6.  | PTM Register Sets Map PCI Address Space to PLB Address Space       | 17-9  |
| Figure 17-7.  | PMM 0 Local Address Register (PCIL0_PMM0LA)                        | 17-21 |
| Figure 17-8.  | PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)                       | 17-22 |
| Figure 17-9.  | PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)                   | 17-23 |
| Figure 17-10. | PMM 0 High Address Register (PCIL0_PMM0PCIHA)                      |       |

|               | PMM 1 Local Address Register (PCIL0_PMM1LA)                 |       |
|---------------|-------------------------------------------------------------|-------|
|               | PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)                |       |
|               | PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)            |       |
|               | PMM 0 High Address Register (PCIL0_PMM0PCIHA)               |       |
|               | PMM 2 Local Address Register (PCIL0_PMM2LA)                 |       |
|               | PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)                |       |
|               | PMM 2 Low Address Register (PCIL0_PMM2PCILA)                |       |
|               | PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)           |       |
| -             | PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)         |       |
| -             | PTM 2 Local Address Register (PCIL0_PTM1LA)                 |       |
|               | PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)         |       |
|               | PTM 2 Local Address Register (PCIL0_PTM2LA)                 |       |
| -             | PCI Configuration Address Register (PCIC0_CFGADDR)          |       |
|               | PCI Configuration Data Register (PCIC0_CFGDATA)             |       |
|               | PCI Vendor ID Register (PCIC0_VENDID)                       |       |
|               | PCI Device ID Register (PCIC0_DEVID)                        |       |
| -             | PCI Command Register (PCIC0_CMD)                            |       |
|               | PCI Status Register (PCIC0_STATUS)                          |       |
|               | PCI Revision ID Register (PCIC0_REVID)                      |       |
| -             | PCI Class Register (PCIC0_PCICLS)                           |       |
| -             | PCI Cache Line Size Register (PCIC0_CACHELS)                |       |
| -             | PCI Latency Timer Register (PCIC0_LATTIM)                   |       |
|               | PCI Header Type Register (PCIC0_HDTYPE)                     |       |
|               | PCI Built-in Self Test Control Register (PCIC0_BIST)        |       |
| •             | PCI PTM 1 BAR Register (PCIC0_PTM1BAR)                      |       |
|               | PCI PTM 2 BAR Register (PCIC0_PTM2BAR)                      |       |
|               | PCI Subsystem Vendor ID Register (PCIC0_SBSYSVID)           |       |
| Figure 17-38. | PCI Subsystem ID Register (PCIC0_SBSYSID)                   | 17-40 |
| Figure 17-39. | PCI Capabilities Pointer (PCIC0_CAP)                        | 17-40 |
| Figure 17-40. | PCI Interrupt Line Register (PCIC0_INTLN)                   | 17-40 |
| Figure 17-41. | PCI Interrupt Pin Register (PCIC0_INTPN)                    | 17-41 |
| Figure 17-42. | PCI Minimum Grant Register (PCIC0_MINGNT)                   | 17-41 |
| Figure 17-43. | PCI Maximum Latency Register (PCIC0_MAXLTNCY)               | 17-41 |
| Figure 17-44. | PCI Interrupt Control/Status Register                       | 17-42 |
| Figure 17-45. | Error Enable Register (PCIC0_ERREN)                         | 17-42 |
| Figure 17-46. | Error Status Register (PCIC0_ERRSTS)                        | 17-43 |
| Figure 17-47. | Bridge Options 1 Register (PCIC0_BRDGOPT1)                  | 17-44 |
| Figure 17-48. | PLB Slave Error Syndrome Register 0 (PCIC0_PLBBESR0)        | 17-46 |
| Figure 17-49. | PLB Slave Error Syndrome 1 (PCIC0_PLBBESR1)                 | 17-47 |
| Figure 17-50. | PLB Slave Error Address Register (PCIC0_PLBBEAR)            | 17-49 |
| Figure 17-51. | Capability Identifier (PCIC0_CAPID)                         | 17-49 |
| Figure 17-52. | Next Item Pointer (PCIC0_NEXTIPTR)                          | 17-49 |
| Figure 17-53. | Power Management Capabilities Register (PCIC0_PMC)          | 17-50 |
| Figure 17-54. | Power Management Control/Status Register (PCIC0_PMCSR)      | 17-51 |
|               | PMCSR PCI to PCI Bridge Support Extensions (PCIC0_PMCSRBSE) |       |
| Figure 17-56. | PCI Data (PCIC0_DATA)                                       | 17-52 |
|               |                                                             |       |

| Figure 17-57  | Bridge Options 2 Register (PCIC0_BRDGOPT2)                            | 17-52           |
|---------------|-----------------------------------------------------------------------|-----------------|
| Figure 17-58  | Power Management State Change Request Register (PCIC0_PMSCRR)         | 17-54           |
| Figure 17-60  | PCI Master Burst Read From SDRAM                                      |                 |
| Figure 17-61. | PCI Master Burst Write To SDRAM                                       | 17-72           |
| Figure 17-62  | CPU Read From PCI Memory Slave, Nonprefetching                        | 17-76           |
| Figure 17-63  | CPU Read From PCI Memory Slave, Prefetching                           | 17-78           |
|               | CPU Write To PCI Memory Slave                                         |                 |
| Figure 17-65  | PCI Memory To SDRAM DMA Transfer                                      |                 |
| Figure 17-66  | SDRAM To PCI Memory DMA Transfer                                      |                 |
| Figure 17-67. | PCI Master Burst Read From SDRAM                                      |                 |
| Figure 17-68. | PCI Master Burst Write To SDRAM                                       | 17-100          |
| Figure 17-69. | CPU Read From PCI Memory Slave, Nonprefetching                        | 17-106          |
| Figure 17-70. | CPU Read From PCI Memory Slave, Prefetching                           | 17-108          |
| Figure 17-71. | CPU Write To PCI Memory Slave                                         | 17 <u>-</u> 112 |
| Figure 17-72. | PCI Memory To SDRAM DMA Transfer                                      | 17-116          |
| Figure 17-73. | SDRAM To PCI Memory DMA Transfer                                      | 17-120          |
| Figure 18-1.  | DMA Controller External Bus Control Signals                           |                 |
| Figure 18-2.  | DMA Polarity Configuration Register (DMA0_POL)                        |                 |
| Figure 18-3.  | DMA Sleep Mode Register (DMA0_SLP)                                    |                 |
| Figure 18-4.  | DMA Status Register (DMA0_SR)                                         |                 |
| Figure 18-5.  | DMA Channel Control Registers (DMA0_CR0-DMA0_CR3)                     |                 |
| Figure 18-6.  | DMA Source Address Registers (DMA0_SA0-DMA0_SA3)                      |                 |
| Figure 18-7.  |                                                                       |                 |
| Figure 18-8.  | DMA Count Registers (DMA0_CT0-DMA0_CT3)                               |                 |
| Figure 18-9.  | DMA Scatter/Gather Descriptor Address Registers (DMA0_SG0-DMA0_SG3)   |                 |
| Figure 18-10. | DMA Scatter/Gather Command Register (DMA0_SGC)                        |                 |
| Figure 18-11. | Peripheral-to-Memory DMA Transfer                                     |                 |
| Figure 18-12. | Memory to Peripheral DMA Transfer                                     | 18-19           |
| Figure 19-1.  | EMAC in a Typical Ethernet Application                                | 19-2            |
| Figure 19-2.  | Internal EMAC Structure                                               | 19-3            |
| Figure 19-3.  | EMAC Loop-Back Modes                                                  | 19-5            |
| Figure 19-4.  | MAL TX Descriptor Control/Status Field                                | 19-7            |
|               | Transmit Packet Structure (Excluding VLAN Tagged and Control Packets) |                 |
| Figure 19-6.  | MAL RX Descriptor Control/Status Field                                | 19-12           |
|               | Wake-Up Packet Format                                                 |                 |
|               | Control Packet Format                                                 |                 |
| Figure 19-9.  | Integrated Flow Control Mechanism                                     | 19-17           |
| Figure 19-10. | Pause Operation State Machine                                         | 19-18           |
| Figure 19-11. | Tagged MAC Packet Format                                              |                 |
| Figure 19-12. | Tag Control Information Field Structure                               | 19-19           |
| Figure 19-13. | Receive Address Recognition Flowchart                                 | 19-22           |
| Figure 19-14. | Ethernet Address Filter Operation                                     | 19-23           |
| Figure 19-15. | Mode Register 0 (EMAC0_MR0)                                           | 19-25           |
| Figure 19-16. | <b>5</b> ( <b>1 1</b>                                                 |                 |
| Figure 19-17. |                                                                       |                 |
| Figure 19-18. | Transmit Mode Register 1 (EMAC0_TMR1)                                 | 19-28           |

|               | Receive Mode Register (EMAC0_RMR)                            |       |
|---------------|--------------------------------------------------------------|-------|
|               | Interrupt Status Register (EMAC0_ISR)                        |       |
|               | Interrupt Status Register (EMAC0_ISER)                       |       |
|               | Individual Address High Register (EMAC0_IAHR)                |       |
|               | Individual Address Low Register (EMAC0_IALR)                 |       |
| •             | VLAN TPID Register (EMAC0_VTPID)                             |       |
|               | VLAN TCI Register (EMAC0_VTCI)                               |       |
|               | Pause Timer Register (EMAC0_PTR)                             |       |
|               | Individual Address Hash Tables 1-4 (EMAC0_IAHT1-EMAC0_IAHT4) |       |
|               | Group Address Hash Tables 1-4 (EMAC0_GAHT1-EMAC0_GAHT4)      |       |
|               | Last Source Address High Register (EMAC0_LSAH)               |       |
|               | Last Source Address Low Register (EMAC0_LSAL)                |       |
| -             | inter-Packet Gap Value Register (EMAC0_IPGVR)                |       |
| Figure 19-32. |                                                              |       |
| Figure 19-33. | Transmit Request Threshold Register (EMAC0_TRTR)             |       |
| Figure 19-34. |                                                              |       |
| Figure 19-35. | Number of Octets Transmitted (EMAC0_OCTX)                    |       |
| Figure 19-36. | Number of Octets Received (EMAC0_OCRX)                       |       |
| Figure 19-37. |                                                              |       |
| Figure 19-38. |                                                              |       |
|               | General PPC405GP Structure (Overview)                        |       |
| -             | MAL Internal Structure                                       |       |
| •             | Transmit Operation                                           |       |
|               | Receive Operation                                            |       |
| Figure 20-5.  | Buffer Descriptor Structure                                  | 20-8  |
| Figure 20-6.  | Packet Memory Structure                                      | 20-9  |
| 5             | TX Status/Control Field                                      |       |
| Figure 20-8.  | RX Status/Control Field                                      | 20-16 |
| Figure 20-9.  | Error Status Register Field                                  | 20-21 |
| Figure 20-10. | MAL Error Processing                                         | 20-23 |
| -             | MAL Configuration Register (MAL0_CFG)                        |       |
|               | TX Channel_Active Set Register (MAL0_TXCASR)                 |       |
|               | TX Channel_Active Reset Register (MAL0_TXCARR)               |       |
| -             | RX Channel_Active Set Register (MAL0_RXCASR)                 |       |
| -             | RX Channel_Active Reset Register (MAL0_RXCARR)               |       |
|               | TX End of Buffer Interrupt Status Register (MAL0_TXEOBISR)   |       |
|               | RX End of Buffer Interrupt Status Register (MAL0_RXEOBISR)   |       |
| Figure 20-18. | MAL Error Status Register (MAL0_ESR)                         | 20-30 |
|               | MAL Interrupt Enable Register (MAL0_IER)                     |       |
|               | TX Descriptor Error Interrupt Register (MAL0_TXDEIR)         |       |
| Figure 20-21. | RX Descriptor Error Interrupt Register (MAL0_RXDEIR)         |       |
| Figure 20-22. | TX Channel Table Pointer x Register (MAL0_TXCTPxR)           | 20-33 |
|               | RX Channel Table Pointer x Register (MAL0_RXCTPxR)           |       |
| Figure 21-1.  | UART Receiver Buffer Registers (UARTx_RBR)                   | 21-5  |
| -             | UART Transmitter Holding Registers (UARTx_THR)               |       |
| Figure 21-3.  | UART Interrupt Enable Registers (UARTx_IER)                  | 21-5  |
|               |                                                              |       |

|               | UART Interrupt Identification Registers (UARTx_IIR)             |       |
|---------------|-----------------------------------------------------------------|-------|
|               | UART FIFO Control Registers (UARTx_FCR)                         |       |
| Figure 21-6.  | UART Line Control Registers (UARTx_LCR)                         | 21-9  |
| Figure 21-7.  | UART Modem Control Registers (UARTx_MCR)                        | 21-10 |
| Figure 21-8.  | UART Line Status Registers (UARTx_LSR)                          | 21-11 |
| Figure 21-9.  | UART Modem Status Registers (UARTx_MSR)                         | 21-13 |
| Figure 21-10. | Scratchpad Registers (UARTx_SCR)                                | 21-14 |
| Figure 21-11. | UART Baud-Rate Divisor Latch (MSB) Registers (UARTx_DLM)        | 21-14 |
|               | UART Baud-Rate Divisor Latch (LSB) Registers (UARTx_DLL)        |       |
|               | Chip Control Register 0 (CPC0_CR0)                              |       |
| Figure 22-1.  | 7-Bit Addressing                                                |       |
| Figure 22-2.  | 10-Bit Addressing                                               |       |
| Figure 22-3.  | IIC0 Master Data Buffer (IIC0_MDBUF)                            |       |
| Figure 22-4.  | FIFO Stages                                                     |       |
| Figure 22-5.  | IIC0 Slave Data Buffer (IIC0_SDBUF)                             |       |
| Figure 22-6.  | IIC0 Low Master Address Register (IIC0_LMADR)                   |       |
| Figure 22-7.  |                                                                 |       |
| Figure 22-8.  | IIC0 Control Register (IIC0_CNTL)                               |       |
| Figure 22-9.  | IIC0 Mode Control Register (IIC0_MDCNTL)                        |       |
| Figure 22-10. | IIC0 Status Register (IIC0_STS)                                 |       |
| Figure 22-11. | IIC0 Extended Status Register (IIC0_EXTSTS)                     |       |
| Figure 22-12. | IIC0 Low Slave Address Register (IIC0_LSADR)                    |       |
|               | IIC0 High Slave Address Register (IIC0_HSADR)                   |       |
| Figure 22-14. | IIC0 Clock Divide Register (IIC0_CLKDIV)                        |       |
| Figure 22-15. | IIC0 Interrupt Mask Register (IIC0_INTRMSK)                     |       |
| Figure 22-16. | IIC0 Transfer Count Register (IIC0_XFRCNT)                      |       |
|               | IIC0 Extended Control and Slave Status Register (IIC0_XTCNTLSS) |       |
| Figure 22-18. | IIC0 Direct Control Register (IIC0_DIRECTCNTL)                  |       |
| Figure 23-1.  | GPIO Functional Block Diagram                                   | 23-2  |
| Figure 23-2.  | CPC0_CR0 Bits Controlling GPIO                                  | 23-3  |
| Figure 23-3.  | GPIO Registers                                                  | 23-5  |
| Figure 25-1.  | Core Configuration Register 0 (CCR0)                            | 25-15 |
| Figure 25-2.  | Chip Control Register 0 (CPC0_CR0)                              | 25-17 |
| Figure 25-3.  | Chip Control Register 1 (CPC0_CR1)                              | 25-20 |
| Figure 25-4.  | CPM Enable Register (CPC0_ER)                                   | 25-21 |
|               | CPM Force Register (CPC0_FR)                                    |       |
| Figure 25-6.  | JTAG ID Register (CPC0_JTAGID)                                  | 25-23 |
| Figure 25-7.  | PLL Mode Register (CPC0_PLLMR)                                  | 25-24 |
|               | Chip Pin Strapping Register (CPC0_PSR)                          |       |
| Figure 25-9.  | CPM Status Register (CPC0_SR)                                   | 25-28 |
| Figure 25-10. | Condition Register (CR)                                         |       |
|               | Count Register (CTR)                                            |       |
| Figure 25-12. | Data Address Compare Registers (DAC1-DAC2)                      | 25-31 |
| Figure 25-13. | Debug Control Register 0 (DBCR0)                                | 25-32 |
|               | Debug Control Register 1 (DBCR1)                                |       |
| Figure 25-15. | Debug Status Register (DBSR)                                    | 25-36 |

| Figure 25-16. | Data Cache Cachability Register (DCCR)                                    |       |
|---------------|---------------------------------------------------------------------------|-------|
| Figure 25-17. | Decompression Address Decode Definition Registers (DCP0_ADDR0-DCP0_ADDR1) |       |
| Figure 25-18. | Decompression Controller Configuration Register (DCP0_CFG)                |       |
| Figure 25-19. | Decompression Controller Error Status Register 0 (DCP0_ESR)               |       |
| Figure 25-20. | Decompression Controller ID Register (DCP0_ID)                            |       |
| Figure 25-21. | Decompression Index Table Origin Registers (DCP0_ITOR0-DCP0_ITOR3)        |       |
| Figure 25-22. | Decompression Controller Bus Error Address Register (DCP0_MEMBEAR)        |       |
| Figure 25-23. | Decompression Controller PLB Error Address Register (DCP0_PLBBEAR)        |       |
| Figure 25-24. | Decompression Controller Version Register (DCP0_VER)                      |       |
| Figure 25-25. | Data Cache Write-through Register (DCWR)                                  |       |
| Figure 25-26. | Data Exception Address Register (DEAR)                                    |       |
| Figure 25-27. | DMA Channel Control Registers (DMA0_CR0-DMA0_CR3)                         |       |
| Figure 25-28. | DMA Count Registers (DMA0_CT0-DMA0_CT3)                                   |       |
| Figure 25-29. | DMA Destination Address Registers (DMA0_DA0-DMA0_DA3)                     |       |
| Figure 25-30. | DMA Polarity Configuration Register (DMA0_POL)                            |       |
| Figure 25-31. | DMA Source Address Registers (DMA0_SA0-DMA0_SA3)                          |       |
| Figure 25-32. | DMA Scatter/Gather Descriptor Address Registers (DMA0_SG0-DMA0_SG3)       |       |
| Figure 25-33. | DMA Scatter/Gather Command Register (DMA0_SGC)                            |       |
| Figure 25-34. | DMA Sleep Mode Register (DMA0_SLP)                                        |       |
| Figure 25-35. | DMA Status Register (DMA0_SR)                                             |       |
| Figure 25-36. | Data Value Compare Registers (DVC1-DVC2)                                  |       |
| Figure 25-37. | Peripheral Bus Error Address Register (EBC0_BEAR)                         |       |
| Figure 25-38. | • • •                                                                     |       |
|               | Peripheral Bus Error Status Register 1 (EBC0_BESR1)                       |       |
| Figure 25-40. | Peripheral Bank Access Parameters (EBC0_BnAP)                             |       |
| Figure 25-41. | Peripheral Bank Configuration Registers (EBC0_BnCR)                       | 25-75 |
| Figure 25-42. | <b>o o i i i j</b>                                                        |       |
| Figure 25-43. |                                                                           |       |
| Figure 25-44. | Individual Address High Register (EMAC0_IAHR)                             | 25-81 |
| Figure 25-45. | STA Control Register (EMAC0_STACR)                                        | 25-82 |
| Figure 25-46. | Transmit Mode Register 0 (EMAC0_TMR0)                                     | 25-83 |
| Figure 25-47. | Transmit Mode Register 1 (EMAC0_TMR1)                                     | 25-84 |
| Figure 25-48. | Transmit Request Threshold Register (EMAC0_TRTR)                          | 25-85 |
| Figure 25-49. | $\bullet$ $i$ = $i$                                                       |       |
| Figure 25-50. | VLAN TPID Register (EMAC0_VTPID)                                          |       |
| Figure 25-51. |                                                                           |       |
| Figure 25-52. |                                                                           |       |
| Figure 25-53. | GPIO Input Register (GPIO0_IR)                                            | 25-90 |
| Figure 25-54. | GPIO Open Drain Register (GPIO0_ODR)                                      |       |
| Figure 25-55. | GPIO Output Register (GPIO0_OR)                                           |       |
| Figure 25-56. | GPIO Three-State Register (GPIO0_TCR)                                     |       |
| Figure 25-57. | General Purpose Registers (R0-R31)                                        |       |
| Figure 25-58. | Instruction Address Compare Registers (IAC1-IAC4)                         |       |
| Figure 25-59. | Instruction Cache Cachability Register (ICCR)                             | 25-96 |
| Figure 25-60. | Instruction Cache Debug Data Register (ICDBDR)                            |       |
| Figure 25-61. | IIC0 Clock Divide Register (IIC0_CLKDIV)                                  | 25-99 |
|               |                                                                           |       |

|                | IIC0 Control Register (IIC0_CNTL)                                |        |
|----------------|------------------------------------------------------------------|--------|
|                | IICO Direct Control Register (IICO_DIRECTCNTL)                   |        |
|                | IIC0 Extended Status Register (IIC0_EXTSTS)                      |        |
|                | IIC0 High Master Address Register (IIC0_HMADR)                   |        |
|                | IIC0 High Slave Address Register (IIC0_HSADR)                    |        |
|                | IIC0 Interrupt Mask Register (IIC0_INTRMSK)                      |        |
|                | IIC0 Low Master Address Register (IIC0_LMADR)                    |        |
| -              | IIC0 Low Slave Address Register (IIC0_LSADR)                     |        |
| -              | IIC0 Master Data Buffer (IIC0_MDBUF)                             |        |
|                | IIC0 Mode Control Register (IIC0_MDCNTL)                         |        |
|                | IIC0 Slave Data Buffer (IIC0_SDBUF)                              |        |
|                | IIC0 Status Register (IIC0_STS)                                  |        |
| -              | IIC0 Transfer Count Register (IIC0_XFRCNT)                       |        |
|                | IIC0 Extended Control and Slave Status Register (IIC0_XTCNTLSS)  |        |
|                | Link Register (LR)                                               |        |
| Figure 25-77.  | MAL Configuration Register (MAL0_CFG)                            | 25-117 |
| Figure 25-78.  | MAL Error Status Register (MAL0_ESR)                             | 25-119 |
| Figure 25-79.  | MAL Interrupt Enable Register (MAL0_IER)                         | 25-121 |
| Figure 25-80.  | RX Channel Buffer Size Register 0 (MAL0_RCBS0)                   |        |
| Figure 25-81.  | RX Channel_Active Reset Register (MAL0_RXCARR)                   | 25-123 |
| -              | RX Channel_Active Set Register (MAL0_RXCASR)                     |        |
| -              | RX Channel Table Pointer x Register (MAL0_RXCTPxR)               |        |
|                | RX Descriptor Error Interrupt Register (MAL0_RXDEIR)             |        |
|                | RX End of Buffer Interrupt Status Register (MAL0_RXEOBISR)       |        |
| Figure 25-86.  | TX Channel_Active Reset Register (MAL0_TXCARR)                   | 25-128 |
| Figure 25-87.  | TX Channel_Active Set Register (MAL0_TXCASR)                     | 25-129 |
| Figure 25-88.  | TX Channel Table Pointer x Register (MAL0_TXCTPxR)               | 25-130 |
| Figure 25-89.  | TX Descriptor Error Interrupt Register (MAL0_TXDEIR)             |        |
| Figure 25-90.  | TX End of Buffer Interrupt Status Register (MAL0_TXEOBISR)       | 25-132 |
| Figure 25-91.  | Machine State Register (MSR)                                     |        |
| Figure 25-92.  | OCM Data-Side Address Range Compare Register (OCM0_DSARC)        | 25-135 |
| Figure 25-93.  | OCM Data-Side Control Register (OCM0_DSCNTL)                     | 25-136 |
| Figure 25-94.  | OCM Instruction-Side Address Range Compare Register (OCM0_ISARC) | 25-137 |
| Figure 25-95.  | OCM Instruction-Side Control Register (OCM0_ISCNTL)              | 25-138 |
| Figure 25-96.  | OPB Arbiter Control Register (OPBA0_CR)                          | 25-139 |
| Figure 25-97.  | OPB Arbiter Priority Register (OPBA0_PR)                         | 25-140 |
| Figure 25-98.  | PCI Base Address Register (PCIC0_BAR0)                           | 25-141 |
| Figure 25-99.  | PCI Built-in Self Test Control Register (PCIC0_BIST)             | 25-142 |
| Figure 25-100. | Bridge Options 1 Register (PCIC0_BRDGOPT1)                       | 25-143 |
| Figure 25-101. | Bridge Options 2 Register (PCIC0_BRDGOPT2)                       | 25-144 |
| Figure 25-102. | PCI Cache Line Size Register (PCIC0_CACHELS)                     |        |
| Figure 25-103. | PCI Capabilities Pointer (PCIC0_CAP)                             | 25-146 |
| Figure 25-104. | Capability Identifier (PCIC0_CAPID)                              |        |
| Figure 25-105. | PCI Configuration Address Register (PCIC0_CFGADDR)               |        |
| Figure 25-106. | PCI Configuration Data Register (PCIC0_CFGDATA)                  |        |
| Figure 25-107. |                                                                  |        |
|                |                                                                  |        |

| •              | PCI Command Register (PCIC0_CMD)                              |          |
|----------------|---------------------------------------------------------------|----------|
| -              | PCI Data (PCIC0_DATA)                                         |          |
| -              | PCI Device ID Register (PCIC0_DEVID)                          |          |
| -              | Error Enable Register (PCIC0_ERREN)                           |          |
|                | Error Status Register (PCIC0_ERRSTS)                          |          |
| Figure 25-113. | PCI Header Type Register (PCIC0_HDTYPE)                       | . 25-157 |
| -              | PCI Interrupt Control/Status Register                         |          |
|                | PCI Interrupt Line Register (PCIC0_INTLN)                     |          |
|                | PCI Interrupt Pin Register (PCIC0_INTPN)                      |          |
| •              | PCI Latency Timer Register (PCIC0_LATTIM)                     |          |
|                | PCI Maximum Latency Register (PCIC0_MAXLTNCY)                 |          |
|                | PCI Minimum Grant Register (PCIC0_MINGNT)                     |          |
|                | Next Item Pointer (PCIC0_NEXTIPTR)                            |          |
|                | PLB Slave Error Address Register (PCIC0_PLBBEAR)              |          |
|                | PLB Slave Error Syndrome Register 0 (PCIC0_PLBBESR0)          |          |
| Figure 25-123. | PLB Slave Error Syndrome 1 (PCIC0_PLBBESR1)                   | . 25-168 |
|                | Power Management Capabilities Register (PCIC0_PMC)            |          |
|                | Power Management Control/Status Register (PCIC0_PMCSR)        |          |
|                | PMCSR PCI to PCI Bridge Support Extensions (PCIC0_PMCSRBSE)   |          |
| Figure 25-127. | Power Management State Change Request Register (PCIC0_PMSCRR) | . 25-173 |
| -              | PCI PTM 1 BAR Register (PCIC0_PTM1BAR)                        |          |
|                | PCI PTM 2 BAR Register (PCIC0_PTM2BAR)                        |          |
|                | PCI Revision ID Register (PCIC0_REVID)                        |          |
|                | PCI Subsystem ID Register (PCIC0_SBSYSID)                     |          |
|                | PCI Subsystem Vendor ID Register (PCIC0_SBSYSVID)             |          |
|                | PCI Status Register (PCIC0_STATUS)                            |          |
| •              | PCI Vendor ID Register (PCIC0_VENDID)                         |          |
|                | PMM 0 Local Address Register (PCIL0_PMM0LA)                   |          |
|                | PMM 0 Mask/Attribute Register (PCIL0_PMM0MA)                  |          |
|                | PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)             |          |
|                | PMM 0 PCI Low Address Register (PCIL0_PMM0PCILA)              |          |
|                | PMM 1 Local Address Register (PCIL0_PMM1LA)                   |          |
|                | PMM 1 Mask/Attribute Register (PCIL0_PMM1MA)                  |          |
|                | PMM 1 PCI High Address Register (PCIL0_PMM1PCIHA)             |          |
|                | PMM 1 PCI Low Address Register (PCIL0_PMM1PCILA)              |          |
|                | PMM 2 Local Address Register (PCIL0_PMM2LA)                   |          |
|                | PMM 2 Mask/Attribute Register (PCIL0_PMM2MA)                  |          |
|                | PMM 2 PCI High Address Register (PCIL0_PMM2PCIHA)             |          |
|                | PMM 2 Low Address Register (PCIL0_PMM2PCILA)                  |          |
|                | PTM 2 Local Address Register (PCIL0_PTM1LA)                   |          |
|                | PTM 1 Memory Size/Attribute Register (PCIL0_PTM1MS)           |          |
|                | PTM 2 Local Address Register (PCIL0_PTM2LA)                   |          |
|                | PTM 2 Memory Size/Attribute Register (PCIL0_PTM2MS)           |          |
| Figure 25-151. | , ,                                                           |          |
| Figure 25-152. | • • • •                                                       |          |
| Figure 25-153. | PLB Arbiter Control Register (PLB0_ACR)                       | 25-200   |
|                |                                                               |          |

|                | PLB Error Address Register (PLB0_BEAR)                                   |  |
|----------------|--------------------------------------------------------------------------|--|
|                | PLB Error Status Register (PLB0_BESR)                                    |  |
|                | Bridge Error Address Register (POB0_BEAR)                                |  |
|                | Bridge Error Status Register 0 (POB0_BESR0)                              |  |
|                | Bridge Error Status Register 1 (POB0_BESR1)                              |  |
| -              | Processor Version Register (PVR)                                         |  |
| Figure 25-160. |                                                                          |  |
| -              | Bus Error Address Register (SDRAM0_BEAR)                                 |  |
| -              | Bus Error Syndrome Register 0 (SDRAM0_BESR0)                             |  |
| -              | Bus Error Status Register 1 (SDRAM0_BESR1)                               |  |
| Figure 25-164. | • • • •                                                                  |  |
| Figure 25-165. | 5 5 ( <u> </u>                                                           |  |
| Figure 25-166. | $\bullet$ $\cdot$ $ \cdot$                                               |  |
|                | Power Management Idle Timer (SDRAM0_PMIT)                                |  |
|                | Refresh Timing Register (SDRAM0_RTR)                                     |  |
|                | SDRAM Timing Register (SDRAM0_TR)                                        |  |
|                | Storage Guarded Register (SGR)                                           |  |
|                | Storage Little-Endian Register (SLER)                                    |  |
| -              | Special Purpose Registers General (SPRG0–SPRG7)                          |  |
|                | Save/Restore Register 0 (SRR0)                                           |  |
| -              | Save/Restore Register 1 (SRR1)                                           |  |
| -              | Save/Restore Register 2 (SRR2)                                           |  |
|                | Save/Restore Register 3 (SRR3)<br>Storage User-defined 0 Register (SU0R) |  |
|                | Time Base Lower (TBL)                                                    |  |
| 0              | Time Base Upper (TBU)                                                    |  |
| •              | Timer Control Register (TCR)                                             |  |
| Figure 25-180. |                                                                          |  |
| •              | UART Baud-Rate Divisor Latch (LSB) Registers (UARTx_DLL)                 |  |
| -              | UART Baud-Rate Divisor Latch (MSB) Registers (UARTx_DLC)                 |  |
|                | UART FIFO Control Registers (UARTx_FCR)                                  |  |
| -              | UART Interrupt Enable Registers (UARTx_IER)                              |  |
| -              | UART Interrupt Identification Registers (UARTx_IIR)                      |  |
|                | UART Line Control Registers (UARTx_LCR)                                  |  |
|                | UART Line Status Registers (UARTx_LSR)                                   |  |
|                | UART Modem Control Registers (UARTx_MCR)                                 |  |
|                | UART Modem Status Registers (UARTx_MSR)                                  |  |
|                | UART Receiver Buffer Registers (UARTx_RBR)                               |  |
|                | Scratchpad Registers (UARTx_SCR)                                         |  |
| •              | UART Transmitter Holding Registers (UARTx_THR)                           |  |
| Figure 25-194. | UIC Critical Register (UIC0_CR)                                          |  |
| Figure 25-195. |                                                                          |  |
| Figure 25-196. | UIC Masked Status Register (UIC0_MSR)                                    |  |
| Figure 25-197. | UIC Polarity Register (UIC0_PR)                                          |  |
| Figure 25-198. | UIC Status Register (UIC0_SR)                                            |  |
| Figure 25-199. | UIC Trigger Register (UIC0_TR)                                           |  |
| <b>.</b>       |                                                                          |  |

| Figure 25-200. UIC Vector Configuration Register (UIC0_VCR) 25-2 |                                            | 25-270 |  |
|------------------------------------------------------------------|--------------------------------------------|--------|--|
| Figure 25-201. UIC Vector Register (UIC0_VR)                     |                                            | 25-271 |  |
| Figure 25-20                                                     | Figure 25-202. User SPR General 0 (USPRG0) |        |  |
| Figure 25-203. Fixed Point Exception Register (XER)              |                                            |        |  |
| Figure 25-20                                                     | 04. Zone Protection Register (ZPR)         | 25-274 |  |
| Figure A-1.                                                      | I Instruction Format                       | A-44   |  |
| Figure A-2. B Instruction Format                                 |                                            |        |  |
| Figure A-3. SC Instruction Format                                |                                            |        |  |
| Figure A-4. D Instruction Format                                 |                                            |        |  |
| Figure A-5. X Instruction Format                                 |                                            |        |  |
| Figure A-6. XL Instruction Format                                |                                            |        |  |
| Figure A-7. XFX Instruction Format                               |                                            |        |  |
| Figure A-8. XO Instruction Format                                |                                            |        |  |
| Figure A-9. M Instruction FormatA-46                             |                                            |        |  |

# Tables

| Table 2-1. PPC405GP PLB Agents as Masters and Slaves               | 2-2  |
|--------------------------------------------------------------------|------|
| Table 2-2. Registers Controlling PLB Master Priority Assignments   | 2-3  |
| Table 2-3. PLB Arbiter Registers                                   | 2-5  |
| Table 2-4. PLB Arbiter Registers                                   | 2-8  |
| Table 2-5. PPC405GP OPB Master Assignments                         | 2-12 |
| Table 2-6. PLB Arbiter Registers                                   | 2-12 |
| Table 3-1. PPC405GP Address Space                                  | 3-2  |
| Table 3-2. PPC405GP SPRs                                           | 3-7  |
| Table 3-3. XER[CA] Updating Instructions                           | 3-10 |
| Table 3-4. XER[SO,OV] Updating Instructions                        | 3-11 |
| Table 3-5. Time Base Registers                                     | 3-15 |
| Table 3-6. Directly Accessed DCRs                                  | 3-17 |
| Table 3-7. SDRAM Controller DCR Usage                              | 3-19 |
| Table 3-8. Offsets for SDRAM Controller Registers                  | 3-19 |
| Table 3-9. External Bus Controller DCR Usage                       | 3-20 |
| Table 3-10. Offsets for External Bus Controller Registers          | 3-20 |
| Table 3-11. Decompression Controller DCR Usage                     | 3-21 |
| Table 3-12. Offsets for Decompression Controller Registers         | 3-21 |
| Table 3-13. Directly Accessed MMIO Registers                       | 3-22 |
| Table 3-14. PCI Configuration Address and Data Registers           | 3-25 |
| Table 3-15. PCI Configuration Registers                            | 3-25 |
| Table 3-16. Alignment Exception Summary                            | 3-28 |
| Table 3-17. Bits of the BO Field                                   | 3-35 |
| Table 3-18. Conditional Branch BO Field                            | 3-36 |
| Table 3-19. Example Memory Mapping                                 | 3-40 |
| Table 3-20. Privileged Instructions                                | 3-42 |
| Table 3-21. PPC405GP Instruction Set Summary                       | 3-47 |
| Table 3-22. Implementation-specific Instructions                   | 3-48 |
| Table 3-23. Storage Reference Instructions                         | 3-48 |
| Table 3-24. Arithmetic Instructions                                | 3-49 |
| Table 3-25. Multiply-Accumulate and Multiply Halfword Instructions | 3-50 |
| Table 3-26. Logical Instructions                                   | 3-50 |
| Table 3-27. Compare Instructions                                   | 3-50 |
| Table 3-28. Branch Instructions                                    | 3-51 |
| Table 3-29. CR Logical Instructions                                | 3-51 |
| Table 3-30. Rotate Instructions                                    | 3-51 |
| Table 3-31. Shift Instructions                                     |      |
| Table 3-32. Cache Management Instructions                          | 3-52 |
| Table 3-33. Interrupt Control Instructions                         | 3-52 |
| Table 3-34. TLB Management Instructions                            | 3-53 |
| Table 3-35. Processor Management Instructions                      |      |
| Table 4-1. Instruction Cache Organization                          | 4-2  |

| Table 4-2. Data Cache Organization                                           | 4-6           |
|------------------------------------------------------------------------------|---------------|
| Table 4-3. Priority Changes With Different Data Cache Operations             | 4 <b>-1</b> 7 |
| Table 5-1. Examples of Store Data Bypass                                     |               |
| Table 5-2. OCM DCRs                                                          | 5 <b>-</b> 5  |
| Table 6-1. TLB Fields Related to Page Size                                   | 6-4           |
| Table 6-2. Protection Applied to Cache Control Instructions                  | 6-15          |
| Table 7-1. Clock Strapping Values                                            |               |
| Table 7-2. PLL Tuning Settings                                               |               |
| Table 7-3. Possible Clocking Ratios for Reference Clock of 33.3MHz           | 7-5           |
| Table 7-4. Possible Clocking Ratios for Reference Clock of 25MHz             | 7 <b>-</b> 6  |
| Table 7-5. Possible Clocking Ratios for Reference Clock of 41.6MHz           |               |
| Table 7-6. Example Synchronous PCI Clock Frequencies in Asynchronous Mode    | 7-8           |
| Table 7-7. Clocking Control Registers                                        | 7-9           |
| Table 8-1. MSR Contents after Reset                                          | 8-3           |
| Table 8-2. SPR Contents After Reset                                          | 8-4           |
| Table 8-3. DCR Contents After Reset                                          | 8-4           |
| Table 8-4. MMIO Register Contents After Reset                                | 8-8           |
| Table 9-1. Multiplexed Pins                                                  | 9-3           |
| Table 10-1. UIC Interrupt Assignments                                        | 10-1          |
| Table 10-2. UIC DCRs                                                         | 10-3          |
| Table 10-3. Interrupt Handling Priorities                                    | <b>10-</b> 25 |
| Table 10-4. Interrupt Vector Offsets                                         | 10-27         |
| Table 10-5. ESR Alteration by Various Interrupts                             | 10-33         |
| Table 10-6. ESR Alteration by Various Interrupts                             | 10-33         |
| Table 10-7. Register Settings during Critical Input Interrupts               | 10-35         |
| Table 10-8. Register Settings during Machine Check-Instruction Interrupts    | 10-36         |
| Table 10-9. Register Settings during Machine Check-Data Interrupts           | 10-36         |
| Table 10-10. Register Settings during Data Storage Interrupts                | 10-37         |
| Table 10-11. Register Settings during Instruction Storage Interrupts         | 10-38         |
| Table 10-12. Register Settings during External Interrupts                    | 10-39         |
| Table 10-13. Alignment Interrupt Summary                                     | 10-39         |
| Table 10-14. Register Settings during Alignment Interrupts                   | 10-40         |
| Table 10-15. ESR Usage for Program Interrupts                                |               |
| Table 10-16. Register Settings during Program Interrupts                     | 10-41         |
| Table 10-17. Register Settings during System Call Interrupts                 | 10-41         |
| Table 10-18. Register Settings during Programmable Interval Timer Interrupts | 10-42         |
| Table 10-19. Register Settings during Fixed Interval Timer Interrupts        | 10-42         |
| Table 10-20. Register Settings during Watchdog Timer Interrupts              | 10-43         |
| Table 10-21. Register Settings during Data TLB Miss Interrupts               | 10-43         |
| Table 10-22. Register Settings during Instruction TLB Miss Interrupts        | 10-44         |
| Table 10-23. SRR2 during Debug Interrupts                                    |               |
| Table 10-24. Register Settings during Debug Interrupts                       | 10-45         |
| Table 11-1. Time Base Access                                                 | 11-3          |
| Table 11-2. FIT Controls                                                     | 11-5          |
| Table 11-3. Watchdog Timer Controls                                          | 11-6          |
| Table 12-1. JTAG Connector Signals                                           | 12-2          |

.

| Table 12-2. | JTAG Instructions                                                   |       |
|-------------|---------------------------------------------------------------------|-------|
| Table 12-3. | RISCTrace Header Pin Description                                    |       |
| Table 12-4. | Debug Events                                                        | 12-16 |
| Table 12-5. | DAC Applied to Cache Instructions                                   |       |
| Table 12-6. | Setting of DBSR Bits for DAC and DVC Events                         |       |
| Table 12-7. | Comparisons Based on DBCR1[DVnM]                                    | 12-23 |
| Table 13-1. | CPM Registers                                                       |       |
| Table 14-1. | DCRs Used to Access the Decompression Controller Registers          | 14-4  |
| Table 14-2. | Offsets for Decompression Controller Registers                      |       |
| Table 15-1. | SDRAM Signal Usage and State During/Following Reset                 |       |
|             | SDRAM Controller DCR Addresses                                      |       |
| Table 15-3. | SDRAM Controller Configuration and Status Registers                 |       |
| Table 15-4. | SDRAM Addressing Modes                                              |       |
| Table 15-5. | SDRAM Page Size                                                     |       |
| Table 15-6. | Logical Address Bit on BA1:0 and MemAddr12:0 Versus Addressing Mode |       |
| Table 15-7. | SDRAM Memory Timing Parameters                                      |       |
| Table 15-8. | Additional Latency when using ECC                                   |       |
|             | EBC Signal Usage and State During/Following a Chip or System Reset  |       |
|             | Effect of Driver Enable Programming on EBC Signal States            |       |
|             | External Master Arbitration.                                        |       |
| Table 16-4. | Signal States During Hold Acknowledge (HoldAck=1)                   |       |
|             | EBC DCR Addresses                                                   |       |
|             | External Bus Configuration and Status Registers                     |       |
|             | PowerPC, CoreConnect PLB, and PCI Address Bit-Naming Conventions    |       |
|             | PowerPC, CoreConnect PLB, and PCI Data Bus Bit-Naming Conventions   |       |
|             | PLB Address Map                                                     |       |
|             | PCI Memory Address Map                                              |       |
|             | Transaction Mapping: PLB -> PCI                                     |       |
|             | Transaction Mapping: PCI $\rightarrow$ PLB                          |       |
|             | Collision Resolution                                                |       |
|             | Directly Accessed MMIO Registers                                    |       |
|             | PCI Configuration Address and Data Registers                        |       |
|             | . PCI Configuration Register Offsets                                |       |
|             | . PLB Unsupported Transfer Types                                    |       |
|             | . Address Map Register Values                                       |       |
|             | DMA Controller External I/Os                                        |       |
|             | DMA Controller Configuration and Status Registers                   |       |
|             | DMA Transfer Priorities                                             |       |
| Table 18-4. | Address Alignment Requirements                                      |       |
| Table 18-5. | Scatter/Gather Descriptor Table                                     |       |
|             | Bit Fields in the Scatter/Gather Descriptor Table                   |       |
|             | DMA Registers Loaded from Scatter/Gather Descriptor Table           |       |
|             | FCS/SA Enable - Possible Configurations                             |       |
|             | FCS/Pad Enable - Possible Configurations                            |       |
|             | FCS/VLAN Tag Enable - Possible Configurations                       |       |
|             | In Range Length Error Behavior for Various Packet Lengths           |       |
|             |                                                                     |       |

•

|                                                                                               | 40.00  |
|-----------------------------------------------------------------------------------------------|--------|
| Table 19-5. EMAC Register Summary                                                             |        |
| Table 20-1. MAL Registers                                                                     |        |
| Table 21-1. Baud Rate Settings                                                                |        |
| Table 21-2. UART Configuration Registers                                                      |        |
| Table 21-3. Interrupt Priority Level                                                          |        |
| Table 21-4. Divisor Latch Settings for Certain Baud Rates                                     |        |
| Table 21-5. UART0 Transmitter DMA Mode Register Field Settings                                |        |
| Table 21-6. UART0 Receiver DMA Mode Register Field Settings                                   |        |
| Table 22-1. IIC Registers                                                                     |        |
| Table 22-2. IIC Response to IIC0_CNTL Field Settings                                          |        |
| Table 22-3. IIC0_STS[ERR, PT] Decoding                                                        |        |
| Table 22-4. IIC0 Clock Divide Programming                                                     |        |
| Table 23-1. Macro I/O Interface Signals                                                       | 23-2   |
| Table 23-2. GPIO Register Summary                                                             | 23-5   |
| Table 23-3. GPIO0_ODR Control Logic                                                           | 23-6   |
| Table 24-1. Implementation-Specific Instructions                                              | 24-1   |
| Table 24-2. Operator Precedence                                                               |        |
| Table 24-3. Extended Mnemonics for addi                                                       |        |
| Table 24-4. Extended Mnemonics for addic                                                      | 24-10  |
| Table 24-5. Extended Mnemonics for addic.                                                     | 24-11  |
| Table 24-6. Extended Mnemonics for addis                                                      |        |
| Table 24-7. Extended Mnemonics for bc, bca, bcl, bcla                                         |        |
| Table 24-8. Extended Mnemonics for bcctr, bcctrl                                              |        |
| Table 24-9. Extended Mnemonics for bclr, bclrl                                                |        |
| Table 24-10. Extended Mnemonics for cmp                                                       |        |
| Table 24-11. Extended Mnemonics for cmpi                                                      |        |
| Table 24-12. Extended Mnemonics for cmpl                                                      |        |
| Table 24-13. Extended Mnemonics for cmpli                                                     |        |
| Table 24-14. Extended Mnemonics for creqv                                                     |        |
| Table 24-15. Extended Mnemonics for crnor                                                     |        |
| Table 24-16. Extended Mnemonics for cror                                                      |        |
| Table 24-17. Extended Mnemonics for crxor                                                     |        |
| Table 24-18. Transfer Bit Mnemonic Assignment                                                 |        |
| Table 24-19. Extended Mnemonics for mfspr                                                     |        |
| Table 24-20. Extended Mnemonics for mfb                                                       |        |
| Table 24-20. Extended Mnemonics for mftb                                                      |        |
| Table 24-22. Extended Mnemonics for mito                                                      |        |
| Table 24-22. Extended Mnemonics for mtspr                                                     |        |
| •                                                                                             |        |
| Table 24-24. Extended Mnemonics for nor, nor.                                                 |        |
| Table 24-25. Extended Mnemonics for or, or.           Table 24-26. Extended Mnemonics for ori |        |
|                                                                                               |        |
| Table 24-27. Extended Mnemonics for riwimi, riwimi.                                           |        |
| Table 24-28. Extended Mnemonics for rlwinm, rlwinm.                                           |        |
| Table 24-29. Extended Mnemonics for rlwnm, rlwnm.                                             |        |
| Table 24-30. Extended Mnemonics for subf, subfo, subfo, subfo.                                |        |
| Table 24-31. Extended Mnemonics for subfc, subfc, subfco, subfco.                             | 24-177 |

| Table 24-32. Extended Mnemonics for tlbre                                            | 24-185 |
|--------------------------------------------------------------------------------------|--------|
| Table 24-33. Extended Mnemonics for tlbwe                                            | 24-189 |
| Table 24-34. Extended Mnemonics for tw                                               | 24-191 |
| Table 24-35. Extended Mnemonics for twi                                              |        |
| Table 25-1. PPC405GP General Purpose Registers                                       |        |
| Table 25-2. Special Purpose Registers                                                |        |
| Table 25-3. Time Base Registers                                                      |        |
| Table 25-4. Directly Accessed DCRs                                                   |        |
| Table 25-5. SDRAM Controller DCR Usage                                               |        |
| Table 25-6. Offsets for SDRAM Controller Registers                                   |        |
| Table 25-7. EBC DCR Usage                                                            |        |
| Table 25-8. Offsets for EBC Registers                                                |        |
| Table 25-9. Decompression Controller DCR Usage                                       |        |
| Table 25-10. Offsets for Decompression Controller Registers                          |        |
| Table 25-11. Directly Accessed MMIO Registers                                        |        |
| Table 25-12. PCI Configuration Address and Data Registers                            |        |
| Table 25-13. PCI Configuration Registers                                             |        |
| Table 26-1. Alphabetical Signal List                                                 |        |
| Table 26-2. Signal Descriptions                                                      |        |
| Table A-1. PPC405GP Instruction Syntax Summary                                       |        |
| Table A-2. PPC405GP Instructions by Opcode                                           | A-33   |
| Table B-1. PPC405GP Instruction Set Functional Summary                               |        |
| Table B-2. Implementation-specific Instructions                                      |        |
| Table B-3. Instructions in the IBM PowerPC Embedded Environment                      |        |
| Table B-4. Privileged Instructions                                                   |        |
| Table B-5. Extended Mnemonics for PPC405GP                                           |        |
| Table B-6. Storage Reference Instructions                                            |        |
| Table B-7. Arithmetic and Logical Instructions                                       |        |
| Table B-8. Condition Register Logical Instructions<br>Table B-9. Branch Instructions |        |
| Table B-9. Branch Instructions                                                       |        |
| Table B-10. Comparison instructions                                                  |        |
| Table B-12. Cache Control Instructions                                               |        |
| Table B-12. Cache Control Instructions                                               |        |
| Table B-14. Processor Management Instructions                                        | •      |
| Table C-1. Cache Sizes, Tag Fields, and Lines                                        |        |
| Table C-1. Cache Sizes, ray reads, and Lines                                         |        |
| Table C-4. Instruction Cache Miss Penalties                                          |        |
|                                                                                      |        |

# **About This Book**

This user's manual provides the architectural overview, programming model, and detailed information about the registers, the instruction set, and operations of the IBM PowerPC 405GP (PPC405GP) 32-bit RISC embedded processor.

The PPC405GP RISC embedded processor features:

- PowerPC Architecture<sup>™</sup>
- Single-cycle execution for most instructions
- Instruction cache unit and data cache unit
- Support for Little Endian operation
- Interrupt interface for one critical and one non-critical interrupt signal
- JTAG interface
- Extensive development tool support

# Who Should Use This Book

This book is for system hardware and software developers, and for application developers who need to understand the PPC405GP. The audience should understand embedded processor design, embedded system design, operating systems, RISC processing, and design for testability.

### How to Use This Book

This book describes the PPC405GP device architecture, programming model, external interfaces, internal registers, and instruction set. This book contains the following chapters, arranged in parts:

Part I Introducing the PPC405GP Embedded Processor

Chapter 1 Overview

Chapter 2 On-Chip Buses

Part II The PPC405GP RISC Processor

- Chapter 3 Programming Model
- Chapter 4 Cache Operations
- Chapter 5 On-Chip Memory
- Chapter 6 Memory Management

Part III PPC405GP System Operations

- Chapter 7 Clocking
- Chapter 8 Reset and Initialization
- Chapter 9 Pin Strapping and Sharing
- Chapter 10 Interrupt Controller Operations
- Chapter 11 Timer Facilities
- Chapter 12 Debugging
- Chapter 13 Clock and Power Management
- Chapter 14 Decompression Controller Operation

xlvii

#### Part IV PPC405GP External Interfaces

- Chapter 15 SDRAM Controller
- Chapter 16 External Bus Controller
- Chapter 17 PCI Interface

Chapter 18 Direct Memory Access Controller

Chapter 19 Ethernet Media Access Controller

Chapter 20 Memory Access Layer

Chapter 21 Serial Port Operations

- Chapter 22 IIC Bus Interface
- Chapter 23 GPIO Operations

#### Part V Reference

- Chapter 24 Instruction Set
- Chapter 25 Register Summary
- Chapter 26 Signal Summary

This book contains the following appendixes:

- Appendix A Instruction Summary
- Appendix B Instructions by Category
- Appendix C Code Optimization and Instruction Timings

To help readers find material in these chapters, the book contains:

Contents, on page v. Figures, on page xxix. Tables, on page xli. Index, on page X-1.

# Conventions

The following is a list of notational conventions frequently used in this manual.

| ActiveLow    | An overbar indicates an active-low signal. |
|--------------|--------------------------------------------|
| n .          | A decimal number                           |
| 0x <i>n</i>  | A hexadecimal number                       |
| 0b <i>n</i>  | A binary number                            |
| =            | Assignment                                 |
| ٨            | AND logical operator                       |
| <b>-</b> , · | NOT logical operator                       |
| V            | OR logical operator                        |
| $\oplus$     | Exclusive-OR (XOR) logical operator        |
| + .          | Twos complement addition                   |
| -            | Twos complement subtraction, unary minus   |
| ×            | Multiplication                             |

| ÷                   | Division yielding a quotient                                                                                                                                                                                            |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| %                   | Remainder of an integer division; $(33 \% 32) = 1$ .                                                                                                                                                                    |
| 1                   |                                                                                                                                                                                                                         |
| =,≠                 | Equal, not equal relations                                                                                                                                                                                              |
| <, >                | Signed comparison relations                                                                                                                                                                                             |
| u u<br><,>          | Unsigned comparison relations                                                                                                                                                                                           |
| ifthenelse          | Conditional execution; if <i>condition</i> then $a$ else $b$ , where $a$ and $b$ represent one or more pseudocode statements. Indenting indicates the ranges of $a$ and $b$ . If $b$ is null, the else does not appear. |
| do                  | Do loop. "to" and "by" clauses specify incrementing an iteration variable;<br>"while" and "until" clauses specify terminating conditions. Indenting<br>indicates the scope of a loop.                                   |
| leave               | Leave innermost do loop or do loop specified in a leave statement.                                                                                                                                                      |
| FLD                 | An instruction or register field                                                                                                                                                                                        |
| FLD <sub>b</sub>    | A bit in a named instruction or register field                                                                                                                                                                          |
| FLD <sub>b:b</sub>  | A range of bits in a named instruction or register field                                                                                                                                                                |
| FLD <sub>b,b,</sub> | A list of bits, by number or name, in a named instruction or register field                                                                                                                                             |
| REG <sub>b</sub>    | A bit in a named register                                                                                                                                                                                               |
| REG <sub>b:b</sub>  | A range of bits in a named register                                                                                                                                                                                     |
| REG <sub>b,b,</sub> | A list of bits, by number or name, in a named register                                                                                                                                                                  |
| REG[FLD]            | A field in a named register                                                                                                                                                                                             |
| REG[FLD, FLD]       | A list of fields in a named register                                                                                                                                                                                    |
| REG[FLD:FLD]        | A range of fields in a named register                                                                                                                                                                                   |
| GPR(r)              | General Purpose Register (GPR) r, where $0 \le r \le 31$ .                                                                                                                                                              |
| (GPR(r))            | The contents of GPR r, where $0 \le r \le 31$ .                                                                                                                                                                         |
| DCR(DCRN)           | A Device Control Register (DCR) specified by the DCRF field in an <b>mfdcr</b> or <b>mtdcr</b> instruction                                                                                                              |
| SPR(SPRN)           | An SPR specified by the SPRF field in an mfspr or mtspr instruction                                                                                                                                                     |
| TBR(TBRN)           | A Time Base Register (TBR) specified by the TBRF field in an <b>mftb</b> instruction                                                                                                                                    |
| GPRs                | RA, RB,                                                                                                                                                                                                                 |
| (Rx)                | The contents of a GPR, where x is A, B, S, or T                                                                                                                                                                         |
| (RAI0)              | The contents of the register RA or 0, if the RA field is 0.                                                                                                                                                             |
| CR <sub>FLD</sub>   | The field in the condition register pointed to by a field of an instruction.                                                                                                                                            |
| с <sub>0:3</sub>    | A 4-bit object used to store condition results in compare instructions.                                                                                                                                                 |
| ď                   | The bit or bit value <i>b</i> is replicated <i>n</i> times.                                                                                                                                                             |
|                     | · · · ·                                                                                                                                                                                                                 |

xlix

| хх                | Bit positions which are don't-cares.                                                                                                                                                                                             |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CEIL(x)           | Least integer $\ge$ x.                                                                                                                                                                                                           |
| EXTS(x)           | The result of extending x on the left with sign bits.                                                                                                                                                                            |
| PC                | Program counter.                                                                                                                                                                                                                 |
| RESERVE           | Reserve bit; indicates whether a process has reserved a block of storage.                                                                                                                                                        |
| CIA               | Current instruction address; the 32-bit address of the instruction being described by a sequence of pseudocode. This address is used to set the next instruction address (NIA). Does not correspond to any architected register. |
| NIA               | Next instruction address; the 32-bit address of the next instruction to be executed. In pseudocode, a successful branch is indicated by assigning a value to NIA. For instructions that do not branch, the NIA is CIA +4.        |
| MS(addr, n)       | The number of bytes represented by <i>n</i> at the location in main storage represented by <i>addr</i> .                                                                                                                         |
| EA                | Effective address; the 32-bit address, derived by applying indexing or indirect addressing rules to the specified operand, that specifies a location in main storage.                                                            |
| EA <sub>b</sub>   | A bit in an effective address.                                                                                                                                                                                                   |
| EA <sub>b:b</sub> | A range of bits in an effective address.                                                                                                                                                                                         |
| ROTL((RS),n)      | Rotate left; the contents of RS are shifted left the number of bits specified by <i>n</i> .                                                                                                                                      |
| MASK(MB,ME)       | Mask having 1s in positions MB through ME (wrapping if $MB > ME$ ) and 0s elsewhere.                                                                                                                                             |
| instruction(EA)   | An instruction operating on a data or instruction cache block associated with an EA.                                                                                                                                             |

I

Part I. Introducing the PPC405GP Embedded Processor

I-2 PPC405GP User's Manual

.

# **Chapter 1. Overview**

The IBM PowerPC 405GP 32-bit reduced instruction set computer (RISC) embedded processor, referred to as the PPC405GP, is a system-on-a-chip (SOC) that integrates a PowerPC embedded processor core with a rich set of on-chip peripherals:

- SDRAM controller
- External bus controller (EBC)
- PCI bus interface
- · Direct memory access (DMA) with scatter/gather support
- Ethernet and media access layer (MAL) interfaces
- Two serial ports
- Inter-integrated circuit (IIC) interface
- General-purpose input/output (GPIO)

In addition, the PPC405GP supports CodePack<sup>™</sup>, a code compression scheme that can significantly reduce application code memory requirements, and a variety of debug tools.

This chapter describes:

- PPC405GP features
- The PowerPC Architecture™
- The PPC405GP implementation of the IBM PowerPC Embedded Environment, an extension of the PowerPC Architecture for embedded applications
- · PPC405GP organization, including a block diagram and descriptions of the functional units
- PPC405GP registers
- PPC405GP addressing modes



Figure 1-1 illustrates the logical organization of the PPC405GP:

Figure 1-1. PPC405GP Block Diagram

# 1.1 PPC405GP Features

The PPC405GP provides high performance and low power consumption. The PPC405GP RISC CPU executes at sustained speeds approaching one cycle per instruction. On-chip instruction and data caches reduce chip count and design complexity in systems and improve system throughput.

# 1.1.1 Bus and Peripheral Features

The PPC405GP multilevel bus architecture and peripherals feature:

- Processor local bus (PLB)
- On-chip peripheral bus (OPB)
- PC-100 synchronous DRAM (SDRAM) controller
  - 32-bit interface for non-ECC applications
  - 40-bit interface (32 data bits and 8 check bits) for ECC applications

- External bus controller (EBC)
  - Flash ROM/Boot ROM interface
  - Direct support for 8-, 16-, or 32-bit SRAM or external peripherals
  - One external master supported
- PCI bus, Revision 2.2 compliant (32 bit, up to 66 MHz)
  - PCI bus interface can be configured to operate synchronously or asynchronously to the PLB
  - Internal PCI bus arbiter that can be disabled for use with an external arbiter
- DMA support for OPB and external peripherals
- Ethernet 10/100 Mbps (full-duplex) controller with media access layer (MAL) support
- · Interrupt controller supporting programmable interrupt handling from a variety of sources
- Two 8-bit serial ports (16550 compatible UARTs)
- Inter-integrated circuit (IIC) controller
- General purpose I/O (GPIO) controller

# 1.1.2 PowerPC Processor Core Features

The PowerPC RISC fixed-point CPU features:

- PowerPC User Instruction Set Architecture (UISA) and extensions for embedded applications
- Thirty-two 32-bit general purpose registers (GPRs)
- Static branch prediction
- · Five-stage pipeline with single-cycle execution of most instructions, including loads/stores
- Unaligned load/store support to cache arrays, main memory, and on-chip memory (OCM)
- Hardware multiply/divide for faster integer arithmetic (4-cycle multiply, 35-cycle divide)
- Multiply-accumulate instructions
- · Enhanced string and multiple-word handling
- True little endian operation
- Programmable Interval Timer (PIT), Fixed Interval Timer (FIT), and watchdog timer
- Forward and reverse trace from a trigger event
- Storage control
  - Separate, configurable, two-way set-associative instruction and data cache units
  - Eight words (32 bytes) per cache line
  - 16KB instruction and 8KB data cache arrays
  - Instruction cache unit (ICU) non-blocking during line fills, data cache unit (DCU) non-blocking during line fills and flushes
  - Read and write line buffers
  - Instruction fetch hits are supplied from line buffer
  - Data load/store hits are supplied to line buffer
  - Programmable ICU prefetching of next sequential line into line buffer

- Programmable ICU prefetching of non-cacheable instructions, full line (eight words) or half line (four words)
- Write-back or write-through DCU write strategies
- Programmable allocation on loads and stores
- Operand forwarding during cache line fills
- Memory Management
  - Translation of the 4GB logical address space into physical addresses
  - Independent enabling of instruction and data translation/protection
  - Page level access control using the translation mechanism
  - Software control of page replacement strategy
  - Additional control over protection using zones
  - WIU0GE (write-through, cacheability, user-defined 0, guarded, endian) storage attribute control for each virtual memory region
- WIU0GE storage attribute control for thirty-two real 128MB regions
- PowerPC timer facilities
  - 64-bit time base
  - PIT, FIT, and watchdog timers
  - Synchronous external time base clock input
- · Debug Support
  - Enhanced debug support with logical operators
  - Four instruction address compares (IACs)
  - Two data address compares (DACs)
  - Two data value compares (DVCs)
  - JTAG instruction to write to ICU
  - Forward or backward instruction tracing
- Minimized interrupt latency
- Advanced power management support

# 1.2 PowerPC Architecture

The PowerPC Architecture comprises three levels of standards:

- PowerPC User Instruction Set Architecture (UISA), including the base user-level instruction set, user-level registers, programming model, data types, and addressing modes. This is referred to as Book I of the PowerPC Architecture.
- PowerPC Virtual Environment Architecture, describing the memory model, cache model, cachecontrol instructions, address aliasing, and related issues. While accessible from the user level, these features are intended to be accessed from within library routines provided by the system software. This is referred to as Book II of the PowerPC Architecture.

• PowerPC Operating Environment Architecture, including the memory management model, supervisor-level registers, and the exception model. These features are not accessible from the user level. This is referred to as Book III of the PowerPC Architecture.

Book I and Book II define the instruction set and facilities available to the application programmer. Book III defines features, such as system-level instructions, that are not directly accessible by user applications. The PowerPC Architecture is described in *The PowerPC Architecture: A Specification for a New Family of RISC Processors.* 

The PowerPC Architecture provides compatibility of PowerPC Book I application code across all PowerPC implementations to help maximize the portability of applications developed for PowerPC processors. This is accomplished through compliance with the first level of the architectural definition, the PowerPC UISA, which is common to all PowerPC implementations.

# **1.3 The PPC405GP as a PowerPC Implementation**

The PPC405GP implements the PowerPC UISA, user-level registers, programming model, data types, addressing modes, and 32-bit fixed-point operations. The PPC405GP fully complies with the PowerPC UISA. The UISA 64-bit and floating point operations are not implemented. The floating point operations, which cause exceptions, can then be emulated by software.

Most of the features of the PPC405GP processor core are compatible with the PowerPC Virtual Environment and Operating Environment Architectures, as implemented in PowerPC processors such as the 6xx/7xx family. The PPC405GP processor core also provides a number of optimizations and extensions to these layers of the PowerPC Architecture. The full architecture of the PPC405GP is defined by the PowerPC Embedded Environment and the PowerPC User Instruction Set Architecture.

The primary extensions of the PowerPC Architecture defined in the Embedded Environment are:

- · A simplified memory management mechanism with enhancements for embedded applications
- · An enhanced, dual-level interrupt structure
- An architected DCR address space for integrated peripheral control
- The addition of several instructions to support these modified and extended resources

Finally, some of the specific implementation features of the PPC405GP are beyond the scope of the PowerPC Architecture. These features are included to enhance performance, integrate functionality, and reduce system complexity in embedded control applications.

# 1.4 **RISC Processor Core Organization**

The processor core consists of a 5-stage pipeline, separate instruction and data cache units, virtual memory management unit (MMU), three timers, debug, and interfaces to other functions.

### **1.4.1** Instruction and Data Cache Controllers

The PPC405GP processor core uses a 16KB instruction cache unit (ICU) and an 8KB data cache unit (DCU) to enable concurrent accesses and minimize pipeline stalls. Both cache units are two-way setassociative and use a 32-byte line size. The instruction set provides a rich assortment of cache control instructions, including instructions to read tag information and data arrays. See Chapter 4, "Cache Operations," for detailed information about the ICU and DCU.

## 1.4.1.1 Instruction Cache Unit

The ICU provides one or two instructions per cycle to the execution unit (EXU) over a 64-bit bus. A line buffer (built into the output of the array for manufacturing test) enables the ICU to be accessed only once for every four instructions, to reduce power consumption by the array.

The ICU can forward any or all of the words of a line fill to the EXU to minimize pipeline stalls caused by cache misses. The ICU aborts speculative fetches abandoned by the EXU, eliminating unnecessary line fills and enabling the ICU to handle the next EXU fetch. Aborting abandoned requests also eliminates unnecessary PLB activity to increase PLB availability for other on-chip cores, such as the DMA and Ethernet controllers.

## 1.4.1.2 Data Cache Unit

The DCU transfers 1, 2, 3, 4, or 8 bytes per cycle, depending on the number of byte enables presented by the CPU. The DCU contains a single-element command and store data queue to reduce pipeline stalls; this queue enables the DCU to independently process load/store and cache control instructions. Dynamic PLB request prioritization reduces pipeline stalls even further. When the DCU is busy with a low-priority request while a subsequent storage operation requested by the CPU is stalled, the DCU automatically increases the priority of the current request to the PLB.

The DCU uses a two-line flush queue to minimize pipeline stalls caused by cache misses. Line flushes are postponed until after a line fill is completed. Registers comprise the first position of the flush queue; the line buffer built into the output of the array for manufacturing test serves as the second position of the flush queue. Pipeline stalls are further reduced by forwarding the requested word to the CPU during the line fill. Single-queued flushes are non-blocking. When a flush operation is pending, the DCU can continue to access the array to determine subsequent load or store hits. Under these conditions, load hits can occur concurrently with store hits to write-back memory without stalling the pipeline. Requests abandoned by the CPU can also be aborted by the cache controller.

Additional DCU features enable the programmer to tailor performance for a given application. The DCU can function in write-back or write-through mode, as controlled by the Data Cache Write-through Register (DCWR) or the translation look-aside buffer (TLB). DCU performance can be tuned to balance performance and memory coherency. Store-without-allocate, controlled by the SWOA field of the Core Configuration Register 0 (CCR0), can inhibit line fills caused by store misses to further reduce potential pipeline stalls and unwanted external bus traffic. Similarly, load-without-allocate, controlled by CCR0[LWOA], can inhibit line fills caused by load misses.

# 1.4.2 Memory Management Unit

The 4GB address space of the PPC405GP is presented as a flat address space.

The MMU provides address translation, protection functions, and storage attribute control for embedded applications. The MMU supports demand paged virtual memory and other management schemes that require precise control of logical to physical address mapping and flexible memory protection. Working with appropriate system level software, the MMU provides the following functions:

- Translation of the 4GB logical address space into physical addresses
- · Independent enabling of instruction and data translation/protection
- Page level access control using the translation mechanism
- Software control of page replacement strategy
- Additional control over protection using zones

• Storage attributes for cache policy and speculative memory access control

The MMU can be disabled under software control. If the MMU is not used, the PPC405GP provides other storage control mechanisms.

The translation lookaside buffer (TLB) is the hardware resource that controls translation and protection. It consists of 64 entries, each specifying a page to be translated. The TLB is fully associative; a page entry can be placed anywhere in the TLB. The translation function of the MMU occurs pre-cache for data accesses. Cache tags and indexing use physical addresses for data accesses; instruction fetches are virtually indexed and physically tagged.

Software manages the establishment and replacement of TLB entries. This gives system software significant flexibility in implementing a custom page replacement strategy. For example, to reduce TLB thrashing or translation delays, software can reserve several TLB entries for globally accessible static mappings. The instruction set provides several instructions to manage TLB entries. These instructions are privileged and require the software to be executing in supervisor state. Additional TLB instructions are provided to move TLB entry fields to and from GPRs.

The MMU divides logical storage into pages. Eight page sizes (1KB, 4KB, 16KB, 64KB, 256KB, 1MB, 4MB, 16MB) are simultaneously supported, so that, at any given time, the TLB can contain entries for any combination of page sizes. For a logical to physical translation to occur, a valid entry for the page containing the logical address must be in the TLB. Addresses for which no TLB entry exists cause TLB-Miss exceptions.

To improve performance, 4 instruction-side and 8 data-side TLB entries are kept in shadow arrays. The shadow arrays prevent TLB contention. Hardware manages the replacement and invalidation of shadow-TLB entries; no system software action is required. The shadow arrays can be thought of as level 1 TLBs, with the main TLB serving as a level 2 TLB.

When address translation is enabled, the translation mechanism provides a basic level of protection. Physical addresses not mapped by a page entry are inaccessible when translation is enabled. Read access is implied by the existence of the valid entry in the TLB. The EX and WR bits in the TLB entry further define levels of access for the page, by permitting execute and write access, respectively.

The Zone Protection Register (ZPR) enables the system software to override the TLB access controls. For example, the ZPR provides a way to deny read access to application programs. The ZPR can be used to classify storage by type; access by type can be changed without manipulating individual TLB entries.

The PowerPC Architecture provides WIU0GE (write-back/write through, cacheability, user-defined 0, guarded, endian) storage attributes that control memory accesses, using bits in the TLB or, when address translation is disabled, storage attribute control registers.

When address translation is enabled (MSR[IR, DR] = 1), storage attribute control bits in the TLB control the storage attributes associated with the current page. When address translation is disabled (MSR[IR, DR] = 0), bits in each storage attribute control register control the storage attributes associated with storage regions. Each storage attribute control register contains 32 fields. Each field sets the associated storage attribute for a 128MB memory region. See "Real-mode Storage Attribute Control" on page 6-17 for more information about the storage attribute control registers.

# 1.4.3 Timer Facilities

The processor core contains a time base and three timers:

- Programmable Interval Timer (PIT)
- Fixed Interval Timer (FIT)
- · Watchdog timer

The time base is a 64-bit counter incremented either by an internal signal equal to the CPU clock rate or by a separate external timer clock signal. No interrupts are generated when the time base rolls over.

The PIT is a 32-bit register that is decremented at the same rate as the time base is incremented. The user loads the PIT register with a value to create the desired delay. When a decrement occurs on a PIT count of 1, the timer stops decrementing, a bit is set in the Timer Status Register (TSR), and a PIT interrupt is generated. Optionally, the PIT can be programmed to reload automatically the last value written to the PIT register, after which the PIT begins decrementing again. The Timer Control Register (TCR) contains the interrupt enable for the PIT interrupt.

The FIT generates periodic interrupts based on selected bits in the time base. Users can select one of four intervals for the timer period by setting the appropriate bits in the TCR. When the selected bit in the time base changes from 0 to 1, a bit is set in the TSR and a FIT interrupt is generated. The FIT interrupt enable is contained in the TCR.

The watchdog timer generates a periodic interrupt based on selected bits in the time base. Users can select one of four time periods for the interval and the type of reset generated if the watchdog timer expires twice without an intervening clear from software.

# 1.4.4 Debug

The processor core debug facilities include debug modes for the various types of debugging used during hardware and software development. Also included are debug events that allow developers to control the debug process. Debug modes and debug events are controlled using debug registers in the chip. The debug registers are accessed either through software running on the processor, or through the JTAG port. The JTAG port can also be used for board test.

The debug modes, events, controls, and interfaces provide a powerful combination of debug facilities for hardware and software development tools

### 1.4.4.1 Development Tool Support

The PPC405GP supports a wide range of hardware and software development tools.

An operating system debugger is an example of an operating system-aware debugger, implemented using software traps.

RISCWatch is an example of a development tool that uses the external debug mode, debug events, and the JTAG port to support hardware and software development and debugging.

The RISCTrace<sup>™</sup> feature of RISCWatch is an example of a development tool that uses the real-time trace capability of the processor core.

# 1.4.4.2 Debug Modes

The internal, external, real-time-trace, and debug wait modes support a variety of debug tool used in embedded systems development. These debug modes are described in detail in "Debug Modes" on page 12-6.

## 1.4.5 Processor Core Interfaces

The processor core provides a range of I/O interfaces.

### 1.4.5.1 Processor Local Bus

The PLB-compliant interface provides separate 32-bit address and 64-bit data buses for the instruction and data sides.

### 1.4.5.2 Device Control Register Bus

The Device Control Register (DCR) bus interface provides access to on-chip registers for configuration and status of peripherals such as SDRAM, DMA and so on.

These registers are accessed using the **mfdcr** and **mtdcr** instructions.

#### 1.4.5.3 Clock and Power Management

This interface supports several methods of clock distribution and power management.

### 1.4.5.4 JTAG

The JTAG port is enhanced to support the attachment of a debug tool such as the RISCWatch product from IBM Microelectronics. Through the JTAG test access port, a debug tool can single-step the processor and interrogate internal processor state to facilitate software debugging. The enhancements comply with the IEEE 1149.1 specification for vendor-specific extensions, and are therefore compatible with standard JTAG hardware for boundary-scan system testing.

#### 1.4.5.5 Interrupts

The processor core provides an interface to the UIC, an on-chip interrupt controller that is logically outside the processor core. The UIC combines asynchronous interrupt inputs from on-chip and off-chip sources and presents them to the processor core using a pair of interrupt signals: critical and non-critical.

### 1.4.5.6 On-Chip Memory

The on-chip memory (OCM) interface supports the implementation of instruction- and data-side memory that can be accessed at performance levels matching the cache arrays.

The PPC405GP provides 4KB of OCM.

# **1.5 Processor Core Programming Model**

The programming model is described in detail in Chapter 3, "Programming Model."

The PowerPC instruction set and Special Purpose Registers (SPRs) provide a high degree of user control over configuration and operation of the processor core functional units.

# 1.5.1 Data Types

Processor core operands are bytes, halfwords, and words. Multiple words or strings of bytes can be transferred using the load/store multiple and load/store string instructions. Data is represented in twos complement notation or in unsigned fixed-point format.

The address of a multibyte operand is always the lowest memory address occupied by that operand. Byte ordering can be selected as big endian (the lowest memory address of an operand contains its most significant byte) or as little endian (the lowest memory address of an operand contains its least significant byte). See "Byte Ordering" on page 3-28 for more information about big and little endian operation.

# 1.5.2 Processor Core Register Set Summary

The processor core registers can be grouped into basic categories based on function and access mode: general purpose registers (GPRs), special purpose registers (SPRs), the machine state register (MSR), the condition register (CR), and device control registers (DCRs).

Chapter 25, "Register Summary," provides a register diagram and a register field description table for each register.

## 1.5.2.1 General Purpose Registers

The processor core contains 32 GPRs; each register contains 32 bits. The contents of the GPRs can be transferred from memory using load instructions and stored to memory using store instructions. GPRs, which are specified as operands in many instructions, can also receive instruction results and the contents of other registers.

### 1.5.2.2 Special Purpose Registers

Special Purpose Registers (SPRs), which are part of the PowerPC Architecture, are accessed using the **mtspr** and **mfspr** instructions. SPRs control the use of the debug facilities, timers, interrupts, storage control attributes, and other architected processor resources.

All SPRs are privileged (unavailable to user-mode programs), except the Count Register (CTR), the Link Register (LR), SPR General Purpose Registers (SPRG4–SPRG7, read-only), and the Fixed-point Exception Register (XER). Note that access to the Time Base Lower (TBL) and Time Base Upper (TBU) registers, when addressed as SPRs, is write-only and privileged. However, when addressed as Time Base Registers (TBRs), read access to these registers is not privileged. See "Time Base Registers" on page 25-3 for more information.

# 1.5.2.3 Machine State Register

The processor core contains a 32-bit Machine State Register (MSR). The contents of a GPR can be written to the MSR using the **mtmsr** instruction, and the MSR contents can be read into a GPR using the **mfmsr** instruction. The MSR contains fields that control the operation of the processor core.

# 1.5.2.4 Condition Register

The processor core contains a 32-bit Condition Register (CR). These bits are grouped into eight 4-bit fields, CR[CR0]–CR[CR7]. Instructions are provided to perform logical operations on CR fields and bits within fields and to test CR bits within fields. The CR fields, which are set by compare instructions, can be used to control branches. CR[CR0] can be set implicitly by arithmetic instructions.

## 1.5.2.5 Device Control Registers

DCRs, which are architecturally outside of the processor core, are accessed using the **mtdcr** and **mfdcr** instructions. DCRs are used to control, configure, and hold status for various functional units that are not part of the processor core.

The **mtdcr** and **mfdcr** instructions are privileged, for all DCRs. Therefore, all accesses to DCRs are privileged. See "Privileged Mode Operation" on page 3-41.

# 1.5.3 Memory-Mapped I/O Registers

The memory-mapped I/O (MMIO) registers are accessed using load and store instructions. MMIO registers, which are outside processor core and which are not architected, are used to control, configure, and hold status for various functional units that are not part of the processor core.

## 1.5.4 Addressing Modes

The processor core supports the following addressing modes, which enable efficient retrieval and storage of data in memory:

- Base plus displacement addressing
- Indexed addressing
- · Base plus displacement addressing and indexed addressing, with update

In the base plus displacement addressing mode, an effective address (EA) is formed by adding a displacement to a base address contained in a GPR (or to an implied base of 0). The displacement is an immediate field in an instruction.

In the indexed addressing mode, the EA is formed by adding an index contained in a GPR to a base address contained in a GPR (or to an implied base of 0).

The base plus displacement and the indexed addressing modes also have a "with update" mode. In "with update" mode, the effective address calculated for the current operation is saved in the base GPR, and can be used as the base in the next operation. The "with update" mode relieves the processor from repeatedly loading a GPR with an address for each piece of data, regardless of the proximity of the data in memory.

1-12 PPC405GP User's Manual

# Chapter 2. On-Chip Buses

The on-chip bus architecture, which consists of the processor local bus (PLB), on-chip peripheral bus (OPB), and device control register (DCR) bus, provides a link between the cache units in the processor core and other PLB and OPB master and slave devices used in the PPC405GP. These devices include the SDRAM controller, PCI bridge, DMA controller, and external bus controller.

The PLB is a high performance bus used to access memory through bus interface units. The PLB master and slave assignments for the PPC405GP are listed in "PLB Masters and Slaves" on page 2-2.

Lower performance peripherals (such as serial ports) are attached to the OPB. A bridge between the PLB and OPB enables data transfers between PLB masters and OPB slaves. DMA peripherals can also be OPB peripherals.

The DCR bus is used primarily to access status and control registers of the various PLB and OPB masters and slaves. The DCR bus offloads status and control read and write transfers from the PLB. The DCR bus is not described further in this chapter.

The following publications, which are available from your IBM representative and in the IBM Microelectronics technical library (www.chips.ibm.com), describe the on-chip bus architecture:

- The CoreConnect<sup>™</sup> Bus Architecture
- Processor Local Bus Architecture Specifications
- On-Chip Peripheral Bus Architecture Specifications
- Device Control Register Bus Architecture Specifications

The PPC405GP block diagram (Figure 1-1 on page 1-2) illustrates the on-chip bus structure of the PPC405GP.

# 2.1 Processor Local Bus

The PLB is a high-performance on-chip bus. The PLB supports read and write data transfers between master and slave devices equipped with a PLB interface and connected through PLB signals.

Each PLB master is attached to the PLB through separate address, read data and write data buses, and transfer qualifier signals. PLB slaves are attached to the PLB through shared, but decoupled, address, read data and write data buses, and transfer control and status signals for each data bus.

Access to the PLB is granted through a central arbitration mechanism that enables masters to compete for bus ownership. This arbitration mechanism provides for fixed and fair priority schemes.

Timing for all PLB signals is provided by a clock source that is shared by all PLB masters and slaves.

# 2.1.1 PLB Features

- Overlapping of read and write transfers allows two data transfers per clock cycle for maximum bus utilization
- · Decoupled address and data buses support split-bus transaction capability for improved bandwidth
- Address pipelining reduces overall bus latency by allowing the latency associated with a new request to be overlapped with an ongoing data transfer in the same direction
- · Late master request abort capability reduces latency associated with aborted requests
- Four levels of request priority and selectable arbitration modes provide flexible arbitration policies.
- Support for 16-, 32-, and 64-byte line data transfers
- · Sequential burst protocol allows byte, halfword, and word burst data transfers.
- DMA buffered peripheral-to-memory, memory-to-peripheral, and memory-to-memory operations are supported

# 2.1.2 PLB Masters and Slaves

Table 2-1 lists the PLB masters and slaves provided in the PPC405GP.

| PLB Agent                                          | PLB Master/Slave |
|----------------------------------------------------|------------------|
| Processor core ICU                                 | Master           |
| Processor core DCU                                 | Master           |
| External bus master interface                      | Master           |
| Static memory/peripherals                          | Slaves           |
| PCI bridge (PCI to PLB)<br>PCI bridge (PLB to PCI) | Master<br>Slave  |
| MAL                                                | Master           |
| DMA controller                                     | Master           |
| PLB to OPB bridge                                  | Slave            |
| SDRAM controller                                   | Slave            |

Table 2-1. PPC405GP PLB Agents as Masters and Slaves

The SDRAM and EBC slaves are connected in line with the decompression controller. When the decompression controller is disabled, a bypass mode that directly accesses SDRAM and the EBC is used. When the decompression controller is enabled, it intercepts reads from compressed regions before they reach SDRAM and the EBC.

# 2.1.3 PLB Master Assignments

Each PLB master can be programmed to use one of four priority levels during PLB transfers, enabling the system designer to tune PLB transfer priorities to the requirements of a particular application. For example, if an application always requires PCI to SDRAM transfers to have the lowest latency, the PCI master can be programmed to the highest PLB master priority. This causes the PLB arbiter to grant PCI access requests before granting the access requests of any other master.

**Programming Note:** PLB master priority assignments, which are application-dependent, must be considered carefully to prevent potential lockouts of lower priority masters. For most applications, assigning a priority of 0b10 to each master is a useful starting point.

A register associated with each master controls the priority of that master. Table 2-2 lists the PLB masters and the register fields controlling the priority of the masters. Priorities range from 0b00 (lowest) to 0b11 (highest).

| Master ID | Description                        | Register Field                   | Comments                                                                                                                           |
|-----------|------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 0         | Processor core ICU                 | CCR0[IPP]                        |                                                                                                                                    |
| 1         | Processor core data cache unit DCU | CCR0[DPP1]                       | The high-order bit of<br>CCR0[DPP1] is controlled<br>by the DCU logic, so only<br>the low-order priority bit<br>can be programmed. |
| 2         | External bus master                | EBC0_CFG[EMPL]<br>EBC0_CFG[EMPH] | Which field sets external<br>master priority depends<br>upon the setting of the<br>HoldPri signal.                                 |
| 3         | PCI bridge                         | PCIC0_BRDGOPT1[PRP]              | Reset value is 0b11                                                                                                                |
| 4         | MAL                                | MAL0_CFG[PLBP]                   |                                                                                                                                    |
| 5         | DMA controller                     | DMA0_CR0[CP]                     | Unique priorities can be                                                                                                           |
|           |                                    | DMA0_CR1[CP]                     | assigned to each DMA                                                                                                               |
|           |                                    | DMA0_CR2[CP]                     | channel.                                                                                                                           |
|           |                                    | DMA0_CR3[CP]                     |                                                                                                                                    |

Table 2-2. Registers Controlling PLB Master Priority Assignments

See "PLB Arbiter Control Register (PLB0\_ACR)" on page 2-5 for information about programming the PLB0\_ACR to control PLB priority mode and priority order, which determine how the PLB arbitrates simultaneous PLB bus access requests having equal priorities.

# 2.1.4 PLB Transfer Protocol

A PLB transaction is composed of an address cycle and a data cycle.

The address cycle has three phases: request, transfer, and address acknowledge. A PLB transaction begins when a master drives its address and transfer qualifier signals and requests ownership of the bus during the request phase of the address cycle. Once bus ownership has been granted by the PLB arbiter, the master's address and transfer qualifiers are presented to the slave devices during the transfer phase.

During normal operation, the address cycle is terminated by a slave latching the master's address and transfer qualifiers during the address acknowledge phase.

Each data beat in the data cycle has two phases: transfer and data acknowledge. During the transfer phase, the master drives the write data bus for a write transfer or samples the read data bus for a read

transfer. Data acknowledge signals are required during the data acknowledge phase for each data beat in a data cycle.

**Note:** For single-beat transfers, data acknowledge signals also indicate the end of the data transfer. For line or burst transfers, the data acknowledge signals apply to each beat and indicate the end of the data cycle only after the final beat.

#### 2.1.5 Overlapped PLB Transfers

Figure 2-1 shows an example of overlapped PLB transactions on the read/write data buses with pipelining. PLB address, read data, and write data buses are decoupled from one another, allowing for address cycles to be overlapped with read or write data cycles, and for read data cycles to be overlapped with write data cycles. The PLB split-bus transaction capability allows the address and data buses to have different masters at the same time.

PLB address pipelining capability enables a new bus transfer to begin before an ongoing transfer finishes. Address pipelining reduces overall bus latency on the PLB by enabling the latency associated with a new transfer request to be overlapped with an ongoing data transfer in the same direction.

PLB masters A and B each present a read request followed by a write request. Master B gets the bus first, so its read is the primary read transaction. The master A address cycle begins as soon as the master B address cycle ends. The master A read is taken as a secondary transfer. Writes follow reads.



#### Figure 2-1. Overlapped PLB Transfers

**Note:** A master can begin to request ownership of the PLB in parallel with the address cycle or data cycle of another master bus transfer. Overlapped read and write data transfers and split-bus transactions enable the PLB to operate at a very high bandwidth.

# 2.1.6 PLB Arbiter Registers

PLB arbiter registers are DCRs accessed using the mfdcr and mtdcr instructions.

Table 2-3 summarizes the PLB arbiter DCRs.

| Mnemonic  | Register Name                | Address | Access  | Page |
|-----------|------------------------------|---------|---------|------|
| PLB0_ACR  | PLB Arbiter Control Register | 0x087   | R/W     | 2-5  |
| PLB0_BEAR | PLB Error Address Register   | 0x086   | R/O     | 2-5  |
| PLB0_BESR | PLB Error Status Register    | 0x084   | R/Clear | 2-6  |

# 2.1.6.1 PLB Arbiter Control Register (PLB0\_ACR)

The PLB0\_ACR controls PLB arbitration priority, which is determined by PLB priority mode and PLB priority order.



| 0    | PPM | PLB Priority Mode<br>0 Fixed<br>1 Fair                                                                                                                                                                                                             |
|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:3  | PPO | PLB Priority Order<br>000 Masters 0, 1, 2, 3, 4, 5<br>001 Masters 1, 2, 3, 4, 5, 0<br>010 Masters 2, 3, 4, 5, 0, 1<br>011 Masters 3, 4, 5, 0, 1, 2<br>100 Masters 4, 5, 0, 1, 2, 3<br>101 Masters 5, 0, 1, 2, 3, 4<br>110 Reserved<br>111 Reserved |
| 4    | HBU | High Bus Utilization<br>0 Disabled<br>1 Enabled                                                                                                                                                                                                    |
| 5:31 |     | Reserved                                                                                                                                                                                                                                           |
|      |     |                                                                                                                                                                                                                                                    |

| Figure 2-2  | <b>DIR</b> Arbitor ( | Control Registe |  |
|-------------|----------------------|-----------------|--|
| rigule z-z. | FLD AIDILEI (        | Johnor negiste  |  |

# 2.1.6.2 PLB Error Address Register (PLB0\_BEAR)

The read-only PLB0\_BEAR contains the address of the access on which a bus timeout error occurred.

The PLB0\_BEAR can be locked by the master. Once locked, the PLB0\_BEAR cannot be updated, if a subsequent error occurs, until all PLB0\_BESR[FLCK*n*] fields are cleared (*n* is the master ID).

Figure 2-3. PLB Error Address Register (PLB0\_BEAR)

|      | -                            | - | • | •                                     |  |
|------|------------------------------|---|---|---------------------------------------|--|
| 0:31 | Address of bus timeout error |   |   | · · · · · · · · · · · · · · · · · · · |  |

### 2.1.6.3 PLB Error Status Register (PLB0\_BESR)

The read/clear PLB0\_BESR identifies timeout errors on PLB bus transfers, the master initiating the transfer, and the type of transfer.

Each PLB0\_BESR[PTE*n*] field (*n* is the master ID) can be locked by the master. Once locked, PLB0\_BESR [PTE*n*] fields cannot be updated if a subsequent error occurs until the corresponding PLB0\_BESR [FLCK*n*] field is cleared. To clear a PLB0\_BESR field, write 1 to the field. Writing 0 to a PLB0\_BESR field does not affect the field.



| 0 | PTE0 | Master 0 PLB Timeout Error Status<br>0 No master 0 timeout error<br>1 Master 0 timeout error                      | Master 0 is the processor core ICU. |
|---|------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| 1 | R/W0 | Master 0 Read/Write Status<br>0 Master 0 error operation was a write<br>1 Master 0 ICU error operation was a read |                                     |
| 2 | FLK0 | Master 0 PLB0_BESR Field Lock<br>0 Master 0 PLB0_BESR field is unlocked<br>1 Master 0 field is locked             |                                     |
| 3 | ALK0 | Master 0 PLB0_BEAR Address Lock<br>0 Master 0 PLB0_BEAR is unlocked<br>1 Master 0 PLB0_BEAR is locked             |                                     |
| 4 | PTE1 | Master 1 PLB Timeout Error Status<br>0 No master 1 timeout error<br>1 Master 1 timeout error                      | Master 1 is the processor core DCU. |
| 5 | R/W1 | Master 1 Read/Write Status<br>0 Master 1 error operation was a write<br>1 Master 1 error operation was a read     |                                     |

| Figure 2-4. | DIR        | Error | Statue | Register |       | BECB) |
|-------------|------------|-------|--------|----------|-------|-------|
| Figure 2-4. | <b>FLD</b> | EIIUI | อเลเนร | negister | (FLDV | DEON  |

2-6 PPC405GP User's Manual

0

31

| 6  | FLK1 | Master 1PLB0_BESR Field Lock<br>0 Master 1 PLB0_BESR field is unlocked<br>1 Master 1 PLB0_BESR field is locked  |                                  |
|----|------|-----------------------------------------------------------------------------------------------------------------|----------------------------------|
| 7  | ALK1 | Master 1 PLB0_BEAR Address Lock<br>0 Master 1 PLB0_BEAR is unlocked<br>1 Master 1 PLB0_BEAR is locked           |                                  |
| 8  | PTE2 | Master 2 PLB Timeout Error Status<br>0 No master 2 timeout error<br>1 Master 2 timeout error                    | Master 2 is the external master. |
| 9  | R/W2 | Master 2 Read/Write Status<br>0 Master 2 error operation was a write<br>1 Master 2 error operation was a read   |                                  |
| 10 | FLK2 | Master 2 PLB0_BESR Field Lock<br>0 Master 2 PLB0_BESR field is unlocked<br>1 Master 2 PLB0_BESR field is locked |                                  |
| 11 | AL2  | Master 2 PLB0_BEAR Address Lock<br>0 Master 2 PLB0_BEAR is unlocked<br>1 Master 2 PLB0_BEAR is locked           |                                  |
| 12 | PTE3 | Master 3 PLB Timeout Error Status<br>0 No Master 3 timeout error<br>1 Master 3 timeout error                    | Master 3 is PCI.                 |
| 13 | R/W3 | Master 3 Read/Write Status<br>0 Master 3 error operation was a write<br>1 Master 3 error operation was a read   |                                  |
| 14 | FLK3 | Master 3 PLB0_BESR Field Lock<br>0 Master 3 PLB0_BESR field is unlocked<br>1 Master 3 PLB0_BESR field is locked |                                  |
| 15 | ALK3 | Master 3 PLB0_BEAR Address Lock<br>0 Master 3 PLB0_BEAR is unlocked<br>1 Master 3 PLB0_BEAR is locked           |                                  |
| 16 | PTE4 | Master 4 PLB Timeout Error Status<br>0 No master 4 timeout error<br>1 Master 4 timeout error                    | Master 4 is MAL.                 |
| 17 | R/W4 | Master 4 Read/Write Status<br>0 Master 4 error operation was a write<br>1 Master 4 error operation was a read   |                                  |
| 18 | FLK4 | Master 4 PLB0_BESR Field Lock<br>0 Master 4 PLB0_BESR field is unlocked<br>1 Master 4 field is locked           |                                  |
| 19 | ALK4 | Master 4 PLB0_BEAR Address Lock<br>0 Master 4 PLB0_BEAR is unlocked<br>1 Master 4 PLB0_BEAR is locked           |                                  |
| 20 | PTE5 | Master 5 PLB Timeout Error Status<br>0 No master 5 timeout error<br>1 Master 5 timeout error                    | Master 5 is DMA.                 |
| 21 | R/W5 | Master 5 Read/Write Status<br>0 Master 5 error operation was a write<br>1. Master 5 error operation was a read  |                                  |

.

۰.

| 22    | FLK5 | Master 5 PLB0_BESR Field Lock<br>0 Master 5 PLB0_BESR field is unlocked<br>1 Master 5 PLB0_BESR field is locked |  |
|-------|------|-----------------------------------------------------------------------------------------------------------------|--|
| 23    | ALK5 | Master 5 PLB0_BEAR Address Lock<br>0 Master 5 PLB0_BEAR is unlocked<br>1 Master 5 PLB0_BEAR is locked           |  |
| 24:31 |      | Reserved                                                                                                        |  |

### 2.1.7 PLB to OPB Bridge Registers

The PLB to OPB bridge registers are DCRs accessed using the mfdcr and mtdcr instructions.

Table 2-4 lists the PLB to OPB bridge registers.

| Mnemonic   | Register Name                                            | Address | Access  | Page |  |
|------------|----------------------------------------------------------|---------|---------|------|--|
| POB0_BEAR  | Bridge Error Address Register                            | 0x0A2   | R/O     | 2-5  |  |
| POB0_BESR0 | Bridge Error Status Register 0<br>(Master IDs 0,1, 2, 3) | 0x0A0   | R/Clear | 2-5  |  |
| POB0_BESR1 | Bridge Error Status Register<br>(Master IDs 4, 5)        | 0x0A4   | R/Clear | 2-6  |  |

#### Table 2-4. PLB Arbiter Registers

### 2.1.7.1 Bridge Error Address Register (POB0\_BEAR)

The read-only POB0\_BEAR reports the address of a PLB to OPB transfer that results in an error. The PLB to OPB bridge writes the error address in the POB0\_BEAR, unless the associated POB0\_BESR*m*[ALCK*n*] field is set (*m* is either 0 or 1, depending on the master ID specified by *n*). Once locked, the PLB to OPB bridge cannot write POB0\_BEAR until all POB0\_BESR*m*[ALCK*n*] fields that are set are cleared.



#### Figure 2-5. Bridge Error Address Register (POB0\_BEAR)

| 0:31 | <sup>•</sup> 0x0B2 | Address of bus error |
|------|--------------------|----------------------|
|      |                    |                      |

### 2.1.7.2 Bridge Error Status Registers (POB0\_BESR0-POB0\_BESR1)

The PLB to OPB bridge writes error information into the appropriate POB0\_BESR*m* register. (For master IDs 0, 1, 2, and 3, m = 0; for master IDs 4 and 5, m = 1.)

POB0\_BESR*m* fields can be locked using the POB0\_BESR*m*[FLK*n*] and POB0\_BESR*m*[ALK*n*] fields (*n* is the master ID). Once locked, the POB0\_BESR*m* fields associated with a master cannot be overwritten if a subsequent error occurs until the locking fields are cleared. To clear a lock, write 1 to

the POB0\_BESR*m*[FLK*n*] and POB0\_BESR*m*[ALK*n*] fields that are set. Writing 0 to a lock field does not affect the field.



| 0:1   | PTE0 | PLB Timeout Error Status Master 0<br>00 No master 0 error occurred<br>01 Master 0 timeout error occurred<br>10 Master 0 slave error occurred<br>11 Reserved | Master 0 is the processor core ICU. |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| 2     | R/W0 | Read Write Status Master 0<br>0 Master 0 error operation is a read<br>1 Master 0 error operation is a write                                                 |                                     |
| 3     | FLK0 | POB0_BESR0 Field Lock Master 0<br>0 Master 0 POB0_BESR0 field is unlocked<br>1 Master 0 POB0_BESR0 field is locked                                          |                                     |
| 4     | ALK0 | POB0_BEAR Address Lock Master 0<br>0 Master 0 POB0_BEAR address is<br>unlocked<br>1 Master 0 POB0_BEAR address is locked                                    |                                     |
| 5:6   | PTE1 | PLB Timeout Error Status Master 1<br>00 No master 1 error occurred<br>01 Master 1 timeout error occurred<br>10 Master 1 slave error occurred<br>11 Reserved | Master 1 is the processor core DCU. |
| 7     | R/W1 | Read/Write Status Master 1<br>0 Master 1 error operation is a read<br>1 Master 1 error operation is a write                                                 |                                     |
| 8     | FLK1 | POB0_BESR0 Field Lock Master 1<br>0 Master 1 POB0_BESR0 field is unlocked<br>1 Master 1 POB0_BESR0 field is locked                                          |                                     |
| 9     | ALK1 | POB0_BEAR Address Lock Master 1<br>0 Master 1 POB0_BEAR address is<br>unlocked<br>1 Master 1 POB0_BEAR address is locked                                    |                                     |
| 10:11 | PTE2 | PLB Timeout Error Status Master 2<br>00 No master 2 error occurred<br>01 Master 2 timeout error occurred<br>10 Master 2 slave error occurred<br>11 Reserved | Master 2 is the external master.    |
| 12    | R/W2 | Read/Write Status Master 2<br>0 Master 2 error operation is a read<br>1 Master 2 error operation is a write                                                 |                                     |

### Figure 2-6. Bridge Error Status Register 0 (POB0\_BESR0)

| 13    | FLK2 | POB0_BESR0 Field Lock Master 2<br>0 Master 2 POB0_BESR0 field is unlocked<br>1 Master 2 POB0_BESR0 field is locked                                          |                                       |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 14    | ALK2 | POB0_BEAR Address Lock Master 2<br>0 Master 2 POB0_BEAR address is<br>unlocked<br>1 Master 2 POB0_BEAR address is locked                                    |                                       |
| 15:16 | PTE3 | PLB Timeout Error Status Master 3<br>00 No master 3 error occurred<br>01 Master 3 timeout error occurred<br>10 Master 3 slave error occurred<br>11 Reserved | Master 3 is PCI.                      |
| 17    | R/W3 | Read/Write Status Master 3<br>0 Master 3 error operation is a read<br>1 Master 3 error operation is a write                                                 |                                       |
| 18    | FLK3 | POB0_BESR0 Field Lock Master 3<br>0 Master 3 POB0_BESR0 field is unlocked<br>1 Master 3 POB0_BESR0 field is locked                                          |                                       |
| 19    | ALK3 | POB0_BEAR Address Lock Master 3<br>0 Master 3 POB0_BEAR address is<br>unlocked<br>1 Master 3 POB0_BEAR address is locked                                    |                                       |
| 20:31 |      | Reserved                                                                                                                                                    | · · · · · · · · · · · · · · · · · · · |

Figure 2-7 illustrates POB0\_BESR1.

| P | ГE4<br>↓ | i   | =LK        | 4   | PT | E5 | F   | ⁼ικ | 5   |      |
|---|----------|-----|------------|-----|----|----|-----|-----|-----|------|
| 0 | 1        | 2   | 3          | 4   | 5  | 6  | 7   | 8   | 9   | 1031 |
|   | -        | R/W | 4 <i>A</i> | ALK | 4  | F  | ₹/₩ | 5 / | ALK | 5    |

| Figure 2-7.         | Bridge | <b>Error Status</b> | <b>Register 1</b> | (POB0 | BESR1) | ) |
|---------------------|--------|---------------------|-------------------|-------|--------|---|
| inguic <u>r</u> -ri | Diluge | Enor otatas         | riegister i       | 1000  |        | , |

| 0:1 | PTE4 | PLB Timeout Error Status Master 4<br>00 No Master 4 error occurred<br>01 Master 4 timeout error occurred<br>10 Master 4 slave error occurred<br>11 Reserved | Master 4 is MAL. |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 2   | R/W4 | Read/Write Status Master 4<br>0 Master 4 error operation is a read<br>1 Master 4 error operation is a write                                                 |                  |
| 3   | FLK4 | POB0_BESR1 Field Lock Master 4<br>0 Master 4 POB0_BESR1 field is unlocked<br>1 Master 4 POB0_BESR1 field is locked                                          |                  |

| 4     | ALK4 | POB0_BEAR Address Lock Master 4<br>0 Master 4 POB0_BEAR address is<br>unlocked<br>1 Master 4 POB0_BEAR address is locked                                    |                  |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 5:6   | PTE5 | PLB Timeout Error Status Master 5<br>00 No Master 5 error occurred<br>01 Master 5 timeout error occurred<br>10 Master 5 slave error occurred<br>11 Reserved | Master 5 is DMA. |
| 7     | R/W5 | Read/Write Status Master 5<br>0 Master 5 error operation is a read<br>1 Master 5 error operation is a write                                                 |                  |
| 8     | FLK5 | POB0_BESR1 Field Lock Master 5<br>0 Master 5 POB0_BESR1 field is unlocked<br>1 Master 5 POB0_BESR1 field is locked                                          |                  |
| 9     | ALK5 | POB0_BEAR Address Lock Master 5<br>0 Master 5 POB0_BEAR address is<br>unlocked<br>1 Master 5 POB0_BEAR address is locked                                    |                  |
| 10:31 |      | Reserved                                                                                                                                                    |                  |

### 2.1.7.3 On-Chip Peripheral Bus

The OPB is used to attach peripherals that do not require the bandwidth of the PLB. The OPB does not connect directly to the PPC405GP processor core, which accesses peripherals attached to the OPB through a PLB-to-OPB bridge.

### 2.1.8 OPB Features

The on-chip peripheral bus features:

- A 32-bit address bus and a 32-bit data bus
- Dynamic bus sizing; byte, halfword, and word transfers
- Byte and halfword duplication for byte and halfword transfers
- Single-cycle transfer of data between OPB bus master and OPB slaves
- Sequential address (burst) protocol support
- Devices on the OPB may be memory mapped, act as DMA peripherals, or support both transfer methods
- A 16-cycle fixed bus timeout provided by the OPB arbiter
- Bus parking for reduced latency
- Bus arbitration overlapped with last cycle of bus transfers

### 2.1.9 OPB Master Assignments

Table 2-1 lists the OPB masters. (The numbering reflects that the PPC405GP implements two masters; the OPB can support four masters.)

| OPB Agents        | Description                  |  |
|-------------------|------------------------------|--|
| DMA controller    | DMA (master 0)               |  |
| OPB to PLB bridge | OPB to PLB bridge (master 2) |  |

# 2.1.10 OPB Arbiter Registers

The OPB arbiter contains the MMIO registers summarized in Table 2-6.

#### Table 2-6. PLB Arbiter Registers

| Mnemonic | Register Name                 | Address    | Access | Page |
|----------|-------------------------------|------------|--------|------|
| OPBA0_CR | OPB Arbiter Control Register  | 0xEF600601 | R/W    | 2-5  |
| OPBA0_PR | OPB Arbiter Priority Register | 0xEF600600 | R/W    | 2-5  |

#### 2.1.10.1 OPB Arbiter Control Register (OPBA0\_CR)

The OPBA0\_CR fields controls updating of the OPBA0\_PR (described in "OPB Arbiter Priority Register (OPBA0\_PR)" on page 2-13). Because the PPC405GP provides two masters, master IDs 1 and 3 are ignored.



| Figure 2-8. ( | <b>OPB Arbiter Control</b> | Register ( | OPBA0_C | R) |
|---------------|----------------------------|------------|---------|----|
|---------------|----------------------------|------------|---------|----|

| 0 | DPE | Dynamic Priority Enable<br>0 Dynamic priority disabled<br>1 Dynamic priority enabled |
|---|-----|--------------------------------------------------------------------------------------|
| 1 | PEN | Park Enable<br>0 Park disabled<br>1 Park enabled                                     |

| 2    | PMN | Park on Master Not Last<br>0 Park on master last<br>1 Park on master not last      |                                                     |
|------|-----|------------------------------------------------------------------------------------|-----------------------------------------------------|
| 3:4  | PID | Parked Master ID<br>00 Master ID 0<br>01 Reserved<br>10 Master ID 2<br>11 Reserved | Master 0 is DMA; master 2 is the OPB to PLB bridge. |
| 5:31 |     | Reserved                                                                           |                                                     |

### 2.1.10.2 OPB Arbiter Priority Register (OPBA0\_PR)

The OPBA0\_PR assigns priorities to the OPB master IDs. Because the PPC405 provides two masters, master IDs 1 and 3 are ignored. At reset, master ID 0 (DMA) has a higher priority than master 2 (OPB to PLB bridge).



| 0:1  | MIDO | High Priority Master ID<br>00 Master ID 0<br>01 Reserved<br>10 Reserved<br>11 Reserved | At reset, this priority is assigned to DMA.                   |
|------|------|----------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 2:3  |      | Reserved                                                                               |                                                               |
| 4:5  | MID2 | Low Priority master ID<br>00 Reserved<br>01 Reserved<br>10 Master ID 2<br>11 Reserved  | At reset, this priority is assigned to the OPB to PLB bridge. |
| 6:31 |      | Reserved                                                                               |                                                               |

#### Figure 2-9. OPB Arbiter Priority Register (OPBA0\_PR)

2-14 PPC405GP User's Manual

Part II. The PPC405GP RISC Processor

II-2 PPC405GP User's Manual

# Chapter 3. Programming Model

The programming model of the PPC405GP embedded processor describes the following features and operations:

- · Memory organization and addressing, starting on page 3-1
- Registers, starting on page 3-3
- Data types and alignment, starting on page 3-26
- Byte ordering, starting on page 3-28
- Instruction processing, starting on page 3-33
- Branching control, starting on page 3-34
- Speculative accesses, starting on page 3-37
- Privileged mode operation, starting on page 3-41
- Synchronization, starting on page 3-43
- Instruction set, starting on page 3-47

# 3.1 User and Privileged Programming Models

The PPC405GP executes programs in two modes, also referred to as states. Programs running in *privileged mode* (also referred to as the supervisor state) can access any register and execute any instruction. These instructions and registers comprise the privileged programming model. In *user mode*, certain registers and instructions are unavailable to programs. This is also called the problem state. Those registers and instructions that are available comprise the user programming model.

Privileged mode provides operating system software access to all processor resources. Because access to certain processor resources is denied in user mode, application software runs in user mode. Operating system software and other application software is protected from the effects of an errant application program.

Throughout this book, the terms user program and privileged programs are used to associate programs with one of the programming models. Registers and instructions are described as user or privileged. Privileged mode operation is described in detail in "Privileged Mode Operation" on page 3-41.

# 3.2 Memory Organization and Addressing

The PowerPC Architecture defines a 32-bit, 4-gigabyte (GB) address space for instructions and data.

### 3.2.1 Physical Address Map

Table 3-1 illustrates the physical address map.

| Function                              | Start<br>Address | End<br>Address | Size     |
|---------------------------------------|------------------|----------------|----------|
| Local Memory/Peripherals <sup>1</sup> | 0x00000000       | 0x7FFFFFFF     | 2GB      |
| PCI Bridge (Total)                    | 0x80000000       | 0xEF5FFFFF     | 1.744GB  |
| PCI Memory                            | 0x80000000       | 0xE7FFFFFF     | 1.625GB  |
| PCI I/O                               | 0xE8000000       | 0xE800FFFF     | 64KB     |
| Reserved                              | 0xE8010000       | 0xE87FFFFF     | 8MB-64KB |
| PCI I/O                               | 0xE8800000       | 0xEBFFFFFF     | 56MB     |
| Reserved (PCI does not respond)       | 0xEC000000       | 0xEEBFFFFF     | 44MB     |
| PCI Configuration Registers           | 0xEEC00000       | 0xEEC00007     | 8B       |
| Reserved                              | 0xEEC00008       |                | 1MB8B    |
| PCI Interrupt Acknowledge (read)      | 0xEED00000       | 0xEED00003     | 4B       |
| PCI Special Cycle (write)             | 0xEED00000       | 0xEED00003     | 4B       |
| Reserved                              | 0xEED00004       | 0xEEDFFFFF     | 1MB-4B   |
| Reserved (PCI does not respond)       | 0xEEE00000       | 0xEF3FFFFF     | 6MB      |
| PCI Local Configuration Registers     | 0xEF400000       | 0xEF40003F     | 64B      |
| Reserved                              | 0xEF400040       | 0xEF5FFFFF     | 2MB-64B  |
| Internal Peripherals (Total)          | 0xEF600000       | 0xEFFFFFFF     | 10MB     |
| UART0 Registers                       | 0xEF600300       | 0xEF600307     | 8B       |
| UART1 Registers                       | 0xEF600400       | 0xEF600407     | 8B       |
| IIC Registers                         | 0xEF600500       | 0xEF600510     | 17B      |
| OPB Arbiter Registers                 | 0xEF600600       | 0xEF600601     | 2B       |
| GPIO Controller Registers             | 0xEF600700       | 0xEF60077F     | 128B     |
| Ethernet MAC Registers                | 0xEF600800       | 0xEF600867     | 104B     |
| Expansion ROM <sup>2</sup>            | 0xF0000000       | 0xFFDFFFFF     | 254MB    |
| Boot ROM <sup>2, 3</sup>              | 0xFFE00000       | 0xFFFFFFFF     | 2MB      |

#### Table 3-1. PPC405GP Address Space

1. The local memory/peripheral area of the memory map can be configured for SDRAM, ROM, or peripherals.

2. The boot ROM and expansion ROM areas of the memory map are intended for ROM or flash devices. The controller supports volatile memory devices such as SDRAM and SRAM in these areas.

3. When booting from PCI memory, the boot ROM address space begins at 0xFFFE 0000 (size is 128KB).

### 3.2.2 Storage Attributes

The PowerPC Architecture defines storage attributes that control data and instruction accesses. Storage attributes are provided to control cache write-through policy (the W storage attribute), cachability (the I storage attribute), memory coherency in multiprocessor environments (the M storage attribute), and guarding against speculative memory accesses (the G storage attribute). The IBM PowerPC Embedded Environment defines additional storage attributes for storage compression (the U0 storage attribute) and byte ordering (the E storage attribute).

The PPC405GP provides two control mechanisms for the W, I, U0, G, and E attributes. Because the PPC405GP does not provide hardware support for multiprocessor environments, the M storage attribute, when present, has no effect.

When the PPC405GP operates in virtual mode (address translation is enabled), each storage attribute is controlled by the W, I, U0, G, and E fields in the translation lookaside buffer (TLB) entry for each memory page. The size of memory pages, and hence the size of storage attribute control regions, is variable. Multiple sizes can be in effect simultaneously on different pages.

When the PPC405GP operates in real mode (address translation is disabled), storage attribute control registers control the corresponding storage attributes. These registers are:

- Data Cache Write-through Register (DCWR)
- Data Cache Cachability Register (DCCR)
- Instruction Cache Cachability Register (ICCR)
- Storage Guarded Register (SGR)
- Storage Little-Endian Register (SLER)
- Storage User-defined 0 Register (SU0R)

Each storage attribute control register contains 32 bits; each bit controls one of thirty-two 128MB storage attribute control regions. Bit 0 of each register controls the lowest-order region, with ascending bits controlling ascending regions in memory. The storage attributes in each storage attribute region are set independently of each other and of the storage attributes for other regions.

# 3.3 Registers

All PPC405GP registers are listed in this section. Some of the frequently-used registers are described in detail. Other registers are covered in their respective topic chapters (for example, the cache registers are described in Chapter 4, "Cache Operations"). All registers are summarized in Chapter 25, "Register Summary."

The registers are grouped into categories: General Purpose Registers (GPRs), Special Purpose Registers (SPRs), Time Base Registers (TBRs), the Machine State Register (MSR), the Condition Register (CR), Device Control Registers (DCRs), and memory-mapped I/O registers (MMIO). Different instructions are used to access each category of registers.

For all registers with fields marked as *reserved*, the reserved fields should be written as 0 and read as *undefined*. That is, when writing to a register with a reserved field, write a 0 to the reserved field. When reading from a register with a reserved field, ignore that field.

**Programming Note:** A good coding practice is to perform the initial write to a register with reserved fields as described, and to perform all subsequent writes to the register using a read-modify-write strategy: read the register, use logical instructions to alter defined fields, leaving reserved fields unmodified, and write the register.

Figure 3-1 on page 3-5 illustrates the registers in the user and supervisor programming models.



#### 3.3.1 General Purpose Registers (R0-R31)

The PPC405GP contains thirty-two 32-bit general purpose registers (GPRs). Data from memory can be read into GPRs using load instructions and the contents of GPRs can be written to memory using store instructions. Most integer instructions use GPRs for source and destination operands. See Table 25-1, "PPC405GP General Purpose Registers," on page 25-1 for the numbering of the GPRs.

0\_\_\_\_\_\_31

#### Figure 3-2. General Purpose Registers (R0-R31)

| 0:31 | <br>General Purpose Register data |
|------|-----------------------------------|
|      |                                   |

#### 3.3.2 Special Purpose Registers

Special purpose registers (SPRs), which are part of the PowerPC Architecture and the IBM PowerPC Embedded Environment, are accessed using the **mtspr** and **mfspr** instructions.

SPRs control the operation of debug facilities, timers, interrupts, storage control attributes, and other architected processor resources. Table 25-2, "Special Purpose Registers," on page 25-2 shows the mnemonic, name, and number for each SPR. Table 3-2, "PPC405GP SPRs," on page 3-7 lists the PPC405GP SPRs by function and indicates the pages where the SPRs are described more fully.

Except for the Link Register (LR), the Count Register (CTR), the Fixed-point Exception Register (XER), User SPR General 0 (USPRG0, and read access to SPR General 4–7 (SPRG4–SPRG7), all SPRs are privileged. As SPRs, the registers TBL and TBU are privileged write-only; as TBRs, these registers can be read in user mode. Unless used to access non-privileged SPRs, attempts to execute **mfspr** and **mtspr** instructions while in user mode cause privileged violation program interrupts. See "Privileged SPRs" on page 3-42.

| Function                  |        | Regi  | ster  |       | Access                      | Page  |
|---------------------------|--------|-------|-------|-------|-----------------------------|-------|
| Configuration             | CCR0   |       |       |       | Privileged                  | 4-11  |
| Branch Control            | CTR    |       |       | 1     | User                        | 3-7   |
| Branch Control            | LR     |       |       |       | User                        | 3-8   |
|                           | DAC1   | DAC2  |       |       | Privileged                  | 12-14 |
|                           | DBCR0  | DBCR1 | 1     |       | Privileged                  | 12-9  |
| Debug                     | DBSR   |       |       |       | Privileged                  | 12-12 |
|                           | DVC1   | DVC2  | ]     |       | Privileged                  | 12-15 |
|                           | IAC1   | IAC2  | IAC3  | IAC4  | Privileged                  | 12-14 |
|                           | ICDBDR |       |       |       | Privileged                  | 4-14  |
| Fixed-point Exception     | XER    |       |       |       | User                        | 3-8   |
|                           | SPRG0  | SPRG1 | SPRG2 | SPRG3 | Privileged                  | 3-11  |
| General-Purpose SPR       | SPRG4  | SPRG5 | SPRG6 | SPRG7 | User read, privileged write | 3-11  |
|                           | USPRG0 |       | L     | 1     | User                        | 3-11  |
|                           | DEAR   |       |       |       | Privileged                  | 10-34 |
|                           | ESR    |       |       |       | Privileged                  | 10-31 |
| Interrupts and Exceptions | EVPR   | 1     |       |       | Privileged                  | 10-31 |
|                           | SRR0   | SRR1  | ]     |       | Privileged                  | 10-29 |
|                           | SRR2   | SRR3  |       |       | Privileged                  | 10-30 |
| Processor Version         | PVR    |       |       |       | Privileged, read-only       | 3-12  |
|                           | DCCR   |       |       |       | Privileged                  | 6-17  |
|                           | DCWR   |       |       |       | Privileged                  | 6-17  |
|                           | ICCR   | 1     |       |       | Privileged                  | 6-17  |
| Storage Attribute Control | SGR    | 1     |       |       | Privileged                  | 6-17  |
|                           | SLER   |       |       |       | Privileged                  | 6-17  |
|                           | SUOR   | 1     |       |       | Privileged                  | 6-17  |
|                           | TBL    | TBU   |       |       | Privileged, write-only      | 11-2  |
| Timer Facilities          | PIT    |       | -     |       | Privileged                  | 11-2  |
| Timer Facilities          | TCR    |       |       |       | Privileged                  | 11-9  |
|                           | TSR    |       |       |       | Privileged                  | 11-8  |
| Zone Protection           | ZPR    |       |       |       | Privileged                  | 6-13  |

#### Table 3-2. PPC405GP SPRs

#### 3.3.2.1 Count Register (CTR)

The CTR is written from a GPR using **mtspr**. The CTR contents can be used as a loop count that is decremented and tested by some branch instructions. Alternatively, the CTR contents can specify a target address for the **bcctr** instruction, enabling branching to any address.

The CTR is in the user programming model.

| Figure 3-3. | Count Register ( | (CTR) |
|-------------|------------------|-------|
|-------------|------------------|-------|

| 0:31 | Count | Used as count for branch conditional with |
|------|-------|-------------------------------------------|
|      |       | decrement instructions, or as address for |
|      |       | branch-to-counter instructions.           |

#### 3.3.2.2 Link Register (LR)

The LR is written from a GPR using **mtspr**, and by branch instructions that have the LK bit set to 1. Such branch instructions load the LR with the address of the instruction following the branch instruction. Thus, the LR contents can be used as the return address for a subroutine that was called using the branch.

The LR contents can be used as a target address for the bclr instruction. This allows branching to any address.

When the LR contents represent an instruction address, LR<sub>30:31</sub> are assumed to be 0, because all instructions must be word-aligned. However, when LR is read using mfspr, all 32 bits are returned as written.

The LR is in the user programming model.

Figure 3-4. Link Register (LR)

| 0:31 | Link Register contents | If (LR) represents an instruction address, |
|------|------------------------|--------------------------------------------|
|      |                        | LR <sub>30:31</sub> should be 0.           |
|      |                        |                                            |

#### 3.3.2.3 Fixed Point Exception Register (XER)

The XER records overflow and carry conditions generated by integer arithmetic instructions.

The Summary Overflow (SO) field is set to 1 when instructions cause the Overflow (OV) field to be set to 1. The SO field does not necessarily indicate that an overflow occurred on the most recent

0

31

arithmetic operation, but that an overflow occurred since the last clearing of XER[SO]. **mtspr**(XER) sets XER[SO, OV] to the value of bit positions 0 and 1 in the source register, respectively.

Once set, XER[SO] is not reset until an **mtspr**(XER) is executed with data that explicitly puts a 0 in the SO bit, or until an **mcrxr** instruction is executed.

XER[OV] is set to indicate whether an instruction that updates XER[OV] produces a result that "overflows" the 32-bit target register. XER[OV] = 1 indicates overflow. For arithmetic operations, this occurs when an operation has a carry-in to the most-significant bit of the result that does not equal the carry-out of the most-significant bit (that is, the exclusive-or of the carry-in and the carry-out is 1).

The following instructions set XER[OV] differently. The specific behavior is indicated in the instruction descriptions in Chapter 24, "Instruction Set."

• Move instructions:

mcrxr, mtspr(XER)

Multiply and divide instructions:

#### mullwo, mullwo., divwo, divwo., divwuo, divwuo

The Carry (CA) field is set to indicate whether an instruction that updates XER[CA] produces a result that has a carry-out of the most-significant bit. XER[CA] = 1 indicates a carry.

The following instructions set XER[CA] differently. The specific behavior is indicated in the instruction descriptions in Chapter 24, "Instruction Set."

Move instructions

mcrxr, mtspr(XER)

Shift-algebraic operations

#### sraw, srawi

The Transfer Byte Count (TBC) field is the byte count for load/store string instructions.

The XER is part of the user programming model.



| 0     | SO  | Summary Overflow<br>0 No overflow has occurred.<br>1 Overflow has occurred. | Can be <i>set</i> by <b>mtspr</b> or by using "o" form instructions; can be <i>reset</i> by <b>mtspr</b> or by <b>mcrxr</b> .                                                                                      |
|-------|-----|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | ov  | Overflow<br>0 No overflow has occurred.<br>0 Overflow has occurred.         | Can be <i>set</i> by <b>mtspr</b> or by using "o" form<br>instructions; can be <i>reset</i> by <b>mtspr</b> , by<br><b>mcrxr</b> , or "o" form instructions.                                                       |
| 2     | CA  | Carry<br>0 Carry has not occurred.<br>1 Carry has occurred.                 | Can be <i>set</i> by <b>mtspr</b> or arithmetic<br>instructions that update the CA field; can<br>be <i>reset</i> by <b>mtspr</b> , by <b>mcrxr</b> , or by<br>arithmetic instructions that update the CA<br>field. |
| 3:24  |     | Reserved                                                                    |                                                                                                                                                                                                                    |
| 25:31 | TBC | Transfer Byte Count                                                         | Used by Iswx and stswx; written by mtspr.                                                                                                                                                                          |

Figure 3-5. Fixed Point Exception Register (XER)

Table 3-3 and Table 3-4 list the PPC405GP instructions that update the XER. In the tables, the syntax "[o]" indicates that the instruction has an "o" form that updates XER[SO,OV], and a "non-o" form. The syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0] (see "Condition Register (CR)" on page 3-12), and a "non-record" form.

| Table 3-3. XER[CA] | Updating | Instructions |
|--------------------|----------|--------------|
|--------------------|----------|--------------|

| Integer Arithmetic                                                 |                                                                      | Integer<br>Shift            | Processor<br>Control   |
|--------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------|------------------------|
| Add                                                                | Subtract                                                             | Shift<br>Right<br>Algebraic | Register<br>Management |
| addc[o][.]<br>adde[o][.]<br>addic[.]<br>addme[o][.]<br>addze[o][.] | subfc[o][.]<br>subfe[o][.]<br>subfic<br>subfme[o][.]<br>subfze[o][.] | sraw[.]<br>srawi[.]         | mtspr<br>mcrxr         |

|                                                           | Integer Arithmetic                                             |           |                       |         | Auxiliary                                                                                                                                            | Processor                                                                  | Processor<br>Control   |
|-----------------------------------------------------------|----------------------------------------------------------------|-----------|-----------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------|
| Add                                                       | Subtract                                                       | Multiply  | Divide                | Negate  | Multiply-<br>Accumulate                                                                                                                              | Negative<br>Multiply-<br>Accumulate                                        | Register<br>Management |
| addo[.]<br>addco[.]<br>addeo[.]<br>addmeo[.]<br>addzeo[.] | subfo[.]<br>subfco[.]<br>subfeo[.]<br>subfmeo[.]<br>subfzeo[.] | mullwo[.] | divwo[.]<br>divwuo[.] | nego[.] | macchwo[.]<br>macchwso[.]<br>macchwsuo[.]<br>machhwo[.]<br>machhwso[.]<br>machhwsuo[.]<br>machhwuo[.]<br>maclhwso[.]<br>maclhwsuo[.]<br>maclhwsuo[.] | nmacchwo[.]<br>nmacchwso[.]<br>nmachhwo[.]<br>nmachhwso[.]<br>nmaclhwso[.] | mtspr<br>mcrxr         |

#### Table 3-4. XER[SO,OV] Updating Instructions

#### 3.3.2.4 Special Purpose Register General (SPRG0–SPRG7)

USPRG0 and SPRG0–SPRG7 are provided for general purpose software use. For example, these registers are used as temporary storage locations. For example, an interrupt handler might save the contents of a GPR to an SPRG, and later restore the GPR from it. This is faster than a save/restore to a memory location. These registers are written using **mtspr** and read using **mfspr**.

Access to USPRG0 is non-privileged for both read and write.

SPRG0–SPRG7 provide temporary storage locations. For example, an interrupt handler might save the contents of a GPR to an SPRG, and later restore the GPR from it. This is faster than performing a save/restore to memory. These registers are written by **mtspr** and read by **mfspr**.

Access to SPRG0–SPRG7 is privileged, except for read access to SPRG4–SPRG7. See "Privileged SPRs" on page 3-42 for more information.

#### Figure 3-6. Special Purpose Register General (SPRG0–SPRG7)

| 0:31 | General data | Software value; no hardware usage. |
|------|--------------|------------------------------------|
|      |              |                                    |

31

### 3.3.2.5 Processor Version Register (PVR)

The PVR is a read-only register that uniquely identifies a standard product or Core+ASIC implementation. Software can examine the PVR to recognize implementation-dependent features and determine available hardware resources.

Access to the PVR is privileged. See "Privileged SPRs" on page 3-42 for more information.

| 0 31 |   |    |
|------|---|----|
|      | 0 | 31 |
|      |   |    |

Figure 3-7. Processor Version Register (PVR)

| 0:31 | Assigned PVR value |  |
|------|--------------------|--|

#### 3.3.3 Condition Register (CR)

The CR contains eight 4-bit fields (CR0–CR7), as shown in Figure 3-8. The fields contain conditions detected during the execution of integer or logical compare instructions, as indicated in the instruction descriptions in Chapter 24, "Instruction Set." The CR contents can be used in conditional branch instructions.

The CR can be modified in any of the following ways:

- mtcrf sets specified CR fields by writing to the CR from a GPR, under control of a mask specified as an instruction field.
- mcrf sets a specified CR field by copying another CR field to it.
- mcrxr copies certain bits of the XER into a designated CR field, and then clears the corresponding XER bits.
- The "with update" forms of integer instructions implicitly update CR[CR0].
- Integer compare instructions update a specified CR field.
- The CR-logical instructions update a specified CR bit with the result of a logical operation on a specified pair of CR bit fields.
- Conditional branch instructions can test a CR bit as one of the branch conditions.

If a CR field is set by a compare instruction, the bits are set as described in "CR Fields after Compare Instructions."

The CR is part of the user programming model.



Figure 3-8. Condition Register (CR)

| 0:3   | CR0 | Condition Register Field 0 |
|-------|-----|----------------------------|
| 4:7   | CR1 | Condition Register Field 1 |
| 8:11  | CR2 | Condition Register Field 2 |
| 12:15 | CR3 | Condition Register Field 3 |
| 16:19 | CR4 | Condition Register Field 4 |
| 20:23 | CR5 | Condition Register Field 5 |
| 24:27 | CR6 | Condition Register Field 6 |
| 28:31 | CR7 | Condition Register Field 7 |

### 3.3.3.1 CR Fields after Compare Instructions

Compare instructions compare the values of two 32-bit registers. The two types of compare instructions, *arithmetic* and *logical*, are distinguished by the interpretation given to the 32-bit values. For *arithmetic* compares, the values are considered to be signed, where 31 bits represent the magnitude and the most-significant bit is a sign bit. For *logical* compares, the values are considered to be unsigned, so all 32 bits represent magnitude. There is no sign bit. As an example, consider the comparison of 0 with 0xFFFF FFFF. In an *arithmetic* compare, 0 is larger, because 0xFFFF FFFF represents –1; in a *logical* compare, 0xFFFF FFFF is larger.

A compare instruction can direct its CR update to any CR field. The first data operand of a compare instruction specifies a GPR. The second data operand specifies another GPR, or immediate data derived from the IM field of the immediate instruction form. The contents of the GPR specified by the first data operand are compared with the contents of the GPR specified by the second data operand (or with the immediate data). See descriptions of the compare instructions (page 24-34 through page 24-37) for precise details.

After a compare, the specified CR field is interpreted as follows:

- LT (bit 0) The first operand is less than the second operand.
- GT (bit 1) The first operand is greater than the second operand.
- EQ (bit 2) The first operand is equal to the second operand.
- SO (bit 3) Summary overflow; a copy of XER[SO].

### 3.3.3.2 The CR0 Field

After the execution of compare instructions that update CR[CR0], CR[CR0] is interpreted as described in "CR Fields after Compare Instructions" on page 3-13. The "dot" forms of arithmetic and logical instructions also alter CR[CR0]. After most instructions that update CR[CR0], the bits of CR0 are interpreted as follows:

| LT (bit 0) | Less than 0; set if the most-significant bit of the 32-bit result is 1.                                   |
|------------|-----------------------------------------------------------------------------------------------------------|
| GT (bit 1) | Greater than 0; set if the 32-bit result is non-zero and the most-<br>significant bit of the result is 0. |
| EQ (bit 2) | Equal to 0; set if the 32-bit result is 0.                                                                |
| SO (bit 3) | Summary overflow; a copy of XER[SO] at instruction completion.                                            |

The CR[CR0]<sub>LT, GT, EQ</sub> subfields are set as the result of an algebraic comparison of the instruction result to 0, regardless of the type of instruction that sets CR[CR0]. If the instruction result is 0, the EQ subfield is set to 1. If the result is not 0, either LT or GT is set, depending on the value of the most-significant bit of the result.

When updating CR[CR0], the most significant bit of an instruction result is considered a sign bit, even for instructions that produce results that are not usually thought of as signed. For example, logical instructions such as **and.**, **or.**, and **nor.** update CR[CR0]<sub>LT, GT, EQ</sub> using such an arithmetic comparison to 0, although the result of such a logical operation is not actually an arithmetic result.

If an arithmetic overflow occurs, the "sign" of an instruction result indicated in  $CR[CR0]_{LT, GT, EQ}$  might not represent the "true" (infinitely precise) algebraic result of the instruction that set CR0. For example, if an **add**. instruction adds two large positive numbers and the magnitude of the result cannot be represented as a twos-complement number in a 32-bit register, an overflow occurs and  $CR[CR0]_{LT, SQ}$  are set, although the infinitely precise result of the add is positive.

Adding the largest 32-bit twos-complement negative number, 0x8000 0000, to itself results in an arithmetic overflow and 0x0000 0000 is recorded in the target register.  $CR[CR0]_{EQ, SO}$  is set, indicating a result of 0, but the infinitely precise result is negative.

The CR[CR0]<sub>SO</sub> subfield is a copy of XER[SO]. Instructions that do not alter the XER[SO] bit cannot cause an overflow, but even for these instructions  $CR[CR0]_{SO}$  is a copy of XER[SO].

Some instructions set CR[CR0] differently or do not specifically set any of the subfields. These instructions include:

Compare instructions

cmp, cmpi, cmpl, cmpli

CR logical instructions

crand, crandc, creqv, crnand, crnor, cror, crorc, crxor, mcrf

• Move CR instructions

mtcrf, mcrxr

stwcx.

The instruction descriptions provide detailed information about how the listed instructions alter CR[CR0].

#### 3.3.4 The Time Base

The PowerPC Architecture provides a 64-bit time base. "Time Base" on page 11-2 describes the architected time base. Access to the time base is through two 32-bit time base registers (TBRs). The least-significant 32 bits of the time base are read from the Time Base Lower (TBL) register and the most-significant 32 bits are read from the Time Base Upper (TBU) register.

User-mode access to the time base is read-only, and there is no explicitly privileged read access to the time base.

The **mftb** instruction reads from TBL and TBU. Writing the time base is accomplished by moving the contents of a GPR to a pair of SPRs, which are also called TBL and TBU, using **mtspr**.

Table 3-5 shows the mnemonics and names of the TBRs.

| Mnemonic | Register Name               | Access    |
|----------|-----------------------------|-----------|
| TBL      | Time Base Lower (Read-only) | Read-only |
| TBU      | Time Base Upper (Read-only) | Read-only |

Table 3-5. Time Base Registers

#### 3.3.5 Machine State Register (MSR)

The Machine State Register (MSR) controls processor core functions, such as the enabling or disabling of interrupts and address translation.

The MSR is written from a GPR using the **mtmsr** instruction. The contents of the MSR can be read into a GPR using the **mfmsr** instruction. MSR[EE] is set or cleared using the **wrtee** or **wrteei** instructions.

The MSR contents are automatically saved, altered, and restored by the interrupt-handling mechanism. See "Machine State Register (MSR)" on page 10-28.



| Figure 3-9. | Machine Stat | e Register (MSR) |
|-------------|--------------|------------------|
|-------------|--------------|------------------|

| 0:12 |    | Reserved                                                                                                |                                                                                                                                                    |
|------|----|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | WE | Wait State Enable<br>0 The processor is not in the wait state.<br>1 The processor is in the wait state. | If MSR[WE] = 1, the processor remains in<br>the wait state until an interrupt is taken, a<br>reset occurs, or an external debug tool<br>clears WE. |
| 14   | CE | Critical Interrupt Enable<br>0 Critical interrupts are disabled.<br>1 Critical interrupts are enabled.  | Controls the critical interrupt input and watchdog timer first time-out interrupts.                                                                |
| 15   |    | Reserved                                                                                                |                                                                                                                                                    |

| 16    | EE  | <ul> <li>External Interrupt Enable</li> <li>O Asynchronous interrupts (external to the processor core) are disabled.</li> <li>1 Asynchronous interrupts are enabled.</li> </ul> | Controls the non-critical external interrupt input, PIT, and FIT interrupts. |
|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 17    | PR  | <ul> <li>Problem State</li> <li>0 Supervisor state (all instructions<br/>allowed).</li> <li>1 Problem state (some instructions not<br/>allowed).</li> </ul>                     |                                                                              |
| 18    |     | Reserved                                                                                                                                                                        |                                                                              |
| 19    | ME  | Machine Check Enable<br>0 Machine check interrupts are disabled.<br>1 Machine check interrupts are enabled.                                                                     |                                                                              |
| 20    |     | Reserved                                                                                                                                                                        |                                                                              |
| 21    | DWE | Debug Wait Enable<br>0 Debug wait mode is disabled.<br>1 Debug wait mode is enabled.                                                                                            |                                                                              |
| 22    | DE  | Debug Interrupts Enable<br>0 Debug interrupts are disabled.<br>1 Debug interrupts are enabled.                                                                                  |                                                                              |
| 23:25 |     | Reserved                                                                                                                                                                        |                                                                              |
| 26    | IR  | Instruction Relocate<br>0 Instruction address translation is<br>disabled.<br>1 Instruction address translation is<br>enabled.                                                   |                                                                              |
| 27    | DR  | Data Relocate<br>0 Data address translation is disabled.<br>1 Data address translation is enabled.                                                                              |                                                                              |
| 28:31 |     | Reserved                                                                                                                                                                        |                                                                              |

# 3.3.6 Device Control Registers

Device Control Registers (DCRs), on-chip registers that exist architecturally outside the processor core, are not part of the IBM PowerPC Embedded Environment. The Embedded Environment simply defines the existence of a DCR address space and the instructions that access the DCRs, but does not define any DCRs. The instructions that access the DCRs are **mtdcr** (move to device control register) and **mfdcr** (move from device control register).

DCRs are used to control the operations of on-chip buses, peripherals, and some processor behavior.

# 3.3.6.1 Directly Accessed DCRs

The following DCRs are directly accessed; that is, they are accessed using their DCR numbers.

| Register                | DCR<br>Number  | Access      | Description                                            |
|-------------------------|----------------|-------------|--------------------------------------------------------|
| DCRs Used for Indirect  |                | Access      | ·                                                      |
| SDRAM0 CFGADDR          | 0x010          | R/W         | Memory Controller Address Register                     |
| SDRAM0_CFGDATA          | 0x011          | B/W         | Memory Controller Data Register                        |
| EBC0 CFGADDR            | 0x012          | B/W         | Peripheral Controller Address Register                 |
| EBC0_CFGDATA            | 0x013          | B/W         | Peripheral Controller Data Register                    |
| DCP0 CFGADDR            | 0x014          | B/W         | Decompression Controller Address Register              |
| DCP0_CFGDATA            | 0x015          | R/W         | Decompression Controller Data Register                 |
| On-Chip Memory          |                |             |                                                        |
| OCM0_ISARC              | 0x018          | R/W         | OCM Instruction-Side Address Range Compare<br>Register |
| OCM0_ISCNTL             | 0x019          | R/W         | OCM Instruction-Side Control Register                  |
| OCM0_DSARC              | 0x01A          | R/W         | OCM Data-Side Address Range Compare Register           |
| OCM0_DSCNTL             | 0x01B          | R/W         | OCM Data-Side Control Register                         |
| On-Chip Buses           | I              | <b>I</b>    |                                                        |
| PLB0_BESR               | 0x084          | R/Clear     | PLB Bus Error Status Register                          |
| PLB0_BEAR               | 0x086          | R/W         | PLB Bus Error Address Register                         |
| PLB0_ACR                | 0x087          | R/W         | PLB Arbiter Control Register                           |
| POB0_BESR0              | 0x0A0          | R/Clear     | PLB to OPB Bus Error Status Register 0                 |
| POB0_BEAR               | 0x0A2          | R           | PLB to OPB Bus Error Address Register                  |
| POB0_BESR1              | 0x0A4          | R/Clear     | PLB to OPB Bus Error Status Register 1                 |
| Clocking, Power Manag   | gement, and Ch | nip Control | ·•• · ·                                                |
| CPC0_PLLMR              | 0x0B0          | R/W         | PLL Mode Register                                      |
| CPC0_CR0                | 0x0B1          | R/W         | Chip Control Register 0                                |
| CPC0_CR1                | 0x0B2          | R/W         | Chip Control Register 1                                |
| CPC0_PSR                | 0x0B4          | R           | Chip Pin Strapping Register                            |
| CPC0_JTAGID             | 0x0B5          | R           | JTAG ID Register                                       |
| CPC0_SR                 | 0x0B8          | R           | CPM Status Register                                    |
| CPC0_ER                 | 0x0B9          | R/W         | CPM Enable Register                                    |
| CPC0_FR                 | 0x0BA          | R/W         | CPM Force Register                                     |
| Universal Interrupt Con | troller        |             |                                                        |
| UIC0_SR                 | 0x0C0          | R/Clear     | UIC Status Register                                    |
| UIC0_ER                 | 0x0C2          | R/W         | UIC Enable Register                                    |
| UIC0_CR                 | 0x0C3          | R/W         | UIC Critical Register                                  |
| UIC0_PR                 | 0x0C4          | R/W         | UIC Polarity Register                                  |
| UIC0_TR                 | 0x0C5          | R/W         | UIC Triggering Register                                |
| UIC0_MSR                | 0x0C6          | R           | UIC Masked Status Register                             |
| UIC0_VR                 | 0x0C7          | R           | UIC Vector Register                                    |
| UIC0_VCR                | 0x0C8          | W           | UIC Vector Configuration Register                      |

#### Table 3-6. Directly Accessed DCRs

| Register             | DCR<br>Number | Access  | Description                                      |  |  |
|----------------------|---------------|---------|--------------------------------------------------|--|--|
| Direct Memory Access |               |         |                                                  |  |  |
| DMA0_CR0             | 0x100         | R/W     | DMA Channel Control Register 0                   |  |  |
| DMA0_CT0             | 0x101         | R/W     | DMA Count Register 0                             |  |  |
| DMA0_DA0             | 0x102         | R/W     | DMA Destination Address Register 0               |  |  |
| DMA0_SA0             | 0x103         | R/W     | DMA Source Address Register 0                    |  |  |
| DMA0_SG0             | 0x104         | R/W     | DMA Scatter/Gather Descriptor Address Register 0 |  |  |
| DMA0_CR1             | 0x108         | R/W     | DMA Channel Control Register 1                   |  |  |
| DMA0_CT1             | 0x109         | R/W     | DMA Count Register 1                             |  |  |
| DMA0_DA1             | 0x10A         | R/W     | DMA Destination Address Register 1               |  |  |
| DMA0_SA1             | 0x10B         | R/W     | DMA Source Address Register 1                    |  |  |
| DMA0_SG1             | 0x10C         | R/W     | DMA Scatter/Gather Descriptor Address Register 1 |  |  |
| DMA0_CR2             | 0x110         | R/W     | DMA Channel Control Register 2                   |  |  |
| DMA0_CT2             | 0x111         | R/W     | DMA Count Register 2                             |  |  |
| DMA0_DA2             | 0x112         | R/W     | DMA Destination Address Register 2               |  |  |
| DMA0_SA2             | 0x113         | R/W     | DMA Source Address Register 2                    |  |  |
| DMA0_SG2             | 0x114         | R/W     | DMA Scatter/Gather Descriptor Address Register 2 |  |  |
| DMA0_CR3             | 0x118         | R/W     | DMA Channel Control Register 3                   |  |  |
| DMA0_CT3             | 0x119         | R/W     | DMA Count Register 3                             |  |  |
| DMA0_DA3             | 0x11A         | R/W     | DMA Destination Address Register 3               |  |  |
| DMA0_SA3             | 0x11B         | R/W     | DMA Source Address Register 3                    |  |  |
| DMA0_SG3             | 0x11C         | R/W     | DMA Scatter/Gather Descriptor Address            |  |  |
| DMA0_SR              | 0x120         | R/Clear | DMA Status Register                              |  |  |
| DMA0_SGC             | 0x123         | R/W     | DMA Scatter/Gather Command Register              |  |  |
| DMA0_SLP             | 0x125         | R/W     | DMA Sleep Mode Register                          |  |  |
| DMA0_POL             | 0x126         | R/W     | DMA Polarity Configuration Register              |  |  |
| Media Access Layer   |               |         |                                                  |  |  |
| MAL0_CFG             | 0x180         | R/W     | MAL Configuration Register                       |  |  |
| MAL0_ESR             | 0x181         | R/Clear | Error Status Register                            |  |  |
| MALO_IER             | 0x182         | R/W     | Interrupt Enable Register                        |  |  |
| MAL0_TXCASR          | 0x184         | R/W     | Tx Channel Active Register (Set)                 |  |  |
| MAL0_TXCARR          | 0x185         | R/W     | Tx Channel Active Register (Reset)               |  |  |
| MAL0_TXEOBISR        | 0x186         | R/Clear | Tx End of Buffer Interrupt Status Register       |  |  |
| MAL0_TXDEIR          | 0x187         | R/Clear | Tx Descriptor Error Interrupt Register           |  |  |
| MAL0_RXCASR          | 0x190         | R/W     | Rx Channel Active Register (Set)                 |  |  |
| MAL0_RXCARR          | 0x191         | R/W     | Rx Channel Active Register (Reset)               |  |  |
| MAL0_RXEOBISR        | 0x192         | R/Clear | Rx End of Buffer Interrupt Status Register       |  |  |
| MAL0_RXDEIR          | 0x193         | R/Clear | Rx Descriptor Error Interrupt Register           |  |  |
| MAL0_TXCTP0R         | 0x1A0         | R/W     | Channel Tx 0 Channel Table Pointer Register      |  |  |
| MAL0_TXCTP1R         | 0x1A1         | R/W     | Channel Tx 1 Channel Table Pointer Register      |  |  |
| MAL0_RXCTP0R         | 0x1C0         | R/W     | Channel Rx 0 Channel Table Pointer Register      |  |  |
| MALO_RCBS0           | 0x1E0         | R/W     | Channel RX 0 Channel Buffer Size Register        |  |  |

# Table 3-6. Directly Accessed DCRs (continued)

#### 3.3.6.2 Indirectly Accessed DCRs

The DCRs for the SDRAM controller, external bus controller (EBC), and decompression controller are indirectly accessed.

#### 3.3.7 Indirect Access of SDRAM Controller DCRs

The following procedure accesses the SDRAM controller DCRs listed in Table 3-7.

1. Write the offset from Table 3-8 to the Memory Controller Address Register (SDRAM0\_CFGADDR).

2. Read data from or write data to the Memory Controller Data Register (SDRAM0\_CFGDATA).

| Register       | DCR<br>Number | Access | Description                        |
|----------------|---------------|--------|------------------------------------|
| SDRAM0_CFGADDR | 0x010         | R/W    | Memory Controller Address Register |
| SDRAM0_CFGDATA | 0x011         | R/W    | Memory Controller Data Register    |

| Table 3-7. SDRAM Controller | DCR | Usage |
|-----------------------------|-----|-------|
|-----------------------------|-----|-------|

| Register      | Offset | R/W     | Description                          |
|---------------|--------|---------|--------------------------------------|
| SDRAM0_BESR0  | 0x00   | R/Clear | Bus Error Syndrome Register 0        |
| SDRAM0_BESR1  | 0x08   | R/Clear | Bus Error Syndrome Register 1        |
| SDRAM0_BEAR   | 0x10   | R/W     | Bus Error Address Register           |
| SDRAM0_CFG    | 0x20   | R/W     | Memory Controller Options 1          |
| SDRAM0_RTR    | 0x30   | R/W     | Refresh Timer Register               |
| SDRAM0_PMIT   | 0x34   | R/W     | Power Management Idle Timer          |
| SDRAM0_B0CR   | 0x40   | R/W     | Memory Bank 0 Configuration Register |
| SDRAM0_B1CR   | 0x44   | R/W     | Memory Bank 1 Configuration Register |
| SDRAM0_B2CR   | 0x48   | R/W     | Memory Bank 2 Configuration Register |
| SDRAM0_B3CR   | 0x4C   | R/W     | Memory Bank 3 Configuration Register |
| SDRAM0_TR     | 0x80   | R/W     | SDRAM Timing Register 1              |
| SDRAM0_ECCCFG | 0x94   | R/W     | ECC Configuration                    |
| SDRAM0_ECCESR | 0x98   | R       | ECC Error Status Register            |

#### Table 3-8. Offsets for SDRAM Controller Registers

### 3.3.8 Indirect Access of External Bus Controller DCRs

The following procedure accesses the EBC DCRs listed in Table 3-9.

1. Write the offset from Table 3-10 to the Peripheral Controller Address Register (EBC0\_CFGADDR).

2. Read data from or write data to the Peripheral Controller Data Register (EBC0\_CFGDATA).

| Register     | DCR<br>Number | Access | Description                            |
|--------------|---------------|--------|----------------------------------------|
| EBC0_CFGADDR | 0x012         | R/W    | Peripheral Controller Address Register |
| EBC0_CFGDATA | 0x013         | R/W    | Peripheral Controller Data Register    |

#### Table 3-9. External Bus Controller DCR Usage

# Table 3-10. Offsets for External Bus Controller Registers

| Register   | Offset | Access | Description                              |
|------------|--------|--------|------------------------------------------|
| EBC0_B0CR  | 0x00   | R/W    | Peripheral Bank 0 Configuration Register |
| EBC0_B1CR  | 0x01   | R/W    | Peripheral Bank 1 Configuration Register |
| EBC0_B2CR  | 0x02   | R/W    | Peripheral Bank 2 Configuration Register |
| EBC0_B3CR  | 0x03   | R/W    | Peripheral Bank 3 Configuration Register |
| EBC0_B4CR  | 0x04   | R/W    | Peripheral Bank 4 Configuration Register |
| EBC0_B5CR  | 0x05   | R/W    | Peripheral Bank 5 Configuration Register |
| EBC0_B6CR  | 0x06   | R/W    | Peripheral Bank 6 Configuration Register |
| EBC0_B7CR  | 0x07   | R/W    | Peripheral Bank 7 Configuration Register |
| EBC0_B0AP  | 0x10   | R/W    | Peripheral Bank 0 Access Parameters      |
| EBC0_B1AP  | 0x11   | R/W    | Peripheral Bank 1 Access Parameters      |
| EBC0_B2AP  | 0x12   | R/W    | Peripheral Bank 2 Access Parameters      |
| EBC0_B3AP  | 0x13   | R/W    | Peripheral Bank 3 Access Parameters      |
| EBC0_B4AP  | 0x14   | R/W    | Peripheral Bank 4 Access Parameters      |
| EBC0_B5AP  | 0x15   | R/W    | Peripheral Bank 5 Access Parameters      |
| EBC0_B6AP  | 0x16   | R/W    | Peripheral Bank 6 Access Parameters      |
| EBC0_B7AP  | 0x17   | R/W    | Peripheral Bank 7 Access Parameters      |
| EBC0_BEAR  | 0x20   | R/W    | Peripheral Bus Error Address Register    |
| EBC0_BESR0 | 0x21   | R/W    | Peripheral Bus Error Status Register 0   |
| EBC0_BESR1 | 0x22   | R/W    | Peripheral Bus Error Status Register 1   |
| EBC0_CFG   | 0x23   | R/W    | External Peripheral Control Register     |

#### 3.3.9 Indirect Access of Decompression Controller DCRs

The following procedure accesses the decompression controller DCRs listed in Table 3-11.

- 1. Write the offset from Table 3-12 to the Decompression Controller Address Register (DCP0\_CFGADDR).
- 2. Read data from or write data to the Decompression Controller Data Register (DCP0\_CFGDATA).

| Register     | DCR<br>Number | Access | Description                               |
|--------------|---------------|--------|-------------------------------------------|
| DCP0_CFGADDR | 0x014         | R/W    | Decompression Controller Address Register |
| DCP0_CFGDATA | 0x015         | R/W    | Decompression Controller Data Register    |

 Table 3-11. Decompression Controller DCR Usage

#### Table 3-12. Offsets for Decompression Controller Registers

| Register                 | Offset      | R/W     | Description                                         |
|--------------------------|-------------|---------|-----------------------------------------------------|
| DCP0_ITOR0               | 0x00        | R/W     | Index Table Origin Register 0                       |
| DCP0_ITOR1               | 0x01        | R/W     | Index Table Origin Register 1                       |
| DCP0_ITOR2               | 0x02        | R/W     | Index Table Origin Register 2                       |
| DCP0_ITOR3               | 0x03        | R/W     | Index Table Origin Register 3                       |
| DCP0_ADDR0               | 0x04        | R/W     | Address Decode Definition Register 0                |
| DCP0_ADDR1               | 0x05        | R/W     | Address Decode Definition Register 1                |
| DCP0_CFG                 | 0x40        | R/W     | Decompression Controller Configuration Register     |
| DCP0_ID                  | 0x41        | R       | Decompression Controller ID Register                |
| DCP0_VER                 | 0x42        | R       | Decompression Controller Version Number<br>Register |
| DCP0_PLBBEAR             | 0x50        | R       | Bus Error Address Register (PLB address)            |
| DCP0_MEMBEAR             | 0x51        | R       | Bus Error Address Register (DCP to EBC address)     |
| DCP0_ESR                 | 0x52        | R/Clear | Bus Error Status Register 0 (masters 0-3)           |
| DCP0_RAM0<br>DCP0_RAM3FF | 0x400-0x7FF | R/W     | Decode Tables                                       |

# 3.3.10 Memory-Mapped Input/Output Registers

Some registers associated with on-chip peripherals are memory-mapped input/output (MMIO) registers. Such registers are mapped into the system memory space and are accessed using load/store instructions.

### 3.3.10.1 Directly Accessed MMIO Registers

Directly-accessed MMIO registers are accessed using load/store instructions that contain the register addresses. Table 3-13 lists the directly-accessed MMIO registers.

| Register                                | Address    | Access | Description                                                                     |  |  |
|-----------------------------------------|------------|--------|---------------------------------------------------------------------------------|--|--|
| MMIO Registers Used for Indirect Access |            |        |                                                                                 |  |  |
| PCIC0_CFGADDR                           | 0xEEC00000 | R/W    | PCI Configuration Address Register                                              |  |  |
| PCIC0_CFGDATA                           | 0xEEC00004 | R/W    | PCI Configuration Data Register                                                 |  |  |
| PCI-to-PLB Bridge                       | _1         |        |                                                                                 |  |  |
| PCILO_PMM0LA                            | 0xEF400000 | R/W    | PMM 0 Local Address                                                             |  |  |
| PCILO_PMM0MA                            | 0xEF400004 | R/W    | PMM 0 Mask/Attribute                                                            |  |  |
| PCIL0_PMM0PCILA                         | 0xEF400008 | R/W    | PMM 0 PCI Low Address                                                           |  |  |
| PCIL0_PMM0PCIHA                         | 0xEF40000C | R/W    | PMM 0 PCI High Address                                                          |  |  |
| PCIL0_PMM1LA                            | 0xEF400010 | R/W    | PMM 1 Local Address                                                             |  |  |
| PCIL0_PMM1MA                            | 0xEF400014 | R/W    | PMM 1 Mask/Attribute                                                            |  |  |
| PCIL0_PMM1PCILA                         | 0xEF400018 | R/W    | PMM 1 PCI Low Address                                                           |  |  |
| PCIL0_PMM1PCIHA                         | 0xEF40001C | R/W    | PMM 1 PCI High Address                                                          |  |  |
| PCIL0_PMM2LA                            | 0xEF400020 | R/W    | PMM 2 Local Address                                                             |  |  |
| PCIL0_PMM2MA                            | 0xEF400024 | R/W    | PMM 2 Mask/Attribute                                                            |  |  |
| PCIL0_PMM2PCILA                         | 0xEF400028 | R/W    | PMM 2 PCI Low Address                                                           |  |  |
| PCIL0_PMM2PCIHA                         | 0xEF40002C | R/W    | PMM 2 PCI High Address                                                          |  |  |
| PCIL0_PTM1MS                            | 0xEF400030 | R/W    | PTM 1 Memory Size                                                               |  |  |
| PCIL0_PTM1LA                            | 0xEF400034 | R/W    | PTM 1 Local Address                                                             |  |  |
| PCIL0_PTM2MS                            | 0xEF400038 | R/W    | PTM 2 Memory Size                                                               |  |  |
| PCIL0_PTM2LA                            | 0xEF40003C | R/W    | PTM 2 Local Address                                                             |  |  |
| Serial Ports                            |            |        |                                                                                 |  |  |
| UART0_RBR                               | 0xEF600300 | R      | UART 0 Receiver Buffer Register<br>Note: Set UART0_LCR[DLAB] = 0 to access.     |  |  |
| UART0_THR                               | -          | W      | UART 0 Transmitter Holding Register<br>Note: Set UART0_LCR[DLAB] = 0 to access. |  |  |
| UART0_DLL                               |            | R/W    | UART 0 Baud-rate Divisor Latch LSB<br>Note: Set UART0_LCR[DLAB] = 1 to access.  |  |  |
| UART0_IER                               | 0xEF600301 | R/W    | UART 0 Interrupt Enable Register<br>Note: Set UART0_LCR[DLAB] = 0 to access.    |  |  |
| UART0_DLM                               |            | R/W    | UART 0 Baud-rate Divisor Latch MSB<br>Note: Set UART0_LCR[DLAB] = 1 to access.  |  |  |
| UART0_IIR                               | 0xEF600302 | R      | UART 0 Interrupt Identification Register                                        |  |  |
| UART0_FCR                               | 0xEF600302 | W      | UART 0 FIFO Control Register                                                    |  |  |
| UART0_LCR                               | 0xEF600303 | R/W    | UART 0 Line Control Register                                                    |  |  |

Table 3-13. Directly Accessed MMIO Registers

| Register                              | Address    | Access  | Description                                                                     |  |  |
|---------------------------------------|------------|---------|---------------------------------------------------------------------------------|--|--|
| UART0_MCR                             | 0xEF600304 | R/W     | UART 0 Modem Control Register                                                   |  |  |
| UART0_LSR                             | 0xEF600305 | R/W     | UART 0 Line Status Register                                                     |  |  |
| UARTO_MSR                             | 0xEF600306 | R/W     | UART 0 Modem Status Register                                                    |  |  |
| UART0_SCR                             | 0xEF600307 | R/W     | UART 0 Scratch Register                                                         |  |  |
| UART1_RBR                             | 0xEF600400 | R       | UART 1 Receiver Buffer Register                                                 |  |  |
|                                       |            |         | Note: Set UART1_LCR[DLAB] = 0 to access.                                        |  |  |
| UART1_THR                             |            | W       | UART 1 Transmitter Holding Register<br>Note: Set UART1_LCR[DLAB] = 0 to access. |  |  |
| UART1_DLL                             |            | R/W     | UART 1 Baud-rate Divisor Latch LSB<br>Note: Set UART1_LCR[DLAB] = 1 to access.  |  |  |
| UART1_IER                             | 0xEF600401 | R/W     | UART 1 Interrupt Enable Register<br>Note: Set UART1_LCR[DLAB] = 0 to access.    |  |  |
| UART1_DLM                             |            | R/W     | UART 1 Baud-rate Divisor Latch MSB<br>Note: Set UART1_LCR[DLAB] = 1 to access.  |  |  |
| UART1_IIR                             | 0xEF600402 | R       | UART 1 Interrupt Identification Register                                        |  |  |
| UART1_FCR                             | 0xEF600402 | W       | UART 1 FIFO Control Register                                                    |  |  |
| UART1_LCR                             | 0xEF600403 | R/W     | UART 1 Line Control Register                                                    |  |  |
| UART1_MCR                             | 0xEF600404 | R/W     | UART 1 Modem Control Register                                                   |  |  |
| UART1_LSR                             | 0xEF600405 | R/W     | UART 1 Line Status Register                                                     |  |  |
| UART1_MSR                             | 0xEF600406 | R/W     | UART 1 Modem Status Register                                                    |  |  |
| UART1_SCR                             | 0xEF600407 | R/W     | UART 1 Scratch Register                                                         |  |  |
| Inter-Integrated Circui               | it         | · · · · |                                                                                 |  |  |
| IIC0_MDBUF                            | 0xEF600500 | R/W     | IIC0 Master Data Buffer                                                         |  |  |
| IIC0_SDBUF                            | 0xEF600502 | R/W     | IIC0 Slave Data Buffer                                                          |  |  |
| IIC0_LMADR                            | 0xEF600504 | R/W     | IIC0 Low Master Address                                                         |  |  |
| IIC0_HMADR                            | 0xEF600505 | R/W     | IIC0 High Master Address                                                        |  |  |
| IIC0_CNTL                             | 0xEF600506 | R/W     | IIC0 Control                                                                    |  |  |
| IIC0_MDCNTL                           | 0xEF600507 | R/W     | IIC0 Mode Control                                                               |  |  |
| IIC0_STS                              | 0xEF600508 | R/W     | IIC0 Status                                                                     |  |  |
| IIC0_EXTSTS                           | 0xEF600509 | R/W     | IIC0 Extended Status                                                            |  |  |
| IIC0_LSADR                            | 0xEF60050A | R/W     | IIC0 Low Slave Address                                                          |  |  |
| IIC0_HSADR                            | 0xEF60050B | R/W     | IIC0 High Slave Address                                                         |  |  |
| IIC0_CLKDIV                           | 0xEF60050C | R/W     | IIC0 Clock Divide                                                               |  |  |
| IIC0_INTRMSK                          | 0xEF60050D | R/W     | IIC0 Interrupt Mask                                                             |  |  |
| IIC0_XFRCNT                           | 0xEF60050E | R/W     | IIC0 Transfer Count                                                             |  |  |
| IIC0_XTCNTLSS                         | 0xEF60050F | R/W     | IIC0 Extended Control and Slave Status                                          |  |  |
| IIC0_DIRECTCNTL                       | 0xEF600510 | R/W     | IIC0 Direct Control                                                             |  |  |
| OPB Arbiter                           |            |         |                                                                                 |  |  |
| OPBA0_PR                              | 0xEF600600 | R/W     | OPB Arbiter Priority Register                                                   |  |  |
| OPBA0_CR                              | 0xEF600601 | R/W     | OPB Arbiter Control Register                                                    |  |  |
| · · · · · · · · · · · · · · · · · · · | - J        |         | 1                                                                               |  |  |

| Register            | Address    | Access | Description                            |  |  |  |
|---------------------|------------|--------|----------------------------------------|--|--|--|
| General-Purpose I/O |            | •      |                                        |  |  |  |
| GPIO0_OR            | 0xEF600700 | R/W    | GPIO0_IRO Output Register              |  |  |  |
| GPIO0_TCR           | 0xEF600704 | R/W    | GPIO0_IRO Three-State Control Register |  |  |  |
| GPIO0_ODR           | 0xEF600718 | R/W    | GPIO0_IRO Open Drain Register          |  |  |  |
| GPIO0_IR            | 0xEF60071C | R      | GPIO0_IRO Input Register               |  |  |  |
| Ethernet            |            |        |                                        |  |  |  |
| EMAC0_MR0           | 0xEF600800 | R/W    | Mode Register 0                        |  |  |  |
| EMAC0_MR1           | 0xEF600804 | R/W    | Mode Register 1                        |  |  |  |
| EMAC0_TMR0          | 0xEF600808 | R/W    | Transmit Mode Register 0               |  |  |  |
| EMAC0_TMR1          | 0xEF60080C | R/W    | Transmit Mode Register 1               |  |  |  |
| EMAC0_RMR           | 0xEF600810 | R/W    | Receive Mode Register                  |  |  |  |
| EMAC0_ISR           | 0xEF600814 | R/W    | Interrupt Status Register              |  |  |  |
| EMAC0_ISER          | 0xEF600818 | R/W    | Interrupt Status Enable Register       |  |  |  |
| EMAC0_IAHR          | 0xEF60081C | R/W    | Individual Address High                |  |  |  |
| EMAC0_IALR          | 0xEF600820 | R/W    | Individual Address Low                 |  |  |  |
| EMAC0_VTPID         | 0xEF600824 | R/W    | VLAN TPID Register                     |  |  |  |
| EMAC0_VTCI          | 0xEF600828 | R/W    | VLAN TCI Register                      |  |  |  |
| EMAC0_PTR           | 0xEF60082C | R/W    | Pause Timer Register                   |  |  |  |
| EMAC0_IAHT1         | 0xEF600830 | R/W    | Individual Address Hash Table 1        |  |  |  |
| EMAC0_IAHT2         | 0xEF600834 | R/W    | Individual Address Hash Table 2        |  |  |  |
| EMAC0_IAHT3         | 0xEF600838 | R/W    | Individual Address Hash Table 3        |  |  |  |
| EMAC0_IAHT4         | 0xEF60083C | R/W    | Individual Address Hash Table 4        |  |  |  |
| EMAC0_GAHT1         | 0xEF600840 | R/W    | Group Address Hash Table 1             |  |  |  |
| EMAC0_GAHT2         | 0xEF600844 | R/W    | Group Address Hash Table 2             |  |  |  |
| EMAC0_GAHT3         | 0xEF600848 | R/W    | Group Address Hash Table 3             |  |  |  |
| EMAC0_GAHT4         | 0xEF60084C | R/W    | Group Address Hash Table 4             |  |  |  |
| EMAC0_LSAH          | 0xEF600850 | R      | Last Source Address Low                |  |  |  |
| EMAC0_LSAL          | 0xEF600854 | R      | Last Source Address High               |  |  |  |
| EMAC0_IPGVR         | 0xEF600858 | R/W    | Inter-Packet Gap Value Register        |  |  |  |
| EMAC0_STACR         | 0xEF60085C | R/W    | STA Control Register                   |  |  |  |
| EMAC0_TRTR          | 0xEF600860 | R/W    | Transmit Request Threshold Register    |  |  |  |
| EMAC0_RWMR          | 0xEF600864 | R/W    | Receive Low/High Water Mark Register   |  |  |  |

# Table 3-13. Directly Accessed MMIO Registers (continued)

#### 3.3.10.2 Indirectly Accessed MMIO Registers

The PCI configuration registers, listed in Table 3-15, are indirectly accessed.

The following procedure accesses the PCI configuration registers, using the address and data registers listed in Table 3-14:

- 1. OR the Enable, Bus, Device, and Function fields of the PCI Configuration Address Register (PCIC0\_CFGADDR) with the high-order 6 bits of the offset from Table 3-15 and write the result to the PCIC0\_CFGADDR.
- 2. OR the low-order 2 bits of the offset from Table 3-15 with the address of the PCI Configuration Data Register (PCIC0\_CFGDATA) to form an address.
- 3. Read data from or write data to the address.

| Register      | Address    | Access | Description                        |
|---------------|------------|--------|------------------------------------|
| PCIC0_CFGADDR | 0xEEC00000 | R/W    | PCI Configuration Address Register |
| PCIC0_CFGDATA | 0xEEC00004 | R/W    | PCI Configuration Data Register    |

Table 3-14. PCI Configuration Address and Data Registers

|                | ]         | Access |     |                                   |
|----------------|-----------|--------|-----|-----------------------------------|
| Register       | Offset    | PLB    | PCI | Description                       |
| PCIC0_VENDID   | 0x01–0x00 | R/W    | R   | PCI Vendor ID                     |
| PCIC0_DEVID    | 0x03-0x02 | R/W    | R   | PCI Device ID                     |
| PCIC0_CMD      | 0x05-0x04 | R/W    | R/W | PCI Command Register              |
| PCIC0_STATUS   | 0x07-0x06 | R/W    | R/W | PCI Status Register               |
| PCIC0_REVID    | 0x08      | R/W    | R/W | PCI Revision ID                   |
| PCIC0_CLS      | 0x0B-0x09 | R/W    | R   | PCI Class Register                |
| PCIC0_CACHELS  | 0x0C      | R      | R   | PCI Cache Line Size               |
| PCIC0_LATTIM   | 0x0D      | R/W    | R/W | PCI Latency Timer                 |
| PCIC0_HDTYPE   | 0x0E      | R      | R   | PCI Header Type                   |
| PCIC0_BIST     | 0x0F      | R      | R   | PCI Built In Self Test Control    |
| PCIC0_BAR0     | 0x13-0x10 | R      | R   | PCI Reserved BAR 0                |
| PCIC0_PTM1BAR  | 0x17-0x14 | R/W    | R/W | PCI PTM 1 BAR                     |
| PCIC0_PTM2BAR  | 0x1B-0x18 | R/W    | R/W | PCI PTM 2 BAR                     |
| PCICO_BAR3     | 0x1F-0x1C | · ·    | -   | PCI Reserved BAR 3                |
| PCIC0_BAR4     | 0x23-0x20 | _      | —   | PCI Reserved BAR 4                |
| PCIC0_BAR5     | 0x24-0x27 | —      | —   | PCI Reserved BAR 5                |
| PCIC0_CISPTR   | 0x2B0x28  | —      | -   | Unused Cardbus CIS Pointer        |
| PCIC0_SBSYSVID | 0x2D0x2C  | R/W    | R   | PCI Subsystem Vendor ID           |
| PCIC0_SBSYSID  | 0x2F-0x2E | R/W    | R   | PCI Subsystem ID                  |
| PCIC0_EROMBA   | 0x33-0x30 |        | —   | Unused Expansion ROM Base Address |
| PCIC0_CAP      | 0x34      | R      | R   | PCI Capabilities Pointer          |
| PCIC0_INTLN    | 0x3C      | R/W    | R/W | PCI Interrupt Line                |
| PCIC0_INTPN    | 0x3D      | R      | R   | PCI Interrupt Pin                 |
| PCIC0_MINGNT   | 0x3E      | R      | R   | PCI Minimum Grant                 |

#### Table 3-15. PCI Configuration Registers

|                |           | Access |     |                                                   |
|----------------|-----------|--------|-----|---------------------------------------------------|
| Register       | Offset    | PLB    | PCI | Description                                       |
| PCIC0_MAXLTNCY | 0x3F      | R      | R   | PCI Maximum Latency                               |
| PCIC0_ICS      | 0x44      | R/W    | R/W | PCI Interrupt Control/Status                      |
| PCIC0_ERREN    | 0x48      | R/W    | R/W | Error Enable                                      |
| PCIC0_ERRSTS   | 0x49      | R/W    | R/W | Error Status                                      |
| PCIC0_BRDGOPT1 | 0x4B-0x4A | R/W    | R/W | PCI Bridge Options 1                              |
| PCIC0_PLBBESR0 | 0x4F-0x4C | R/W    | R/W | PLB Slave Error Syndrome 0                        |
| PCIC0_PLBBESR1 | 0x53–0x50 | R/W    | R/W | PLB Slave Error Syndrome 1                        |
| PCIC0_PLBBEAR  | 0x57–0x54 | R/W    | R/W | PLB Slave Error Address Register                  |
| PCIC0_CAPID    | 0x58      | R      | R   | Capability Identifier                             |
| PCIC0_NEXTIPTR | 0x59      | R      | R   | Next Item Pointer                                 |
| PCIC0_PMC      | 0x5B-0x5A | R      | R   | Power Management Capabilities                     |
| PCIC0_PMCSR    | 0x5D-0x5C | R/W    | R/W | Power Management Control Status                   |
| PCIC0_PMCSRBSE | 0x5E      | R      | R   | PMCSR PCI to PCI bridge Support Extensions        |
| PCIC0_DATA     | 0x5F      | -      | -   | Unused Data                                       |
| PCIC0_BRDGOPT2 | 0x63-0x60 | R/W    | R/W | PCI Bridge Options 2                              |
| PCIC0_PMSCRR   | 0x64      | R/W    | R/W | Power Management State Change Request<br>Register |

Table 3-15. PCI Configuration Registers (continued)

# 3.4 Data Types and Alignment

The data types consist of bytes (eight bits), halfwords (two bytes), words (four bytes), and strings (1 to 128 bytes). Figure 3-10 shows the byte, halfword, and word data types and their bit and byte definitions for big endian representations of values. Note that PowerPC bit numbering is reversed from industry conventions; bit 0 represents the most significant bit of a value.



Figure 3-10. PPC405GP Data Types

Data is represented in either twos-complement notation or in an unsigned integer format; data representation is independent of alignment issues.

The address of an a data object is always the lowest address of any byte comprising the object.

All instructions are words, and are word-aligned (the lowest byte address is divisible by 4).

### 3.4.1 Alignment for Storage Reference and Cache Control Instructions

The storage reference instructions (loads and stores; see Table 3-23, "Storage Reference Instructions," on page 3-48) move data to and from storage. The data cache control instructions listed in Table 3-32, "Cache Management Instructions," on page 3-52, control the contents and operation of the data cache unit (DCU). Both types of instructions form an effective address (EA). The method of calculating the EA for the storage reference and cache control instructions is detailed in the description of those instructions. See Chapter 24, "Instruction Set," for more information.

Cache control instructions ignore the four least significant bits of the EA; no alignment restrictions exist in the DCU because of EAs. However, storage control attributes can cause alignment exceptions. When data address translation is disabled and a **dcbz** instruction references a storage region that is non-cachable, or for which write-through caching is the write strategy, an alignment exception is taken. Such exceptions result from the storage control attributes, not from EA alignment. The alignment exception enables system software to emulate the write-through function.

Alignment requirements for the storage reference instructions and the **dcread** instruction depend on the particular instruction. Table 3-16, "Alignment Exception Summary," on page 3-28, summarizes the instructions that cause alignment exceptions.

The data targets of instructions are of types that depend upon the instruction. The load/store instructions have the following "natural" alignments:

- Load/store word instructions have word targets, word-aligned.
- Load/ store halfword instructions have halfword targets, halfword-aligned.
- · Load/store byte instructions have byte targets, byte-aligned (that is, any alignment).

Misalignments are addresses that are not naturally aligned on data type boundaries. An address not divisible by four is misaligned with respect to word instructions. An address not divisible by two is misaligned with respect to halfword instructions. The PPC405GP implementation handles misalignments within and across word boundaries, but there is a performance penalty because additional bus cycles are required.

### 3.4.2 Alignment and Endian Operation

The endian storage control attribute does not affect alignment behavior. In little endian storage regions, the alignment of data is treated as it is in big endian storage regions; no special alignment exceptions occur when accessing data in little endian storage regions. Note that the alignment exceptions that apply to big endian region accesses also apply to little endian storage region accesses.

## 3.4.3 Summary of Instructions Causing Alignment Exceptions

Table 3-16 summarizes the instructions that cause alignment exceptions and the conditions under which the alignment exceptions occur.

| Instructions Causing Alignment<br>Exceptions | Conditions                                  |
|----------------------------------------------|---------------------------------------------|
| dcbz                                         | EA in non-cachable or write-through storage |
| dcread, Iwarx, stwcx.                        | EA not word-aligned                         |

Table 3-16. Alignment Exception Summary

# 3.5 Byte Ordering

The following discussion describes the "endianness" of the PPC405GP core, which, by default and in normal use is "big endian." The PPC405GP also contains "little endian" peripherals and supports the attachment of external little endian peripherals.

If scalars (individual data items and instructions) were indivisible, "byte ordering" would not be a concern. It is meaningless to consider the order of bits or groups of bits within a byte, the smallest addressable unit of storage; nothing can be observed about such order. Only when scalars, which the programmer and processor regard as indivisible quantities, can comprise more than one addressable unit of storage does the question of byte order arise.

For a machine in which the smallest addressable unit of storage is the 32-bit word, there is no question of the ordering of bytes within words. All transfers of individual scalars between registers and storage are of words, and the address of the byte containing the high-order eight bits of a scalar is the same as the address of any other byte of the scalar.

For the PowerPC Architecture, as for most computer architectures currently implemented, the smallest addressable unit of storage is the 8-bit byte. Other scalars are halfwords, words, or doublewords, which consist of groups of bytes. When a word-length scalar is moved from a register to storage, the scalar is stored in four consecutive byte addresses. It thus becomes meaningful to discuss the order of the byte addresses with respect to the value of the scalar: that is, which byte contains the highest-order eight bits of the scalar, which byte contains the next-highest-order eight bits, and so on.

Given a scalar that contains multiple bytes, the choice of byte ordering is essentially arbitrary. There are 4! = 24 ways to specify the ordering of four bytes within a word, but only two of these orderings are commonly used:

• The ordering that assigns the lowest address to the highest-order ("leftmost") eight bits of the scalar, the next sequential address to the next-highest-order eight bits, and so on.

This ordering is called *big endian* because the "big end" of the scalar, considered as a binary number, comes first in storage.

• The ordering that assigns the lowest address to the lowest-order ("rightmost") eight bits of the scalar, the next sequential address to the next-lowest-order eight bits, and so on.

This ordering is called *little endian* because the "little end" of the scalar, considered as a binary number, comes first in storage.

#### 3.5.1 Structure Mapping Examples

The following C language structure, *s*, contains an assortment of scalars and a character string. The comments show the value assumed to be in each structure element; these values show how the bytes comprising each structure element are mapped into storage.

struct {

| int a;       | /* 0x1112_1314 word */                           |
|--------------|--------------------------------------------------|
| long long b; | /* 0x2122_2324_2526_2728 doubleword */           |
| char *c;     | /* 0x3132_3334 word */                           |
| char d[7];   | /* 'A','B','C','D','E','F','G' array of bytes */ |
| short e;     | /* 0x5152 halfword */                            |
| int f;       | /* 0x6162_6364 word */                           |

} s;

C structure mapping rules permit the use of padding (skipped bytes) to align scalars on desirable boundaries. The structure mapping examples show each scalar aligned at its natural boundary. This alignment introduces padding of four bytes between *a* and *b*, one byte between *d* and *e*, and two bytes between *e* and *f*. The same amount of padding is present in both big endian and little endian mappings.

#### 3.5.1.1 Big Endian Mapping

The big endian mapping of structure s follows. (The data is highlighted in the structure mappings. Addresses, in hexadecimal, are below the data stored at the address. The contents of each byte, as defined in structure s, is shown as a (hexadecimal) number or character (for the string elements).

| 11   | 12   | 13   | 14   |      |      |      |      |
|------|------|------|------|------|------|------|------|
| 0x00 | 0x01 | 0x02 | 0x03 | 0x04 | 0x05 | 0x06 | 0x07 |
| 21   | 22   | 23   | 24   | 25   | 26   | 27   | 28   |
| 0x08 | 0x09 | 0x0A | 0x0B | 0x0C | 0x0D | 0x0E | 0x0F |
| 31   | 32   | 33   | 34   | 'A'  | 'B'  | 'C'  | 'D'  |
| 0x10 | 0x11 | 0x12 | 0x13 | 0x14 | 0x15 | 0x16 | 0x17 |
| 'E'  | 'F'  | 'G'  |      | 51   | 52   |      |      |
| 0x18 | 0x19 | 0x1A | 0x1B | 0x1C | 0x1D | 0x1E | 0x1F |
| 61   | 62   | 63   | 64   |      |      |      |      |
| 0x20 | 0x21 | 0x22 | 0x23 | 0x24 | 0x25 | 0x26 | 0x27 |

#### 3.5.1.2 Little Endian Mapping

Structure s is shown mapped little endian.

| 14   | 13   | 12   | 11   |      |      |      |      |
|------|------|------|------|------|------|------|------|
| 0x00 | 0x01 | 0x02 | 0x03 | 0x04 | 0x05 | 0x06 | 0x07 |
| 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   |
| 0x08 | 0x09 | 0x0A | 0x0B | 0x0C | 0x0D | 0x0E | 0x0F |
| 34   | 33   | 32   | 31   | 'A'  | 'B'  | 'C'  | 'D'  |
| 0x10 | 0x11 | 0x12 | 0x13 | 0x14 | 0x15 | 0x16 | 0x17 |
| 'E'  | 'F'  | 'G'  |      | 52   | 51   |      |      |
| 0x18 | 0x19 | 0x1A | 0x1B | 0x1C | 0x1D | 0x1E | 0x1F |
| 64   | 63   | 62   | 61   |      |      |      |      |
| 0x20 | 0x21 | 0x22 | 0x23 | 0x24 | 0x25 | 0x26 | 0x27 |

#### 3.5.2 Support for Little Endian Byte Ordering

Except as noted, this book describes the processor as if it operated only in a big endian fashion. In fact, the IBM PowerPC Embedded Environment also supports little endian operation.

The PowerPC little endian mode, defined in the PowerPC Architecture, is not implemented.

#### 3.5.3 Endian (E) Storage Attribute

The endian (E) storage attribute supports direct connection of the PPC405GP to little endian peripherals and to memory containing little endian instructions and data. For every storage reference (instruction fetch or load/store access), an E storage attribute is associated with the storage region of the reference. The E attribute specifies whether that region is organized as big endian (E = 0) or little endian (E = 1).

When address translation is enabled (MSR[IR] = 1 or MSR[DR] = 1), the E field in the corresponding TLB entry controls the endianness of a memory region. When address translation is disabled (MSR[IR] = 0 or MSR[DR] = 0), the SLER controls the endianness of a memory region.

Bytes in storage that are accessed as little endian are arranged in true little endian format. The PPC405GP does not support the little endian mode defined in the PowerPC architecture and used in PPC401xx and PPC403xx processors. Furthermore, no address modification is performed when accessing storage regions programmed as little endian. Instead, the PPC405GP reorders the bytes as they are transferred between the processor and memory.

The on-the-fly reversal of bytes in little endian storage regions is handled in one of two ways, depending on whether the storage access is an instruction fetch or a data access (load/store). The following sections describe byte reordering for the two kinds of storage accesses.

#### 3.5.3.1 Fetching Instructions from Little Endian Storage Regions

Instructions are words (four bytes) that are aligned on word boundaries in memory. As such, instructions in a big endian memory region are arranged with the most significant byte (MSB) of the instruction word at the lowest address.

Consider the big endian mapping of instruction p at address 00, where, for example, p = add r7, r7, r4:

| MSB  |      |      | LSB  |
|------|------|------|------|
| 0x00 | 0x01 | 0x02 | 0x03 |

On the other hand, in the little endian mapping instruction p is arranged with the least significant byte (LSB) of the instruction word at the lowest numbered address:

| LSB  |      |      | MSB  |
|------|------|------|------|
| 0x00 | 0x01 | 0x02 | 0x03 |

When an instruction is fetched from memory, the instruction must be placed in the instruction queue in the proper order. The execution unit assumes that the MSB of an instruction word is at the lowest address. Therefore, when instructions are fetched from little endian storage regions, the four bytes of an instruction word are reversed before the instruction is decoded. In the PPC405GP, the byte reversal occurs between memory and the instruction cache unit (ICU). The ICU always stores instructions in big endian format, regardless of whether the memory region containing the instruction is programmed as big endian or little endian. Thus, the bytes are already in the proper order when an instruction is transferred from the ICU to the decode stage of the pipeline.

If a storage region is reprogrammed from one endian format to the other, the storage region must be reloaded with program and data structures in the appropriate endian format. If the endian format of instruction memory changes, the ICU must be made coherent with the updates. The ICU must be invalidated and the updated instruction memory using the new endian format must be fetched so that the proper byte ordering occurs before the new instructions are placed in the ICU.

#### 3.5.3.2 Accessing Data in Little Endian Storage Regions

Unlike instruction fetches from little endian storage regions, data accesses from little endian storage regions are *not* byte-reversed between memory and the DCU. Data byte ordering, in memory, depends on the data type (byte, halfword, or word) of a specific data item. It is only when moving a data item *of a specific type* from or to a GPR that it becomes known what type of byte reversal is required. Therefore, byte reversal during load/store accesses is performed between the DCU and the GPR.

When accessing data in a little endian storage region:

- For byte loads/stores, no reordering occurs.
- For halfword loads/stores, bytes are reversed within the halfword.
- For word loads/stores, bytes are reversed within the word.

Note that this applies, regardless of data alignment.

The big endian and little endian mappings of the structure *s*, shown in "Structure Mapping Examples" on page 3-29, demonstrate how the size of an item determines its byte ordering. For example:

- The word *a* has its four bytes reversed within the word spanning addresses 0x00–0x03.
- The halfword e has its two bytes reversed within the halfword spanning addresses 0x1C-0x1D.

Note that the array of bytes *d*, where each data item is a byte, is not reversed when the big endian and little endian mappings are compared. For example, the character 'A' is located at address 14 in both the big endian and little endian mappings.

In little endian storage regions, the alignment of data is treated as it is in big endian storage regions. Unlike PowerPC little endian mode, no special alignment exceptions occur when accessing data in little endian storage regions.

#### 3.5.3.3 PowerPC Byte-Reverse Instructions

For big endian storage regions, normal load/store instructions move the more significant bytes of a register to and from the lower-numbered memory addresses. The load/store with byte-reverse instructions move the more significant bytes of the register to and from the higher numbered memory addresses.

As Figure 3-11 through Figure 3-14 illustrate, a normal store to a big endian storage region is the same as a byte-reverse store to a little endian storage region. Conversely, a normal store to a little endian storage region is the same as a byte-reverse store to a big endian storage region.

Figure 3-11 illustrates the contents of a GPR and memory (starting at address 00) after a normal load/store in a big endian storage region.



Figure 3-11. Normal Word Load or Store (Big Endian Storage Region)

Note that the results are identical to the results of a load/store with byte-reverse in a little endian storage region, as illustrated in Figure 3-12.

| MSB |    |    |    |     |
|-----|----|----|----|-----|
| 11  | 12 | 13 | 14 | GPR |
|     |    |    |    | _   |

| 11   | 12   | 13   | 14   | Memory |
|------|------|------|------|--------|
| 0x00 | 0x01 | 0x02 | 0x03 |        |

Figure 3-12. Byte-Reverse Word Load or Store (Little Endian Storage Region)

Figure 3-13 illustrates the contents of a GPR and memory (starting at address 00) after a load/store with byte-reverse in a big endian storage region.



Figure 3-13. Byte-Reverse Word Load or Store (Big Endian Storage Region)

Note that the results are identical to the results of a normal load/store in a little endian storage region, as illustrated in Figure 3-14.



| 14   | 13     | 12   | 11   | Memory |
|------|--------|------|------|--------|
| 0x00 | : 0x01 | 0x02 | 0x03 |        |

Figure 3-14. Normal Word Load or Store (Little Endian Storage Region)

The E storage attribute augments the byte-reverse load/store instructions in two important ways:

• The load/store with byte-reverse instructions do not solve the problem of fetching instructions from a storage region in little endian format.

Only the endian storage attribute mechanism supports the fetching of little endian program images.

• Typical compilers cannot make general use of the byte-reverse load/store instructions, so these instructions are ordinarily used only in device drivers written in hand-coded assembler.

Compilers can, however, take full advantage of the endian storage attribute mechanism, enabling application programmers working in a high-level language, such as C, to compile programs and data structures into little endian format.

# 3.6 Instruction Processing

The instruction pipeline, illustrated in Figure 3-15, contains three queue locations: prefetch buffer 1 (PFB1), prefetch buffer 0 (PFB0), and decode (DCD). This queue implements a pipeline with the following functional stages: fetch, decode, execute, write-back and load write-back. Instructions are fetched from the instruction cache unit (ICU), placed in the instruction queue, and eventually dispatched to the execution unit (EXU).

Instructions are fetched from the ICU at the request of the EXU. Cachable instructions are forwarded directly to the instruction queue and stored in the ICU cache array. Non-cachable instructions are also forwarded directly to the instruction queue, but are not stored in the ICU cache array. Fetched

instructions drop to the empty queue location closest to the EXU. When there is room in the queue, Instructions can be returned from the ICU two at a time. If the queue is empty and the ICU is returning two instructions, one instruction drops into DCD while the other drops into PFB0. PFB1 buffers instructions when the pipeline stalls.

Branch instructions are examined in DCD and PFB0 while all other instructions are decoded in DCD. All instructions must pass through DCD before entering the EXU. The EXU contains the execute, write-back and load write-back stages of the pipe. The results of most instructions are calculated during the execute stage and written to the GPR file during the write back stage. Load instructions write the GPR file during the load write-back stage.



Figure 3-15. PPC405GP Instruction Pipeline

## 3.7 Branch Processing

The PPC405GP, which provides a variety of conditional and unconditional branching instructions, uses the branch prediction techniques described in "Branch Prediction" on page 3-35.

### 3.7.1 Unconditional Branch Target Addressing Options

The unconditional branches (**b**, **ba**, **bl**, **bla**) carry the displacement to the branch target address as a signed 26-bit value (the 24-bit LI field right-extended with 0b00). The displacement enables unconditional branches to cover an address range of  $\pm 32$ MB.

For the relative (AA = 0) forms (**b**, **b**I), the target address is the current instruction address (CIA, the address of the branch instruction) plus the signed displacement.

For the absolute (AA = 1) forms (**ba**, **bla**), the target address is 0 plus the signed displacement. If the sign bit (LI[0]) is 0, the displacement is the target address. If the sign bit is 1, the displacement is a negative value and wraps to the highest memory addresses. For example, if the displacement is 0x3FF FFFC (the 26-bit representation of -4), the target address is 0xFFFF FFFC (0 – 4B, or 4 bytes below the top of memory).

## 3.7.2 Conditional Branch Target Addressing Options

The conditional branches (**bc**, **bca**, **bcl**, **bcla**) carry the displacement to the branch target address as a signed 16-bit value (the 14-bit BD field right-extended with 0b00). The displacement enables conditional branches to cover an address range of  $\pm$ 32KB.

For the relative (AA = 0) forms (**bc**, **bc**), the target address is the CIA plus the signed displacement.

For the absolute (AA = 1) forms (**bca**, **bcla**), the target address is 0 plus the signed displacement. If the sign bit (BD[0]) is 0, the displacement is the target address. If the sign bit is 1, the displacement is negative and wraps to the highest memory addresses. For example, if the displacement is 0xFFFC (the 16-bit representation of -4), the target address is 0xFFFFFFFFFC (0 - 4B, or 4 bytes from the top of memory).

### 3.7.3 Conditional Branch Condition Register Testing

Conditional branch instructions can test a CR bit. The value of the BI field specifies the bit to be tested (bit 0–31). The BO field controls whether the CR bit is tested, as described in the following section.

## 3.7.4 BO Field on Conditional Branches

The BO field of the conditional branch instruction specifies the conditions used to control branching, and specifies how the branch affects the CTR.

Conditional branch instructions can test one bit in the CR. This option is selected when BO[0] = 0; if BO[0] = 1, the CR does not participate in the branch condition test. If this option is selected, the condition is satisfied (branch can occur) if CR[BI] = BO[1].

Conditional branch instructions can decrement the CTR by one, and after the decrement, test the CTR value. This option is selected when BO[2] = 0. If this option is selected, BO[3] specifies the condition that must be satisfied to allow a branch to be taken. If BO[3] = 0, CTR  $\neq 0$  is required for a branch to occur. If BO[3] = 1, CTR = 0 is required for a branch to occur.

If BO[2] = 1, the contents of the CTR are left unchanged, and the CTR does not participate in the branch condition test.

Table 3-17 summarizes the usage of the bits of the BO field. BO[4] is further discussed in "Branch Prediction."

| BO Bit | Description                                                                                                                                                                        |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BO[0]  | CR Test Control<br>0 Test CR bit specified by BI field for value specified by BO[1]<br>1 Do not test CR                                                                            |
| BO[1]  | CR Test Value<br>0 Test for CR[BI] = 0.<br>1 Test for CR[BI] = 1.                                                                                                                  |
| BO[2]  | <ul> <li>CTR Test Control</li> <li>Decrement CTR by one and test whether CTR satisfies the condition specified by BO[3].</li> <li>1 Do not change CTR, do not test CTR.</li> </ul> |

Table 3-17. Bits of the BO Field

| BO Bit | Description                                                                                                    |   |
|--------|----------------------------------------------------------------------------------------------------------------|---|
| BO[3]  | CTR Test Value<br>0 Test for CTR ≠ 0.<br>1 Test for CTR = 0.                                                   |   |
| BO[4]  | Branch Prediction Reversal<br>0 Apply standard branch prediction.<br>1 Reverse the standard branch prediction. | _ |

Table 3-17. Bits of the BO Field (continued)

Table 3-18 lists specific BO field contents, and the resulting actions; z represents a mandatory value of 0, and y is a branch prediction option discussed in "Branch Prediction."

| Table 3-18. | Conditional | Branch | BO Field |   |
|-------------|-------------|--------|----------|---|
|             |             |        |          | _ |

| BO Value               | Description                                                                    |
|------------------------|--------------------------------------------------------------------------------|
| 0000 <i>y</i>          | Decrement the CTR, then branch if the decremented CTR $\neq$ 0 and CR[BI]=0.   |
| 0001 <i>y</i>          | Decrement the CTR, then branch if the decremented $CTR = 0$ and $CR[BI] = 0$ . |
| 001 <i>zy</i>          | Branch if CR[BI] = 0.                                                          |
| 0100 <i>y</i>          | Decrement the CTR, then branch if the decremented CTR $\neq$ 0 and CR[BI] = 1. |
| 0101 <i>y</i>          | Decrement the CTR, then branch if the decremented CTR=0 and CR[BI] = 1.        |
| 011 <i>zy</i>          | Branch if CR[BI] = 1.                                                          |
| 1 <i>z</i> 00 <i>y</i> | Decrement the CTR, then branch if the decremented CTR $\neq$ 0.                |
| 1 <i>z</i> 01 <i>y</i> | Decrement the CTR, then branch if the decremented $CTR = 0$ .                  |
| 1 <i>z</i> 1 <i>zz</i> | Branch always.                                                                 |

### 3.7.5 Branch Prediction

Conditional branches present a problem to the instruction fetcher. A branch might be taken. The branch EXU attempts to predict whether or not a branch is taken before all information necessary to determine the branch direction is available. This decision is called a *branch prediction*. The fetcher can then prefetch instructions starting at the predicted branch target address. If the prediction is correct, time is saved because the branched-to instruction is available in the instruction queue. Otherwise, the instruction pipeline stalls while the correct instruction is fetched into the instruction queue. To be effective, branch prediction must be correct most of the time.

The PowerPC Architecture enables software to reverse the default branch prediction, which is defined as follows:

Predict that the branch is to be taken if  $((BO[0] \land BO[2]) \lor s) = 1$ 

where *s* is the sign bit of the displacement for conditional branch (**bc**) instructions, and 0 for **bcIr** and **bcctr** instructions.

 $(BO[0] \land BO[2]) = 1$  only when the conditional branch tests nothing (the "branch always" condition). Obviously, the branch should be predicted taken for this case.

If the branch tests anything,  $(BO[0] \land BO[2]) = 0$ , and *s* entirely controls the prediction. The default prediction for this case was decided by considering the relative form of **bc**, which is commonly used at the end of loops to control the number of times that a loop is executed. The branch is taken every time

the loop is executed except the last, so it is best if the branch is predicted taken. The branch target is the beginning of the loop, so the branch displacement is negative and s = 1.

If branch displacements are positive (s = 0), the branch is predicted not taken. If the branch instruction is any form of **bcir** or **bcctr** except the "branch always" forms, then s = 0, and the branch is predicted not taken.

There is a peculiar consequence of this prediction algorithm for the absolute forms of **bc** (**bca** and **bcla**). As described in "Unconditional Branch Target Addressing Options" on page 3-34, if the algebraic sign of the displacement is negative (s = 1), the branch target address is in high memory. If the algebraic sign of the displacement is positive (s = 0), the branch target address is in low memory. Because these are absolute-addressing forms, there is no reason to treat high and low memory differently. Nevertheless, for the high memory case the default prediction is taken, and for the low memory case the default prediction is not taken.

BO[4] is the *prediction reversal bit*. If BO[4] = 0, the default prediction is applied. If BO[4] = 1, the reverse of the standard prediction is applied. For the cases in Table 3-17 where BO[4] = y, software can reverse the default prediction. This should only be done when the default prediction is likely to be wrong. Note that for the "branch always" condition, reversal of the default prediction is not allowed.

The PowerPC Architecture requires assemblers to provide a way to conveniently control branch prediction. For any conditional branch mnemonic, a suffix may be added to the mnemonic to control prediction, as follows:

- + Predict branch to be taken
- Predict branch to be not taken

For example, **bcctr+** causes BO[4] to be set appropriately to force the branch to be predicted taken.

## 3.8 Speculative Accesses

The PowerPC Architecture permits implementations to perform speculative accesses to memory, either for instruction fetching, or for data loads. A speculative access is defined as any access which is not required by a sequential execution model.

For example, prefetching instructions beyond an undetermined conditional branch is a speculative fetch; if the branch is not in the predicted direction, the program, as executed, never needs the instructions from the predicted path.

Sometimes speculative accesses are inappropriate. For example, attempting to fetch instructions from addresses that cannot contain instructions can cause problems. To protect against errant accesses to "sensitive" memory or I/O devices, the PowerPC Architecture provides the G (guarded) storage attribute, which can be used to specify memory pages from which speculative accesses are prohibited. (Actually, speculative accesses to guarded storage are allowed in certain limited circumstances; if an instruction in a cache block will be executed, the rest of the cache block can be speculatively accessed.)

### 3.8.1 Speculative Accesses in the PPC405GP

The PPC405GP does not perform speculative loads.

Two methods control speculative instruction fetching. If instruction address translation is enabled (MSR[IR] = 1), the G (guarded) field in the translation lookaside buffer (TLB) entries controls speculative accesses.

If instruction address translation is disabled (MSR[IR] = 0), the Storage Guarded Register (SGR) controls speculative accesses for regions of memory. When a region is guarded (speculative fetching is disallowed), instruction prefetching is disabled for that region. A fetch request must be completely resolved (no longer speculative) before it is issued. There is a considerable performance penalty for fetching from guarded storage, so guarding should be used only when required.

Note that, following any reset, the PPC405GP operates with all of storage guarded.

Note that when address translation is enabled, attempts to access guarded storage result in instruction storage exceptions. Guarded memory is in most often needed with peripheral status registers that are cleared automatically after being read, because an unintended access resulting from a speculative fetch would cause the loss of status information. Because the MMU provides 64 pages with a wide range of page sizes as small as 1KB, fetching instructions from guarded storage should be unnecessary.

### 3.8.1.1 Prefetch Distance Down an Unresolved Branch Path

The fetcher will speculatively access up to five instructions down a predicted branch path, whether taken or sequential. The unresolved branch is in the DCD stage of the instruction queue (see "Instruction Processing" on page 3-33 for a description of the instruction pipeline). If PFB0 and PFB1 are full, no further speculative accesses occur. If PFB0 or PFB1 is empty, the fetcher requests the next speculative instruction from the ICU; that instruction is placed in PFB0 or PFB1. If the fetched instruction is at the end of a cache line, and if PFB1 is empty, the fetcher requests the next cache line. The instruction at the beginning of the cache line is placed in PFB1. In this case, five instructions are speculatively accessed. The fetcher can speculatively access no more than four instructions (a cache line) from the cache with a single request, assuming the speculative address is cachable.

If the address is non-cachable (as controlled by the I storage attribute), no more than two instructions are speculatively accessed.

### 3.8.1.2 Prefetch of Branches to the CTR and Branches to the LR

When the instruction fetcher predicts that a **bctr** or **blr** instruction will be taken, the fetcher does not attempt to fetch an instruction from the target address in the CTR or LR if an executing instruction updates the register ahead of the branch. (See "Instruction Processing" on page 3-33 for a description of the instruction pipeline). The fetcher recognizes that the CTR or LR contains data left from an earlier use and that such data is probably not valid.

In such cases, the fetcher does not fetch the instruction at the target address until the instruction that is updating the CTR or LR completes. Only then are the "correct" CTR or LR contents known. This prevents the fetcher from speculatively accessing a completely "random" address. After the CTR or LR contents are known to be correct, the fetcher accesses no more than five instructions down the sequential or taken path of an unresolved branch, or at the address contained in the CTR or LR.

## 3.8.2 Preventing Inappropriate Speculative Accesses

A memory-mapped I/O peripheral, such as a serial port having a status register that is automatically reset when read provides a simple example of storage that should not be speculatively accessed. If code is in memory at an address adjacent to the peripheral (for example, code goes from

0x0000 0000 to 0x0000 0FFF, and the peripheral is at 0x0000 1000), prefetching past the end of the code will read the peripheral.

Guarding storage also prevents prefetching past the end of memory. If the highest memory address is left unguarded, the fetcher could attempt to fetch past the last valid address, potentially causing machine checks on the fetches from invalid addresses. While the machine checks do not actually cause an exception until the processor attempts to execute an instruction at an invalid address, some systems could suffer from the attempt to access such an invalid address. For example, an external memory controller might log an error.

System designers can avoid problems from speculative fetching without using the guarded storage attributes. The rest of this section describes ways to prevent speculative instruction fetches to sensitive addresses in unguarded memory regions.

#### 3.8.2.1 Fetching Past an Interrupt-Causing or Interrupt-Returning Instruction

Suppose a **bctr** or **blr** instruction closely follows an interrupt-causing or interrupt-returning instruction (**sc**, **rfi**, or **rfci**). The fetcher does not prevent speculatively fetching past one of these instructions. In other words, the fetcher does not treat the interrupt-causing and interrupt-returning instructions specially when deciding whether to predict down a branch path. Instructions after an **rfi**, for example, are considered to be on the determined branch path.

To understand the implications of this situation, consider the code sequence:

handler: aaa bbb rfi subroutine: bctr

When executing the interrupt handler, the fetcher does not recognize the **rfi** as a break in the program flow, and speculatively fetches the target of the **bctr**, which is really the first instruction of a subroutine that has not been called. Therefore, the CTR might contain an invalid pointer.

To protect against such a prefetch, the software must insert an unconditional branch hang (**b** \$) just after the **rfi**. This prevents the hardware from prefetching the invalid target address used by **bctr**.

Consider also the above code sequence, with the **rfi** instruction replaced by an **sc** instruction used to initialize the CTR with the appropriate value for the **bctr** to branch to, upon return from the system call. The **sc** handler returns to the instruction following the **sc**, which can't be a branch hang. Instead, software could put a **mtctr** just before the **sc** to load a non-sensitive address into the CTR. This address will be used as the prediction address before the **sc** executes. An alternative would be to put a **mtctr** between the **sc** and the **bctr**; the **mtctr** prevents the fetcher from speculatively accessing the address contained in the CTR before initialization.

#### 3.8.2.2 Fetching Past tw or twi Instructions

The interrupt-causing instructions, **tw** and **twi**, do not require the special handling described in "Fetching Past an Interrupt-Causing or Interrupt-Returning Instruction" on page 3-39. These instructions are typically used by debuggers, which implement software breakpoints by substituting a trap instruction for the instruction originally at the breakpoint address. In a code sequence **mtir** followed by **bir** (or **mtctr** followed by **bctr**), replacement of **mtir/mtctr** by **tw** or **twi** leaves the LR/CTR uninitialized. It would be inappropriate to fetch from the **bir/bctr** target address. This situation is common, and the fetcher is designed to prevent the problem.

## 3.8.2.3 Fetching Past an Unconditional Branch

When an unconditional branch is in DCD in the instruction queue, the fetcher recognizes that the sequential instructions following the branch are unnecessary. These sequential addresses are not accessed. Addresses at the branch target are accessed instead.

Therefore, placing an unconditional branch just before the start of a sensitive address space (for example, at the "end" of a memory area that borders an I/O device) guarantees that addresses in the sensitive area will not be speculatively fetched.

#### 3.8.2.4 Suggested Locations of Memory-Mapped Hardware

The preferred method of protecting memory-mapped hardware from inadvertent access is to use address translation, with hardware isolated to guarded pages (the G storage attribute in the associated TLB entry is set to 1.) The pages can be as small as 1KB. Code should never be stored in such pages.

If address translation is disabled, the preferred protection method is to isolate memory-mapped hardware into regions guarded using the SGR. Code should never be stored in such regions. The disadvantage of this method, compared to the preferred method, is that each region guarded by the SGR consumes 128MB of the address space.

Table 3-19 shows two address regions of the PPC405GP. Suppose a system designer can map all I/O devices and all ROM and SRAM devices into any location in either region. The choices made by the designer can prevent speculative accesses to the memory-mapped I/O devices.

Table 3-19. Example Memory Mapping

| 0x7800 0000 – 0x7FFF FFFF (SGR bit 15) | 128MB Region 2 |
|----------------------------------------|----------------|
| 0x7000 0000 – 0x77FF FFFF (SGR bit 14) | 128MB Region 1 |

A simple way to avoid the problem of speculative reads to peripherals is to map all storage containing code into Region 2, and all I/O devices into Region 1. Thus, accesses to Region 2 would only be for code and program data. Speculative fetches occuring in Region 2 would never access addresses in Region 1. Note that this hardware organization eliminates the need to use of the G storage attribute to protect Region 1. However, Region 1 could be set as guarded with no performance penalty, because there is no code to execute or variable data to access in Region 1.

The use of these regions could be reversed (code in Region 1 and I/O devices in Region 2), if Region 2 is set as guarded. Prefetching from the highest addresses of Region 1 could cause an attempt to speculatively access the bottom of Region 2, but guarding prevents this from occurring. The performance penalty is slight, under the assumption that code infrequently executes the instructions in the highest addresses of Region 1.

## 3.8.3 Summary

Software should take the following actions to prevent speculative accesses to sensitive data areas, if the sensitive data areas are not in guarded storage:

- Protect against accesses to "random" values in the LR or CTR on blr or bctr branches following rfi, rfci, or sc instructions by putting appropriate instructions before or after the rfi, rfci, or sc instruction. See "Fetching Past an Interrupt-Causing or Interrupt-Returning Instruction" on page 3-39.
- Protect against "running past" the end of memory into a bordering I/O device by putting an unconditional branch at the end of the memory area. See "Fetching Past an Unconditional Branch" on page 3-40.
- Recognize that a maximum of five words (20 bytes) can be prefetched past an unresolved conditional branch, either down the target path or the sequential path. See "Prefetch Distance Down an Unresolved Branch Path" on page 3-38.

Of course, software should not code branches with known unsafe targets (either relative to the instruction counter, or to addresses contained in the LR or CTR), on the assumption that the targets are "protected" by code guaranteeing that the unsafe direction is not taken. The fetcher assumes that if a branch is predicted to be taken, it is safe to fetch down the target path.

# 3.9 Privileged Mode Operation

In the PowerPC Architecture, several terms describe two operating modes that have different instruction execution privileges. When a processor is in "privileged mode," it can execute all instructions in the instruction set. This mode is also called the "supervisor state." The other mode, in which certain instructions cannot be executed, is called the "user mode," or "problem state." These terms are used in pairs:

| Privileged       | Non-privileged |  |
|------------------|----------------|--|
| Privileged Mode  | User Mode      |  |
| Supervisor State | Problem State  |  |

The architecture uses MSR[PR] to control the execution mode. When MSR[PR] = 1, the processor is in user mode (problem state); when MSR[PR] = 0, the processor is in privileged mode (supervisor state).

After a reset, MSR[PR] = 0.

### 3.9.1 MSR Bits and Exception Handling

The current value of MSR[PR] is saved, along with all other MSR bits, in the SRR1 (for non-critical interrupts) or SRR3 (for critical interrupts) upon any interrupt, and MSR[PR] is set to 0. Therefore, all exception handlers operate in privileged mode.

Attempting to execute a privileged instruction while in user mode causes a privileged violation program exception (see "Program Interrupt" on page 10-40). The PPC405GP does not execute the instruction, and the least-significant 16 bits of the program counter are loaded with 0x0700, the address of an exception processing routine.

The PRR field of the Exception Syndrome Register (ESR) is set when an interrupt was caused by a privileged instruction program exception. Software is not required to clear ESR[PRR].

#### 3.9.2 Privileged Instructions

The instructions listed in Table 3-20 are privileged and cannot be executed while in user mode (MSR[PR] = 1).

| dcbi    |                                                                                          |
|---------|------------------------------------------------------------------------------------------|
| dccci   |                                                                                          |
| dcread  |                                                                                          |
| iccci   |                                                                                          |
| icread  |                                                                                          |
|         |                                                                                          |
| mfdcr   | · · · · · · · · · · · · · · · · · · ·                                                    |
| mfmsr   |                                                                                          |
| mfspr   | For all SPRs except CTR, LR, SPRG4–SPRG7, and XER. See<br>"Privileged SPRs" on page 3-42 |
| mtdcr   |                                                                                          |
| mtmsr   |                                                                                          |
| mtspr   | For all SPRs except CTR, LR, XER. See "Privileged SPRs" on page 3-42                     |
| rfci    |                                                                                          |
| rfi     |                                                                                          |
| tlbia   |                                                                                          |
| tlbre   |                                                                                          |
| tlbsx   |                                                                                          |
| tlbsync |                                                                                          |
| tlbwe   |                                                                                          |
| wrtee   |                                                                                          |
| wrteei  |                                                                                          |

#### 3.9.3 Privileged SPRs

All SPRs are privileged, except for the LR, the CTR, the XER, USPRG0, and read access to SPRG4– SPRG7. Reading from the time base registers Time Base Lower (TBL) and Time Base Upper (TBU) is not privileged. These registers are read using the **mftb** instruction, rather than the **mfspr** instruction. TBL and TBU are written (with different addresses) using **mtspr**, which is privileged for these registers. Except for moves to and from non-privileged SPRs, attempts to execute **mfspr** and **mtspr** instructions while in user mode result in privileged violation program exceptions. In a **mfspr** or **mtspr** instruction, the 10-bit SPRN field specifies the SPR number of the source or destination SPR. The SPRN field contains two five-bit subfields,  $SPRN_{0:4}$  and  $SPRN_{5:9}$ . The assembler handles the unusual register number encoding to generate the SPRF field. In the *machine code* for the **mfspr** and **mtspr** instructions, the SPRN subfields are *reversed* (ending up as  $SPRF_{5:9}$  and  $SPRF_{0:4}$ ) for compatibility with the POWER Architecture.

In the PowerPC Architecture, SPR numbers having a 1 in the most-significant bit of the SPRF field are privileged.

The following example illustrates how SPR numbers appear in assembler language coding and in machine coding of the **mfspr** and **mtspr** instructions.

In assembler language coding, SRR0 is SPR 26. Note that the assembler handles the unusual register number encoding to generate the SPRF field.

mfspr r5,26

When the SPR number is considered as a binary number (0b0000011010), the most-significant bit is 0. However, the machine code for the instruction reverses the subfields, resulting in the following SPRF field: 0b1101000000. The most-significant bit is 1; SRR0 is privileged.

When an SPR number is considered as a hexadecimal number, the second digit of the three-digit hexadecimal number indicates whether an SPR is privileged. If the second digit is odd (1, 3, 5, 7, 9, B, D, F), the SPR is privileged.

For example, the SPR number of SRR0 is 26 (0x01A). The second hexadecimal digit is odd; SRR0 is privileged. In contrast, the LR is SPR 8 (0x008); the second hexadecimal digit is not odd; the LR is non-privileged.

#### 3.9.4 Privileged DCRs

The mtdcr and mfdcr instructions themselves are privileged, in all cases. All DCRs are privileged.

### 3.10 Synchronization

The PPC405GP supports the synchronization operations of the PowerPC Architecture. The following book, chapter, and section numbers refer to related information in *The PowerPC Architecture: A Specification for a New Family of RISC Processors*:

- Book II, Section 1.8.1, "Storage Access Ordering" and "Enforce In-order Execution of I/O"
- Book III, Section 1.7, "Synchronization"
- Book III, Chapter 7, "Synchronization Requirements for Special Registers and Lookaside Buffers"

### 3.10.1 Context Synchronization

The context of a program is the environment (for example, privilege and address translation) in which the program executes. Context is controlled by the content of certain registers, such as the Machine State Register (MSR), and includes the content of all GPRs and SPRs.

An instruction or event is context synchronizing if it satisfies the following requirements:

- 1. All instructions that *precede* a context synchronizing operation must complete in the context that existed *before* the context synchronizing operation.
- 2. All instructions that *follow* a context synchronizing operation must complete in the context that exists *after* the context synchronizing operation.

Such instructions and events are called "context synchronizing operations." In the PPC405GP, these include any interrupt, except a non-recoverable instruction machine check, and the **isync**, **rfci**, **rfi**, and **sc** instructions.

However, context specifically excludes the contents of memory. A context synchronizing operation does not guarantee that subsequent instructions observe the memory context established by previous instructions. To guarantee memory access ordering in the PPC405GP, one must use either an **eieio** instruction or a **sync** instruction. Note that for the PPC405GP, the **eieio** and **sync** instructions are implemented identically. See "Storage Synchronization" on page 3-46.

The contents of DCRs are not considered as part of the processor "context" managed by a context synchronizing operation. DCRs are not part of the processor core, and are analogous to memory-mapped registers. Their context is managed in a manner similar to that of memory contents.

Finally, implementations of the PowerPC Architecture can exempt the machine check exception from context synchronization control. If the machine check exception is exempted, an instruction that *precedes* a context synchronizing operation can cause a machine check exception *after* the context synchronizing operation occurs and additional instructions have completed.

The following scenarios use pseudocode examples to illustrate these limitations of context synchronization. Subsequent text explains how software can further guarantee "storage ordering."

1. Consider the following instruction sequence:

STORE non-cachable to address XYZ isync XYZ instruction

In this sequence, the **isync** instruction does not guarantee that the XYZ instruction is fetched after the STORE has occurred to memory. There is no guarantee which XYZ instruction will execute; either the old version or the new (stored) version might.

2. Consider the following instruction sequence, which assumes that the PPC405GP uses DCRs to provide bus region control:

STORE non-cachable to address XYZ

isync

MTDCR to change a bus region containing XYZ

In this sequence, there is no guarantee that the STORE will occur before the **mtdcr** changing the bus region control DCR. The STORE could fail because of a configuration error.

Consider an interrupt that changes privileged mode. An interrupt is a context synchronizing operation, because interrupts cause the MSR to be updated. The MSR is part of the processor context; the context synchronizing operation guarantees that all instructions that precede the interrupt complete using the preinterrupt value of MSR[PR], and that all instructions that follow the interrupt complete using the postinterrupt value.

Consider, on the other hand, some code that uses **mtmsr** to change the value of MSR[PR], which changes the privileged mode. In this case, the MSR is changed, changing the context. It is possible, for example, that prefetched privileged instructions expect to execute after the **mtmsr** has changed the operating mode from privileged mode to user mode. To prevent privileged instruction program exceptions, the code must execute a context synchronization operation, such as **isync**, immediately after the **mtmsr** instruction to prevent further instruction execution until the **mtmsr** completes.

eieio or sync can ensure that the contents of memory and DCRs are synchronized in the instruction stream. These instructions guarantee storage ordering because all memory accesses that precede eieio or sync are completed before subsequent memory accesses. Neither eieio nor sync guarantee that instruction prefetching is delayed until the eieio or sync completes. The instructions do not cause the prefetch queues to be purged and instructions to be refetched. See "Storage Synchronization" on page 3-46 for more information.

Instruction cache state is part of context. A context synchronization operation is required to guarantee instruction cache access ordering.

3. Consider the following instruction sequence, which is required for creating self-modifying code:

STOREChange data cache contentsdcbstFlush the new data cache contents to memorysyncGuarantee that **dcbst** completes before subsequent instructions beginicbiContext changing operation; invalidates instruction cache contents.isyncContext synchronizing operation; causes refetch using new instruction cache context text and new memory context, due to the previous **sync**.

If software wishes to ensure that all storage accesses are complete before executing a **mtdcr** to change a bus region (Example 2), the software must issue a **sync** after all storage accesses and before the **mtdcr**. Likewise, if the software is to ensure that all instruction fetches after the **mtdcr** use the new bank register contents, the software must issue an **isync**, after the **mtdcr** and before the first instruction that should be fetched in the new context.

**isync** guarantees that all subsequent instructions are fetched and executed using the context established by all previous instructions. **isync** is a context synchronizing operation; **isync** causes all subsequently prefetched instructions to be discarded and refetched.

The following example illustrates the use of **isync** with debug exceptions:

- mtdbcr0 Enable an instruction address compare (IAC) event
- isync Wait for the new Debug Control Register 0 (DBCR0) context to be established
- XYZ This instruction is at the IAC address; an **isync** was necessary to guarantee that the IAC event occurs at the execution of this instruction

#### 3.10.2 Execution Synchronization

For completeness, consider the definition of execution synchronizing as it relates to context synchronization. Execution synchronization is architecturally a subset of context synchronization.

Execution synchronization guarantees that the following requirement is met:

All instructions that *precede* an execution synchronizing operation must complete in the context that existed *before* the execution synchronizing operation.

The following requirement need not be met:

All instructions that *follow* an execution synchronizing operation must complete in the context that exists *after* the execution synchronizing operation.

Execution synchronization ensures that preceding instructions execute in the old context; subsequent instructions might execute in either the new or old context (indeterminate). The PPC405GP provides three execution synchronizing operations: the **eieio**, **mtmsr**, and **sync** instructions.

Because **mtmsr** is execution synchronizing, it guarantees that previous instructions complete using the old MSR value. (For example, using **mtmsr** to change the endian mode.) However, to guarantee that subsequent instructions use the new MSR value, we have to insert a context synchronization operation, such as **isync**.

Note that the PowerPC Architecture requires MSR[EE] (the external interrupt bit) to be, in effect, execution synchronizing: if a **mtmsr** sets MSR[EE] = 1, and an external interrupt is pending, the exception must be taken before the instruction that follows **mtmsr** is executed. However, the **mtmsr** instruction is not a context synchronizing operation, so the PPC405GP does not, for example, discard prefetched instructions and refetch. Note that the **wrtee** and **wrteei** instructions can change the value of MSR[EE], but are not execution synchronizing.

Finally, while **sync** and **eieio** are execution synchronizing, they are also more restrictive in their requirement of memory ordering. Stating that an operation is execution synchronizing does not imply storage ordering. This is an additional specific requirement of **sync** and **eieio**.

#### 3.10.3 Storage Synchronization

The **sync** instruction guarantees that all previous storage references complete with respect to the PPC405GP before the **sync** instruction completes (therefore, before any subsequent instructions begin to execute). The **sync** instruction is execution synchronizing.

Consider the following use of sync:

| stw   | Store to peripheral                 |
|-------|-------------------------------------|
| sync  | Wait for store to actually complete |
| mtdcr | Reconfigure device                  |

The eieio instruction guarantees the order of storage accesses. All storage accesses that precede eieio complete before any storage accesses that follow the instruction, as in the following example:

- stb X Store to peripheral, address X; this resets a status bit in the device
- eieio Guarantee **stb** X completes before next instruction
- Ibz Y Load from peripheral, address Y; this is the status register updated by **stb** X. eieio was necessary, because the read and write addresses are different, but affect each other

The PPC405GP implements both **sync** and **eieio** identically, in the manner described above for **sync**. In the PowerPC Architecture, **sync** can function across all processors in a multiprocessor environment; **eieio** functions only within its executing processor. The PPC405GP does not provide hardware support for multiprocessor memory coherency, so **sync** does not guarantee memory ordering across multiple processors.

## 3.11 Instruction Set

The PPC405GP instruction set contains instructions defined in the PowerPC Architecture and instructions specific to the IBM PowerPC 400 family of embedded processors.

Chapter 24, "Instruction Set," contains detailed descriptions of each instruction.

Appendix A, "Instruction Summary," alphabetically lists each instruction and extended mnemonic and provides a short-form description. Appendix B, "Instructions by Category," provides short-form descriptions of instructions, grouped by the instruction categories listed in Table 3-21, "PPC405GP Instruction Set Summary," on page 3-47.

Table 3-21 summarizes the PPC405GP instruction set functions by categories. Instructions within each category are described in subsequent sections.

| Storage Reference    | load, store                                                                                                     |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------|--|--|
| Arithmetic           | add, subtract, negate, multiply, multiply-accumulate, multiply halfword, divide                                 |  |  |
| Logical              | and, andc, or, orc, xor, nand, nor, xnor, sign extension, count leading zeros                                   |  |  |
| Comparison           | compare, compare logical, compare immediate                                                                     |  |  |
| Branch               | branch, branch conditional, branch to LR, branch to CTR                                                         |  |  |
| CR Logical           | crand, crandc, cror, crorc, crnand, crnor, crxor, crxnor, move CR field                                         |  |  |
| Rotate               | rotate and insert, rotate and mask, shift left, shift right                                                     |  |  |
| Shift                | shift left, shift right, shift right algebraic                                                                  |  |  |
| Cache Management     | invalidate, touch, zero, flush, store, read                                                                     |  |  |
| Interrupt Control    | write to external interrupt enable bit, move to/from MSR, return from interrupt, return from critical interrupt |  |  |
| Processor Management | system call, synchronize, trap, move to/from DCRs, move to/from SPRs, move to/from CR                           |  |  |

#### 3.11.1 Instructions Specific to IBM PowerPC Embedded Processors

To support functions required in embedded real-time applications, the IBM PowerPC 400 family of embedded processors defines instructions that are not defined in the PowerPC Architecture.

Table 3-22 lists the instructions specific to IBM PowerPC embedded processors. Programs using these instructions are not portable to PowerPC implementations that are not part of the IBM PowerPC 400 family of embedded processors.

In the table, the syntax [s] indicates that the instruction has a signed form. The syntax [u] indicates that the instruction has an unsigned form. The syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

| dccci<br>dcread<br>iccci<br>icread | macchw[s][u]<br>machhw[s][u]<br>maclhw[s][u]<br>nmacchw[s]<br>nmachhw[s]<br>nmaclhw[s] | mulchw[u]<br>mulhhw[u]<br>mullhw[u] | mfdcr<br>mtdcr<br>rfci<br>tlbre<br>tlbsx[.]<br>tlbwe<br>wrtee<br>wrteei |
|------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------|
|------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------|

Table 3-22. Implementation-specific Instructions

#### 3.11.2 Storage Reference Instructions

Table 3-23 lists the PPC405GP storage reference instructions. Load/store instructions transfer data between memory and the GPRs. These instructions operate on bytes, halfwords, and words. Storage reference instructions also support loading or storing multiple registers, character strings, and byte-reversed data.

In the table, the syntax "[**u**]" indicates that an instruction has an "update" form that updates the RA addressing register with the calculated address, and a "non-update" form. The syntax "[**x**]" indicates that an instruction has an "indexed" form, which forms the address by adding the contents of the RA and RB GPRs) and a "base + displacement" form (in which the address is formed by adding a 16-bit signed immediate value (included as part of the instruction word) to the contents of RA GPR.

| Loads     |                                 |                             | Stores              |           |                     |                               |                        |
|-----------|---------------------------------|-----------------------------|---------------------|-----------|---------------------|-------------------------------|------------------------|
| Byte      | Halfword                        | Word                        | Multiple/String     | Byte      | Halfword            | Word                          | Multiple/String        |
| lbz[u][x] | lha[u][x]<br>lhbrx<br>lhz[u][x] | lwarx<br>lwbrx<br>lwz[u][x] | lmw<br>Iswi<br>Iswx | stb[u][x] | sth[u][x]<br>sthbrx | stw[u][x]<br>stwbrx<br>stwcx. | stmw<br>stswi<br>stswx |

Table 3-23. Storage Reference Instructions

#### 3.11.3 Arithmetic Instructions

Arithmetic operations are performed on integer operands stored in GPRs. Instructions that perform operations on two operands are defined in a three-operand format; an operation is performed on the operands, which are stored in two GPRs. The result is placed in a third, operand, which is stored in a GPR. Instructions that perform operations on one operand are defined using a two-operand format; the operation is performed on the operand in a GPR and the result is placed in another GPR. Several instructions also have immediate formats in which an operand is contained in a field in the instruction word.

Most arithmetic instructions have versions that can update CR[CR0] and XER[SO, OV], based on the result of the instruction. Some arithmetic instructions also update XER[CA] implicitly. See "Condition Register (CR)" on page 3-12 and "Fixed Point Exception Register (XER)" on page 3-8 for more information.

Table 3-24 lists the PPC405GP arithmetic instructions. In the table, the syntax "[o]" indicates that an instruction has an "o" form that updates XER[SO,OV], and a "non-o" form. The syntax "[-]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

| Add                                                                                              | Subtract                                                                           | Multiply                                      | Divide                    | Negate    |
|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------|---------------------------|-----------|
| add[o][.]<br>addc[o][.]<br>adde[o][.]<br>addi<br>addic[.]<br>addis<br>addme[o][.]<br>addze[o][.] | subf[o][.]<br>subfc[o][.]<br>subfe[o][.]<br>subfic<br>subfme[o][.]<br>subfze[o][.] | mulhw[.]<br>mulhwu[.]<br>mulli<br>mullw[o][.] | divw[o][.]<br>divwu[o][.] | neg[o][.] |

Table 3-24. Arithmetic Instructions

Table 3-25 lists additional arithmetic instructions for multiply-accumulate and multiply halfword operations. In the table, the syntax "[o]" indicates that an instruction has an "o" form that updates XER[SO,OV], and a "non-o" form. The syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

| Multiply-<br>Accumulate                                                                                                                                                           | Negative-<br>Multiply-<br>Accumulate                                                                  | Multiply<br>Halfword                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| macchw[o][.]<br>macchws[o][.]<br>macchws[o][.]<br>machhw[o][.]<br>machhws[o][.]<br>machhws[o][.]<br>machhws[o][.]<br>machws[o][.]<br>machws[o][.]<br>machws[o][.]<br>machws[o][.] | nmacchw[o][.]<br>nmacchws[o][.]<br>nmachhw[o][.]<br>nmachhws[o][.]<br>nmaclhw[o][.]<br>nmaclhws[o][.] | mulchw[.]<br>mulchwu[.]<br>mulhhw[.]<br>mulhhwu[.]<br>mullhw[.]<br>mullhwu[.] |

Table 3-25. Multiply-Accumulate and Multiply Halfword Instructions

### 3.11.4 Logical Instructions

Table 3-26 lists the PPC405GP logical instructions. In the table, the syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

Table 3-26. Logical Instructions

| And                       | And with complement | Nand    | Or                   | Or with complement | Nor    | Xor                     | Equivalence | Extend sign          | Count<br>leading<br>zeros |
|---------------------------|---------------------|---------|----------------------|--------------------|--------|-------------------------|-------------|----------------------|---------------------------|
| and[.]<br>andi.<br>andis. | andc[.]             | nand[.] | or[.]<br>ori<br>oris | orc[.]             | nor[.] | xor[.]<br>xori<br>xoris | eqv[.]      | extsb[.]<br>extsh[.] | cntlzw[.]                 |

#### 3.11.5 Compare Instructions

These instructions perform arithmetic or logical comparisons between two operands and update the CR with the result of the comparison.

Table 3-27 lists the PPC405GP compare instructions.

| Arithmetic | Logical |
|------------|---------|
| cmp        | cmpl    |
| cmpi       | cmpli   |

#### 3.11.6 Branch Instructions

These instructions unconditionally or conditionally branch to an address. Conditional branch instructions can test condition codes set by a previous instruction and branch accordingly. Conditional branch instructions can also decrement and test the CTR as part of branch determination, and can save the return address in the LR.The target address for a branch can be a displacement from the current instruction address (a relative address), an absolute address, or contained in the CTR or LR.

See "Branch Processing" on page 3-34 for more information on branch operations.

Table 3-28 lists the PPC405GP branch instructions. In the table, the syntax "[I]" indicates that the instruction has a "link update" form that updates LR with the address of the instruction after the branch, and a "non-link update" form. The syntax "[a]" indicates that the instruction has an "absolute address" form, in which the target address is formed directly using the immediate field specified as part of the instruction, and a "relative" form, in which the target address is formed by adding the immediate field to the address of the branch instruction).

| Branch                                     |
|--------------------------------------------|
| b[l][a]<br>bc[l][a]<br>bcctr[l]<br>bclr[l] |

#### Table 3-28. Branch Instructions

#### 3.11.6.1 CR Logical Instructions

These instructions perform logical operations on a specified pair of bits in the CR, placing the result in another specified bit. These instructions can logically combine the results of several comparisons without incurring the overhead of conditional branch instructions. Software performance can significantly improve if multiple conditions are tested at once as part of a branch decision.

Table 3-29 lists the PPC405GP condition register logical instructions.

| Table 3-29. | CR | Logical | Instructions |
|-------------|----|---------|--------------|
|-------------|----|---------|--------------|

| crand  | crnor |
|--------|-------|
| crandc | cror  |
| creqv  | crorc |
| crnand | crxor |
|        | mcrf  |
|        |       |

#### 3.11.6.2 Rotate Instructions

These instructions rotate operands stored in the GPRs. Rotate instructions can also mask rotated operands.

Table 3-30 lists the PPC405GP rotate instructions. In the table, the syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

| Table 3-30. | Rotate | Instructions |
|-------------|--------|--------------|
|-------------|--------|--------------|

| Rotate and Insert | Rotate and Mask       |
|-------------------|-----------------------|
| rlwimi[.]         | rlwinm[.]<br>rlwnm[.] |

#### 3.11.6.3 Shift Instructions

These instructions rotate operands stored in the GPRs.

Table 3-31 lists the PPC405GP shift instructions. Shift right algebraic instructions implicitly update XER[CA]. In the table, the syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

| Shift Left | Shift Right | Shift Right<br>Algebraic |
|------------|-------------|--------------------------|
| slw[.]     | srw[.]      | sraw[.]<br>srawi[.]      |

#### 3.11.6.4 Cache Management Instructions

These instructions control the operation of the ICU and DCU. Instructions are provided to fill or invalidate instruction cache blocks. Instructions are also provided to fill, flush, invalidate, or zero data cache blocks, where a block is defined as a 32-byte cache line.

Table 3-32 lists the PPC405GP cache management instructions.

Table 3-32. Cache Management Instructions

| DCU                                                                        | ICU                             |
|----------------------------------------------------------------------------|---------------------------------|
| dcba<br>dcbf<br>dcbl<br>dcbst<br>dcbt<br>dcbtst<br>dcbtst<br>dcbz<br>dccci | icbi<br>icbt<br>iccci<br>icread |
| dcread                                                                     |                                 |

#### 3.11.7 Interrupt Control Instructions

**mfmsr** and **mtmsr** read and write data between the MSR and a GPR to enable and disable interrupts. **wrtee** and **wrteei** enable and disable external interrupts. **rfi** and **rfci** return from interrupt handlers. Table 3-33 lists the PPC405GP interrupt control instructions.

#### Table 3-33. Interrupt Control Instructions

| 1 | mfmsr  |
|---|--------|
|   | mtmsr  |
|   | rfi    |
|   | rfci   |
|   | wrtee  |
|   | wrteei |
|   |        |

## 3.11.8 TLB Management Instructions

The TLB management instructions read and write entries of the TLB array in the MMU, search the TLB array for an entry which will translate a given address, and invalidate all TLB entries. There is also an instruction for synchronizing TLB updates with other processors, but because the PPC405GP is for use in uniprocessor environments, this instruction performs no operation.

Table 3-34 lists the TLB management instructions. In the table, the syntax "[.]" indicates that the instruction has a "record" form that updates CR[CR0], and a "non-record" form.

#### Table 3-34. TLB Management Instructions

| tlbia    |
|----------|
| tibre    |
| tlbsx[.] |
| tlbsync  |
| tlbwe    |
|          |

#### 3.11.9 Processor Management Instructions

These instructions move data between the GPRs and SPRs, the CR, and DCRs in the PPC405GP, and provide traps, system calls, and synchronization controls.

Table 3-35 lists the processor management instructions in the PPC405GP.

#### Table 3-35. Processor Management Instructions

| eieio<br>isync<br>sync | mcrxr<br>mfcr<br>mfdcr<br>mfspr | mtcrf<br>mtdcr<br>mtspr<br>sc<br>tw<br>twi |
|------------------------|---------------------------------|--------------------------------------------|
|------------------------|---------------------------------|--------------------------------------------|

#### 3.11.10 Extended Mnemonics

In addition to mnemonics for instructions supported directly by hardware, the PowerPC Architecture defines numerous *extended mnemonics*.

An extended mnemonic translates directly into the mnemonic of a hardware instruction, typically with carefully specified operands. For example, the PowerPC Architecture does not define a "shift right word immediate" instruction, because the "rotate left word immediate then AND with mask," (rlwinm) instruction can accomplish the same result:

#### rlwinm RA,RS,32-n,n,31

However, because the required operands are not obvious, the PowerPC Architecture defines an extended mnemonic:

#### srwi RA,RS,n

Extended mnemonics transfer the problem of remembering complex or frequently used operand combinations to the assembler, and can more clearly reflect a programmer's intentions. Thus, programs can be more readable.

Refer to the following chapter and appendixes for lists of the extended mnemonics:

- Chapter 24, "Instruction Set," lists extended mnemonics under the associated hardware instruction mnemonics.
- Appendix A, "Instruction Summary," lists extended mnemonics alphabetically, along with the hardware instruction mnemonics.
- Table B-5 in Appendix B, "Instructions by Category," lists all extended mnemonics.

3-54 PPC405GP User's Manual

# Chapter 4. Cache Operations

The PPC405GP incorporates two internal caches, a16KB instruction cache and an 8KB data cache. Instructions and data can be accessed in the caches much faster than in main memory.

The instruction cache unit (ICU) controls instruction accesses to main memory and stores frequently used instructions to reduce the overhead of instruction transfers between the instruction pipeline and external memory. Using the instruction cache minimizes access latency for frequently executed instructions.

The data cache unit (DCU) controls data accesses to main memory and stores frequently used data to reduce the overhead of data transfers between the GPRs and external memory. Using the data cache minimizes access latency for frequently used data.

The ICU features:

- Programmable address pipelining and prefetching for cache misses and non-cachable lines
- Support for non-cachable hits from lines contained in fill buffer
- Programmable non-cachable requests to memory as 4 or 8 words (line or half line)
- Bypass path for critical words
- · Non-blocking cache for hits during fills
- Flash invalidate (one instruction invalidates entire cache)
- Programmable allocation for fetch fills, enabling program control of cache contents using the **icbt** instruction
- · Virtually indexed, physically tagged cache arrays
- Support for 64-bit and 32-bit PLB slaves
- A rich set of cache control instructions

The DCU features:

- Address pipelining for line fills
- · Support for load hits from non-cachable and non-allocated lines contained in fill buffer
- · Bypass path for critical words
- · Non-blocking cache for hits during fills
- · Write-back and write-through write strategies controlled by storage attributes
- Programmable non-cachable load requests to memory as lines or words.
- · Handling of up to two pending line flushes.
- · Holding of up to three stores before stalling the core pipeline
- · Physically indexed, physically tagged cache arrays
- · Support for 64-bit and 32-bit PLB slaves
- A rich set of cache control instructions

"ICU Organization" on page 4-2 and "DCU Organization" on page 4-5 describe the organization and provide overviews of the ICU and the DCU.

# 4.1 ICU Organization

The ICU manages instruction transfers between external cachable memory and the instruction queue in the execution unit.

The ICU contains a two-way set-associative 16KB cache memory. Each way is organized in 256 lines of eight words (eight instructions) each.

As shown in Table 4-1, tag ways A and B store instruction address bits  $A_{0:21}$  for each line in cache ways A and B. Instruction address bits  $A_{19:26}$  serve as the index to the cache array. The two cache lines that correspond to the same line index (one in each way) are called a congruence class.

| Tags (Two-way Set)           |                              | Instructions (Two-way Set) |            |
|------------------------------|------------------------------|----------------------------|------------|
| Way A                        | Way B                        | Way A                      | Way B      |
| A <sub>0:21</sub> Line 0 A   | A <sub>0:21</sub> Line 0 B   | Line 0 A                   | Line 0 B   |
| A <sub>0:21</sub> Line 1 A   | A <sub>0:21</sub> Line 1 B   | Line 1 A                   | Line 1 B   |
| •                            | •                            | •                          | •          |
| A <sub>0:21</sub> Line 254 A | A <sub>0:21</sub> Line 254 B | Line 254 A                 | Line 254 B |
| A <sub>0:21</sub> Line 255 A | A <sub>0:21</sub> Line 255 B | Line 255 A                 | Line 255 B |

 Table 4-1. Instruction Cache Organization

When a cache line is to be loaded, the cache way to receive the line is determined by using an leastrecently-used (LRU) policy. The index, determined by the instruction address, selects a congruence class. Within a congruence class, the line which was accessed most recently is retained, and the other line is marked as LRU, using an LRU bit in the tag array. The line to receive the incoming data is the LRU line. After the cache line fill, the LRU bit is then set to identify as least-recently-used the line opposite the line just filled. Figure 4-1 shows the relationships between the ICU and the instruction pipeline.



Figure 4-1. Instruction Flow

### 4.1.1 ICU Operations

Instructions from cachable memory regions are copied into the instruction cache array. The fetcher can access instructions much more quickly from a cache array than from memory. Cache lines are loaded either target-word-first or sequentially. Target-word-first fills start at the requested word, continue to the end of the line, and then wrap to fill the remaining words at the beginning of the line. Sequential fills start at the first word of the cache line and proceed sequentially to the last word of the line.

The bypass path handles instructions in cache-inhibited memory and improves performance during line fill operations. If a request from the fetcher obtains an entire line from memory, the queue does not have to wait for the entire line to reach the cache. The target word (the word requested by the fetcher) is sent on the bypass path to the queue while the line fill proceeds, even if the selected line fill order is not target-word-first.

Cache line fills always run to completion, even if the instruction stream branches away from the rest of the line. As requested instructions are received, they go to the fetcher from the fill register before the line fills in the cache. The filled line is always placed in the ICU; if an external memory subsystem error occurs during the fill, the line is not written to the cache. During a clock cycle, the ICU can send two instruction to the fetcher.

## 4.1.2 Instruction Cachability Control

When instruction address translation is enabled (MSR[IR] = 1), instruction cachability is controlled by the I storage attribute in the translation lookaside buffer (TLB) entry for the memory page. If TLB\_entry[I] = 1, caching is inhibited; otherwise caching is enabled. Cachability is controlled separately for each page, which can range in size from 1KB to 16MB. "Translation Lookaside Buffer (TLB)" on page 6-2 describes the TLB.

When instruction address translation is disabled (MSR[IR] = 0), instruction cachability is controlled by the Instruction Cache Cachability Register (ICCR). Each field in the ICCR (ICCR[S0:S31]) controls the cachability of a 128MB region (see "Real-mode Storage Attribute Control" on page 6-17). If ICCR[S*n*] = 1, caching is enabled for the specified region; otherwise, caching is inhibited.

The performance of the PPC405GP is significantly lower while fetching instructions from cacheinhibited regions.

Following system reset, address translation is disabled and all ICCR bits are reset to 0 so that no memory regions are cachable. Before regions can be designated as cachable, the ICU cache array must be invalidated. The **iccci** instruction must execute before the cache is enabled. Address translation can then be enabled, if required, and the TLB or the ICCR can then be configured for the required cachability.

### 4.1.3 Instruction Cache Synonyms

The following information applies only if instruction address translation is enabled (MSR[IR] = 1) and 1KB or 4KB page sizes are used. See Chapter 6, "Memory Management," for information about address translation and page sizes.

An instruction cache synonym occurs when the instruction cache array contains multiple cache lines from the same real address. Such synonyms result from combinations of:

- · Cache array size
- · Cache associativity
- Page size
- The use of effective addresses (EAs) to index the cache array

For example, the instruction cache array has a "way size" of 8KB (16KB array/2 ways). Thus, 11 bits  $(EA_{19:29})$  are needed to select a word (instruction) in each way. For the minimum page size of 1KB, the low order 8 bits  $(EA_{22:29})$  address a word in a page. The high order address bits  $(EA_{0:21})$  are translated to form a real address (RA), which the ICU uses to perform the cache tag match. Cache synonyms could occur because the index bits  $(EA_{19:29})$  overlap the translated RA bits. For 1KB pages, overlap in  $EA_{19:21}$  and  $RA_{19:21}$  could result in as many as 8 synomyms. In other words, data from the same RA could occur as as manyas 8 llocations in the cache array. Similarly, for 4KB pages,  $EA_{0:19}$  are translated. Differences in  $EA_{19}$  and  $RA_{19}$  could result in as many as 2 synonyms. For the next largest page size (16KB), only  $EA_{0:17}$  are translated. Because there is no overlap with index bits  $EA_{19:21}$ , synonyms do not occur.

In practice, cache synonyms occur when a real instruction page having multiple virtual mappings exists in multiple cache lines. For 1KB pages, all EAs differing in  $EA_{19:21}$  must be cast out of cache, using an **icbi** instruction for each such EA (up to 8 per cache line in the page). For 4KB pages, all EAs differing in EA<sub>19</sub> must be cast out in the same manner (up to 2 per cache line in the page). For larger pages, cache synonyms do not occur, and casting out any of the multiple EAs removes the physical information from the cache.

**Programming Note:** To prevent the occurrence of cache synonyms, use only page sizes greater than the cache way size (8KB), if possible. For the PPC405GP, the minimum such page size is 16KB.

#### 4.1.4 ICU Coherency

The ICU does not "snoop" external memory or the DCU. Programmers must follow special procedures for ICU synchronization when self-modifying code is used or if a peripheral device updates memory containing instructions.

The following code example illustrates the necessary steps for self-modifying code. This example assumes that *addr1* is both data and instruction cachable.

| stw   | regN, addr1 | # the data in regN is to become an instruction at addr1 |
|-------|-------------|---------------------------------------------------------|
| dcbst | addr1       | # forces data from the data cache to memory             |
| sync  |             | # wait until the data actually reaches the memory       |
| icbi  | addr1       | # the previous value at addr1 might already be in       |
|       |             | the instruction cache; invalidate it in the cache       |
| isync |             | # the previous value at addr1 may already have been     |
|       |             | pre-fetched into the queue; invalidate the queue        |
|       |             | so that the instruction must be re-fetched              |

## 4.2 DCU Organization

The DCU manages data transfers between external cachable memory and the general-purpose registers in the execution unit.

The DCU contains a two-way set-associative 8KB1KB cache memory. Each way is organized in 128 lines of eight words (32 bytes) each.

As shown in Table 4-2, tag ways A and B store data address bits  $A_{0:19}$  for each line in cache ways A and B. Data address bits  $A_{20:26}$  serve as the index to the cache array. The two cache lines that correspond to the same line index (one in each way) are called a congruence class.

| Tags (Two-way Set)           |                              | Data (Two-way Set) |            |
|------------------------------|------------------------------|--------------------|------------|
| Way A                        | Way B                        | Way A              | Way B      |
| A <sub>0:19</sub> Line 0 A   | A <sub>0:19</sub> Line 0 B   | Line 0 A           | Line 0 B   |
| A <sub>0:19</sub> Line 1 A   | A <sub>0:19</sub> Line 1 B   | Line 1 A           | Line 1 B   |
| •                            | •                            | •                  | •          |
| A <sub>0:19</sub> Line 126 A | A <sub>0:19</sub> Line 126 B | Line 126 A         | Line 126 B |
| A <sub>0:19</sub> Line 127 A | A <sub>0:19</sub> Line 127 B | Line 127 A         | Line 127 B |

#### Table 4-2. Data Cache Organization

When a cache line is to be loaded, the cache way to receive the line is determined by using an LRU policy. The index, determined by the data address, selects a congruence class. Within a congruence class, the line which was accessed most recently is retained, and the other line is marked as LRU, using an LRU bit in the tag array. The line to receive the incoming data is the LRU line. After the cache line fill, the LRU bit is then set to identify as least-recently-used the line opposite the line just filled.

A bypass path handles data operations in cache-inhibited memory and improves performance during line fill operations.

## 4.2.1 DCU Operations

Data from cachable memory regions are copied from external memory into lines in the data cache array so that subsequent cache operations result in cache hits. Loads and stores that hit in the DCU are completed in one cycle. For loads, GPRs receive the requested byte, halfword, or word of data from the data cache array. The DCU supports byte-writeability to improve the performance of byte and halfword store operations.

Cache operations require a line fill when they require data from cachable memory regions that are not currently in the DCU. A line fill is the movement of a cache line (eight words) from external memory to the data cache array. Eight words are copied from external memory into the fill buffer, either target-word-first or sequentially. Loading order is controlled by the PLB slave. Target-word-first fills start at the requested word, continue to the end of the line, and then wrap to fill the remaining words at the beginning of the line. Sequential fills start at the first word of the cache line and proceed sequentially to the last word of the line. In both types of fills, the fill buffer, when full, is transferred to the data cache array. The cache line is marked valid when it is filled.

Loads that result in a line fill, and loads from non-cachable memory, are sent to a GPR. The requested byte, halfword, or word is sent from the DCU to the GPR from the fill buffer, using a cache bypass mechanism. Additional loads for data in the fill buffer can be bypassed to the GPR until the data is moved into the data array.

Stores that result in a line fill have their data held in the fill buffer until the line fill completes. Additional stores to the line being filled will also have their data placed in the fill buffer before being transferred into the data cache array.

To complete a line fill, the DCU must access the tag and data arrays. The tag array is read to determine the tag addresses, the LRU line, and whether the LRU line is dirty. A dirty cache line is one that was accessed by a store instruction after the line was established, and can be inconsistent with external memory. If the line being replaced is dirty, the address and the cache line must be saved so that external memory can be updated. During the cache line fill, the LRU bit is set to identify the line opposite the line just filled as LRU.

When a line fill completes and replaces a dirty line, a line flush begins. A flush copies updated data in the data cache array to main storage. Cache flushes are always sequential, starting at the first word of the cache line and proceeding sequentially to the end of the line.

Cache lines are always completely flushed or filled, even if the program does not request the rest of the bytes in the line, or if a bus error occurs after a bus interface unit accepts the request for the line fill. If a bus error occurs during a line fill, the line is filled and the data is marked valid. However, the line can contain invalid data, and a machine check exception occurs.

## 4.2.2 DCU Write Strategies

DCU operations can use write-back or write-through strategies to maintain coherency with external cachable memory.

The write-back strategy updates only the data cache, not external memory, during store operations. Only modified data lines are flushed to external memory, and then only when necessary to free up locations for incoming lines, or when lines are explicitly flushed using **dcbf** or **dcbst** instructions. The write-back strategy minimizes the amount of external bus activity and avoids unnecessary contention for the external bus between the ICU and the DCU.

The write-back strategy is contrasted with the write-through strategy, in which stores are written simultaneously to the cache and to external memory. A write-through strategy can simplify maintaining coherency between cache and memory.

When data address translation is enabled (MSR[DR] = 1), the W storage attribute in the TLB entry for the memory page controls the write strategy for the page. If TLB\_entry[W] = 0, write-back is selected; otherwise, write-through is selected. The write strategy is controlled separately for each page. "Translation Lookaside Buffer (TLB)" on page 6-2 describes the TLB.

When data address translation is disabled (MSR[DR] = 0), the Data Cache Write-through Register (DCWR) sets the storage attribute. Each bit in the DCWR (DCWR[W0:W31]) controls the write strategy of a 128MB storage region (see "Real-mode Storage.Attribute Control" on page 6-17). If DCWR[Wn] = 0, write-back is enabled for the specified region; otherwise, write-through is enabled.

**Programming Note:** The PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited.

### 4.2.3 DCU Load and Store Strategies

The DCU can control whether a load receives one word or one line of data from main memory.

For cachable memory, the load without allocate (LWOA) field of the CCR0 controls the type of load resulting from a load miss. If CCR0[LWOA] = 0, a load miss causes a line fill. If CCR0[LWOA] = 1, load misses do not result in a line fill, but in a word load from external memory. For infrequent reads of non-contiguous memory, setting CCR0[LWOA] = 1 may provide a small performance improvement.

For non-cachable memory and for loads misses when CCR0[LWOA] = 1, the load word as line (LWL) field in the CCR0 affects whether load misses are satisfied with a word, or with eight words (the equivalent of a cache line) of data. If CCR0[LWL] = 0, only the target word is bypassed to the core. If CCR0[LWL] = 1, the DCU saves eight words (one of which is the target word) in the fill buffer and bypasses the target data to the core to satisfy the load word request. The fill buffer is not written to the data cache array.

Setting CCR0[LWL] = 1 provides the fastest accesses to sequential non-cachable memory. Subsequent loads from the same line are bypassed to the core from the fill buffer and do not result in additional external memory accesses. The load data remains valid in the fill buffer until one of the following occurs: the beginning of a subsequent load that requires the fill buffer, a store to the target address, a **dcbi** or **dccci** instruction issued to the target address, or the execution of a **sync** instruction. Non-cachable loads to guarded storage never cause a line transfer on the PLB even if CCR0[LWL] = 1. Subsequent loads to the same non-cachable storage are always requested again from the PLB.

For cachable memory, the store without allocate (SWOA) field of the CCR0 controls the type of store resulting from a store miss. If CCR0[SWOA] = 0, a store miss causes a line fill. If CCR0[SWOA] = 1, store misses do not result in a line fill, but in a single word store to external memory.

### 4.2.4 Data Cachability Control

When data address translation is disabled (MSR[DR] = 0), data cachability is controlled by the Data Cache Cachability Register (DCCR). Each bit in the DCCR (DCCR[S0:S31]) controls the cachability of a 128MB region (see "Real-mode Storage Attribute Control" on page 6-17). If DCCR[Sn] = 1, caching is enabled for the specified region; otherwise, caching is inhibited.

When data address translation is enabled (MSR[DR] = 1), data cachability is controlled by the I bit in the TLB entry for the memory page. If TLB\_entry[I] = 1, caching is inhibited; otherwise caching is enabled. Cachability is controlled separately for each page, which can range in size from 1KB to 16MB. "Translation Lookaside Buffer (TLB)" on page 6-2 describes the TLB.

**Programming Note:** The PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited.

The performance of the PPC405GP is significantly lower while accessing memory in cache-inhibited regions.

Following system reset, address translation is disabled and all DCCR bits are reset to 0 so that no memory regions are cachable. The **dccci** instruction must execute 128before regions can be designated as cachable. This invalidates all congruence classes before enabling the cache. Address translation can then be enabled, if required, and the TLB or the DCCR can then be configured for the desired cachability.

**Programming Note:** If a data block corresponding to the effective address (EA) exists in the cache, but the EA is non-cachable, loads and stores (including **dcbz**) to that address are considered programming errors (the cache block should previously have been flushed). The only instructions that can legitimately access such an EA in the data cache are the cache management instructions **dcbf**, **dcbi**, **dcbst**, **dcbt**, **dcbtst**, **dccci**, and **dcread**.

#### 4.2.5 DCU Coherency

The DCU does not provide snooping. Application programs must carefully use cache-inhibited regions and cache control instructions to ensure proper operation of the cache in systems where external devices can update memory.

## 4.3 Cache Instructions

For detailed descriptions of the instructions described in the following sections, see Chapter 24, "Instruction Set."

In the instruction descriptions, the term "block" is synonymous with cache line. A block is the unit of storage operated on by all cache block instructions.

#### 4.3.1 ICU Instructions

The following instructions control instruction cache operations:

| icbi   | Instruction Cache Block Invalidate                                                                                                                                                                                                 |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Invalidates a cache block.                                                                                                                                                                                                         |
| icbt   | Instruction Cache Block Touch                                                                                                                                                                                                      |
|        | Initiates a block fill, enabling a program to begin a cache block fetch before the program needs an instruction in the block.                                                                                                      |
|        | The program can subsequently branch to the instruction address and fetch the instruction without incurring a cache miss.                                                                                                           |
|        | This is a privileged instruction.                                                                                                                                                                                                  |
| iccci  | Instruction Cache Congruence Class Invalidate                                                                                                                                                                                      |
|        | Invalidates the instruction cache array.                                                                                                                                                                                           |
|        | This is a privileged instruction.                                                                                                                                                                                                  |
| icread | Instruction Cache Read                                                                                                                                                                                                             |
|        | Reads either an instruction cache tag entry or an instruction word from an instruction cache line, typically for debugging. Fields in CCR0 control instruction behavior (see "Cache Control and Debugging Features" on page 4-11). |
|        | This is a privileged instruction.                                                                                                                                                                                                  |

This is a privileged instruction.

## 4.3.2 DCU Instructions

Data cache flushes and fills are triggered by load, store and cache control instructions. Cache control instructions are provided to fill, flush, or invalidate cache blocks.

The following instructions control data cache operations.

| dcba   | Data Cache Block Allocate                                                                                                                                  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Speculatively establishes a line in the cache and marks the line as modified.                                                                              |
|        | If the line is not currently in the cache, the line is established and marked as modified without actually filling the line from external memory.          |
|        | If dcba references a non-cachable address, dcba is treated as a no-op.                                                                                     |
|        | If dcba references a cachable address, write-through required (which would otherwise cause an alignment exception), <b>dcba</b> is treated as a no-op.     |
| dcbf   | Data Cache Block Flush                                                                                                                                     |
|        | Flushes a line, if found in the cache and marked as modified, to external memory; the line is then marked invalid.                                         |
|        | If the line is found in the cache and is not marked modified, the line is marked invalid<br>but is not flushed.                                            |
|        | This operation is performed regardless of whether the address is marked cachable.                                                                          |
| dcbi   | Data Cache Block Invalidate                                                                                                                                |
|        | Invalidates a block, if found in the cache, regardless of whether the address is marked cachable. Any modified data is not flushed to memory.              |
|        | This is a privileged instruction.                                                                                                                          |
| dcbst  | Data Cache Block Store                                                                                                                                     |
|        | Stores a block, if found in the cache and marked as modified, into external memory; the block is not invalidated but is no longer marked as modified.      |
|        | If the block is marked as not modified in the cache, no operation is performed.                                                                            |
|        | This operation is performed regardless of whether the address is marked cachable.                                                                          |
| dcbt   | Data Cache Block Touch                                                                                                                                     |
|        | Fills a block with data, if the address is cachable and the data is not already in the cache. If the address is non-cachable, this instruction is a no-op. |
| dcbtst | Data Cache Block Touch for Store                                                                                                                           |
|        | Implemented identically to the <b>dcbt</b> instruction for compatibility with compilers and other tools.                                                   |

| dcbz   | Data Cache Block Set to Zero                                                                                                                                                                                                                                                                                                                |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | Fills a line in the cache with zeros and marks the line as modified.                                                                                                                                                                                                                                                                        |
|        | If the line is not currently in the cache (and the address is marked as cachable and<br>non-write-through), the line is established, filled with zeros, and marked as modified<br>without actually filling the line from external memory. If the line is marked as either<br>non-cachable or write-through, an alignment exception results. |
| dccci  | Data Cache Congruence Class Invalidate                                                                                                                                                                                                                                                                                                      |
|        | Invalidates a congruence class (both cache ways).                                                                                                                                                                                                                                                                                           |
|        | This is a privileged instruction.                                                                                                                                                                                                                                                                                                           |
| dcread | Data Cache Read                                                                                                                                                                                                                                                                                                                             |
|        | Reads either a data cache tag entry or a data word from a data cache line, typically for debugging. Bits in CCR0 control instruction behavior (see "Cache Control and Debugging Features" on page 4-11).                                                                                                                                    |

This is a privileged instruction.

# 4.4 Cache Control and Debugging Features

Registers and instructions are provided to control cache operation and help debug cache problems. For ICU debug, the **icread** instruction and the Instruction Cache Debug Data Register (ICDBDR) are provided. See "ICU Debugging" on page 4-14 for more information. For DCU debug, the **dcread** instruction is provided. See "DCU Debugging" on page 4-15 for more information.

CCR0 controls the behavior of the icread and the dcread instructions.



| Figure 4-2. Cor | e Configuration | Register 0 | (CCR0) |
|-----------------|-----------------|------------|--------|
|-----------------|-----------------|------------|--------|

| 0:5 | and manager | Reserved                                                                                                                                                                                                                                                  |
|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | LWL         | Load Word as Line<br>0 The DCU performs load misses or non-<br>cachable loads as words, halfwords, or<br>bytes, as requested<br>1 For load misses or non-cachable loads,<br>the DCU moves eight words (including<br>the target word) into the line buffer |

| 7     | LWOA | Load Without Allocate<br>0 Load misses result in line fills<br>1 Load misses do not result in a line fill, but<br>in non-cachable loads                                           |                                                          |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| 8     | SWOA | Store Without Allocate<br>0 Store misses result in line fills<br>1 Store misses do not result in line fills, but<br>in non-cachable stores                                        |                                                          |
| 9     | DPP1 | DCU PLB Priority Bit 1<br>0 DCU PLB priority 0 on bit 1<br>1 DCU PLB priority 1 on bit 1                                                                                          | Note: DCU logic dynamically controls DCU priority bit 0. |
| 10:11 | IPP  | ICU PLB Priority Bits 0:1<br>00 Lowest ICU PLB priority<br>01 Next to lowest ICU PLB priority<br>10 Next to highest ICU PLB priority<br>11 Highest ICU PLB priority               |                                                          |
| 12:13 |      | Reserved                                                                                                                                                                          | ·                                                        |
| 14    | U0XE | Enable U0 Exception<br>0 Enables the U0 exception<br>1 Disables the U0 exception                                                                                                  |                                                          |
| 15    | LDBE | Load Debug Enable<br>0 Load data is invisible on data-side (on-<br>chip memory (OCM)<br>1 Load data is visible on data-side OCM                                                   |                                                          |
| 16:19 |      | Reserved                                                                                                                                                                          |                                                          |
| 20    | PFC  | <ul> <li>ICU Prefetching for Cachable Regions</li> <li>0 Disables prefetching for cachable regions</li> <li>1 Enables prefetching for cachable regions</li> </ul>                 |                                                          |
| 21    | PFNC | <ul> <li>ICU Prefetching for Non-Cachable Regions</li> <li>0 Disables prefetching for non-cachable regions</li> <li>1 Enables prefetching for non-cachable regions</li> </ul>     |                                                          |
| 22    | NCRS | Non-cachable ICU request size<br>0 Requests are for four-word lines<br>1 Requests are for eight-word lines                                                                        |                                                          |
| 23    | FWOA | <ul><li>Fetch Without Allocate</li><li>0 An ICU miss results in a line fill.</li><li>1 An ICU miss does not cause a line fill,<br/>but results in a non-cachable fetch.</li></ul> |                                                          |
| 24:26 |      | Reserved                                                                                                                                                                          |                                                          |
| 27    | CIS  | Cache Information Select<br>0 Information is cache data.<br>1 Information is cache tag.                                                                                           |                                                          |
| 28:30 |      | Reserved                                                                                                                                                                          |                                                          |

| 31 | CWS | Cache Way Select  |
|----|-----|-------------------|
|    |     | 0 Cache way is A. |
|    |     | 1 Cache way is B. |

# 4.4.1 CCR0 Programming Guidelines

Several fields in CCR0 affect ICU and DCU operation. Altering these fields while the cache units are involved in PLB transfers can cause errant operation, including a processor hang.

To guarantee correct ICU and DCU operation, specific code sequences must be followed when altering CCR0 fields.

CCR0[IPP, FWOA] affect ICU operation. When these fields are altered, execution of the following code sequence (Sequence 1) is required.

```
! SEQUENCE 1 Altering CCR0[IPP, FWOA]
    ! Turn off interrupts
    mfmsr
              RM
    addis
              RZ,r0,0x0002 ! CE bit
    ori
              RZ,RZ,0x8000 ! EE bit
                           ! Turn off MSR[CE,EE]
    andc
              RZ,RM,RZ
    mtmsr
              RZ
    ! sync
    svnc
    ! Touch code sequence into i-cache
    addis
              RX,r0,seq1@h
    ori
              RX,RX,seq1@I
    icbt
               r0.RX
! Call function to alter CCR0 bits
    b sea1
back:
! Restore MSR to original value
    mtmsr
              RM
! The following function must be in cacheable memory
               ! Align CCR0 altering code on a cache line boundary.
    .align 5
    seq1:
    icbt
              r0.RX
                              ! Repeat ICBT and execute an ISYNC to guarantee CCR0
    isync
                              ! altering code has been completely fetched across the PLB.
    mfspr
              RN.CCR0
                            ! Read CCR0.
    andi/ori RN,RN,0xXXXX ! Execute and/or function to change any CCR0 bits.
                             ! Can use two instructions before having to touch
                             ! in two cache lines.
```

mtspr CCR0, RN ! Update CCR0.

isync ! Refetch instructions under new processor context.

b back ! Branch back to initialization code.

CCR0[DPP1, U0XE] affect DCU operation. When these fields are altered, execution of the following code sequence (Sequence 2) is required. Note that Sequence 1 includes Sequence 2, so Sequence 1 can be used to alter any CCR0 fields.

In the following sample code, registers RN, RM, RX, and RZ are any available GPRs.

! SEQUENCE 2 Alter CCR0[DPP1, U0XE) ! Turn off interrupts mfmsr ' RM addis RZ.r0.0x0002 ! CE bit ori RZ.RZ.0x8000 ! EE bit andc RZ.RM.RZ ! Turn off MSR[CE,EE] mtmsr RZ ! sync sync ! Alter CCR0 bits mfspr ! Read CCR0. RN.CCR0 andi/ori RN,RN,0xXXXX ! Execute and/or function to change any CCR0 bits. mtspr CCR0, RN ! Update CCR0. isync ! Refetch instructions under new processor context. I Restore MSR to original value mtmsr RM CCR0[CIS, CWS] do not require special programming.

# 4.4.2 ICU Debugging

The **icread** instruction enables the reading of the instruction cache entries for the congruence class specified by EA<sub>19:26</sub>. The cache information is read into the ICDBDR; from there it can subsequently be moved, using a **mfspr** instruction, into a GPR.

0

| Figure 4-3. Instruction Cache Debug Dat | a Register ( | (ICDBDR) |
|-----------------------------------------|--------------|----------|
|-----------------------------------------|--------------|----------|

| 0:31 | Instruction cache information | See icread, page 24-68. |
|------|-------------------------------|-------------------------|
|      | <br>                          |                         |

31

ICU tag information is placed into the ICDBDR as shown:

| 0:21  | TAG                    | Cache Tag                                               |  |
|-------|------------------------|---------------------------------------------------------|--|
| 22:26 | alari<br>Alari         | Reserved                                                |  |
| 27    | V                      | Cache Line Valid<br>0 Not valid<br>1 Valid              |  |
| 28:30 | n fan Bry<br>Hynnesser | Reserved                                                |  |
| 31    | LRU                    | Least Recently Used (LRU)<br>0 A-way LRU<br>1 B-way LRU |  |

If CCR0[CIS] = 0, the data is a word of ICU data from the addressed line, specified by  $EA_{27:29}$ . If CCR0[CWS] = 0, the data is from the A-way; otherwise; the data from the B-way.

If CCR0[CIS] = 1, the cache information is the cache tag. If CCR0[CWS] = 0, the tag is from the A-way; otherwise, the tag is from the B-way.

**Programming Note:** The instruction pipeline does not wait for data from an **icread** instruction to arrive before attempting to use the contents the ICDBDR. The following code sequence ensures proper results:

icread r5,r6# read cache information isync # ensure completion of icread mficdbdr r7# move information to GPR

# 4.4.3 DCU Debugging

The **dcread** instruction provides a debugging tool for reading the data cache entries for the congruence class specified by  $EA_{20:26}$ . The cache information is read into a GPR.

If CCR0[CIS] = 0, the data is a word of DCU data from the addressed line, specified by  $EA_{27:29}$ . If CCR0[CWS] = 0, the data is from the A-way; otherwise; the data is from the B-way.

If CCR0[CIS] = 1, the cache information is the cache tag. If CCR0[CWS] = 0, the tag is from the A-way; otherwise the tag is from the B-way.

DCU tag information is placed into the GPR as shown:

| 0:19  | TAG | Cache Tag                                               |                                       |
|-------|-----|---------------------------------------------------------|---------------------------------------|
| 20:25 |     | Reserved                                                | · · · · · · · · · · · · · · · · · · · |
| 26    | D   | Cache Line Dirty<br>0 Not dirty<br>1 Dirty              | · ·                                   |
| 27    | V   | Cache Line Valid<br>0 Not valid<br>1 Valid              |                                       |
| 28:30 |     | Reserved                                                |                                       |
| 31    | LRU | Least Recently Used (LRU)<br>0 A-way LRU<br>1 B-way LRU |                                       |

**Note:** A "dirty" cache line is one which has been accessed by a store instruction after it was established, and can be inconsistent with external memory.

# 4.5 DCU Performance

DCU performance depends upon the application, but, in general, cache hits complete in one cycle without stalling the CPU pipeline. Under certain conditions and limitations of the DCU, the pipeline stalls (stops executing instructions) until the DCU completes current operations.

Several factors affect DCU performance, including:

- Pipeline stalls
- DCU priority
- Simultaneous cache operations
- Sequential cache operations

# 4.5.1 Pipeline Stalls

The CPU issues commands for cache operations to the DCU. If the DCU can immediately perform the requested cache operation, no pipeline stall occurs. In some cases, however, the DCU cannot immediately perform the requested cache operation, and the pipeline stalls until the DCU can perform the pending cache operation.

In general, the DCU, when hitting in the cache array, can execute a load/store every cycle. If a cache miss occurs, the DCU must retrieve the line from main memory. For cache misses, the DCU stores the cache line in a line buffer until the entire cache line is received. The DCU can accept new DCU commands while the fill progresses. If the instruction causing the line fill is a load, the target word is bypassed to the GPR during the cycle after it becomes available in the fill buffer. When the fill buffer is full, it must be moved into the tag and data arrays. During this time, the DCU cannot begin a new cache operation and stalls the pipeline if new DCU commands are presented. Storing a line in the line buffer takes 3 cycles, unless the line being replaced has been modified. In that case, the operation takes 4 cycles.

The DCU can accept up to two load commands. If the data for the first load command is not immediately available, the DCU can still accept the second load command. If the load data is not required by subsequent instructions, those instructions will continue to execute. If data is required from either load command, the CPU pipeline will stall until the load data has been delivered. The pipeline will also stall until the second load has read the data array if a subsequent data cache command is issued.

In general, if the fill buffer is being used and the next load or store command requires the fill buffer, only one additional command can be accepted before causing additional DCU commands to stall the pipeline.

The DCU can accept up to three outstanding store commands before stalling the CPU pipeline for additional data cache commands.

The DCU can have two flushes pending before stalling the CPU pipeline.

DCU cache operations other than loads and stores stall the CPU pipeline until all prior data cache operations complete. Any subsequent data cache command will stall the pipeline until the prior operation is complete.

The pipeline stalls when on-chip memory (OCM) asserts a hold signal. For loads or stores that are held, the DCU can still accept one additional load or store command before stalling the pipeline for subsequent commands.

## 4.5.2 Cache Operation Priorities

The DCU uses a priority signal to improve performance when pipeline stalls occur. When the pipeline is stalled because of a data cache operation, the DCU asserts the priority signal to the PLB. The priority signal tells the external bus that the DCU requires immediate service, and is valid only when the data cache is requesting access to the PLB. The priority signal is asserted for all loads that require external data, or when the data cache is requesting the PLB and stalling an operation that is being presented to the data cache.

Table 4-3 provides examples of when the priority is asserted and deasserted.

| Instruction<br>Requesting PLB      | Priority | Next Instruction                                         | Priority |
|------------------------------------|----------|----------------------------------------------------------|----------|
| Any load from 1<br>external memory |          | N/A                                                      | N/A      |
| Any store                          | 0        | Any other cache operation not being accepted by the DCU. | 1        |
| dcbf                               | 0        | Any cache hit.                                           | 0        |
| dcbf/dcbst                         | 0        | Load non-cache.                                          | 1        |
| dcbf/dcbst                         | 0        | Another command that requires a line flush.              | 1        |
| dcbt                               | 0        | Any cache hit.                                           | 0        |
| dcbi/dccci/dcbz                    | 0        | N/A                                                      | N/A      |

Table 4-3. Priority Changes With Different Data Cache Operations

# 4.5.3 Simultaneous Cache Operations

Some cache operations can occur simultaneously to improve DCU performance. For example, combinations of line fills, line flushes, word load/stores, and operations that hit in the cache can occur simultaneously. Cache operations other than loads/stores cannot begin until the PLB completes all previous operations.

# 4.5.4 Sequential Cache Operations

Some common cache operations, when performed sequentially, can limit DCU performance: sequential loads/stores to non-cachable storage regions, sequential line fills, and sequential line flushes.

In the case of sequential cache hits, the most commonly occurring operations, the DCU loads or stores data every cycle. In such cases, the DCU does not limit performance.

However, when a load from a non-cachable storage region is followed by multiple loads from noncachable regions, the loads can complete no faster than every four cycles, assuming that the addresses are accepted during the same cycle in which it is requested, and that the data is returned during the cycle after the load is accepted.

Similarly, when a store to a non-cachable storage region is followed by multiple stores to noncachable regions the fastest that the stores can complete is every other cycle. The DCU can have accepted up to three stores before additional DCU commands will stall waiting for the prior stores to complete.

Sequential line fills can limit DCU performance. Line fills occur when a load/store or **dcbt** instruction misses in the cache, and can be pipelined on the PLB interface such that up to two requests can be accepted before stalling subsequent requests. The subsequent operations will wait in the DCU until the first line fill completes. The line fills must complete in the order that they are accepted.

Sequential line flushes from the DCU to main memory also limit DCU performance. Flushes occur when a line fill replaces a valid line that is marked dirty (modified), or when a **dcbf** instruction flushes a specific line. If two flushes are pending, the DCU stalls any new data cache operations until the first flush finishes and the second flush begins.

# Chapter 5. On-Chip Memory

The on-chip memory (OCM) subsystem consists of a memory controller that connects the PPC405GP processor core to a one-port, 4KB on-chip SRAM array. OCM is ideal for applications requiring low-latency access to critical instructions and data. OCM can provide performance that is identical to cache hits, yet, unlike a cache, the OCM never misses. Instructions and data stored in the OCM are always available because OCM contents only change under program control. Therefore, if the programmer avoids instruction-side and data-side OCM access contention, OCM can provide information availability that is superior to a cache line locking scheme. OCM is superior because it can provide single cycle performance identical to cache hits without locking down portions of the cache. This results in more effective cache utilization for the processor.

Instructions and data returned from OCM interface do not flow through the PPC405GP core caches. The caches remain available for caching from other memory sources accessed across the PLB interface. The system designer must ensure that each address has a single access path into the PPC405GP core for a given software process. Each address that is requested should be found in either the OCM address space or the PLB address space, *but not in both*.

Code to initialize OCM should execute in non-OCM address space in a region marked as noncachable. The initialization code should invalidate the cache arrays (in the instruction cache unit (ICU) and data cache unit (DCU), as appropriate) to ensure that no addresses to be programmed as OCM space are in the cache. After programming the OCM address and control registers, the OCM address space should remain marked as non-cachable. Chip initialization for OCM usage is described in "OCM Initialization" on page 8-13.

Read and write accesses to the OCM array share a single access port. OCM accesses have the following priorities:

- 1. Data-side OCM reads (loads)
- 2. Data-side OCM writes (stores)
- 3. Instruction-side OCM read (fetches)

Data-side OCM reads occur in one cycle. Data-side writes also complete in one cycle, though they can be pre-empted by higher priority data-side reads. Instruction-side OCM reads occur by default (that is, after a reset) in two cycles. However, when the Instruction-Side Two-Cycle Mode field of the OCM Instruction-Side Control Register is set to 0 (OCM0\_ISCNTL[ISTCM] = 0), instruction-side OCM reads occur in one cycle, unless pre-empted by higher priority data-side transfers. Two-cycle mode is provided for chips that cannot make instruction-side timing to the processor core. The PPC405GP, however, meets the timing requirement. Therefore, programmers should set OCM0\_ISCNTL[ISTCM] = 0 during chip initialization, as described in "OCM Initialization" on page 8-13.

# 5.1 OCM Addressing

The address space for the instruction-side OCM and the data side OCM are defined by the OCM Instruction-Side Address Range Compare Register (OCM0\_ISARC) and OCM Data-Side Address Range Compare Register (OCM0\_DSARC), respectively. These registers are implemented as 6-bit registers that define the most significant address bits of the respective OCM address space. Using 6

bits defines a 64MB address space. The instruction side and data side can share a 64MB address space, or each can have its own 64MB address space. The address spaces are fully relocatable on 64MB boundaries within the 4GB address space of the PPC405GP, but the programmer must assign OCM address space to avoid conflicts with other assigned addresses. See "Programming Model" on page 3-1 for information about the PPC405GP memory map.



#### Figure 5-1. OCM Address Usage

Figure 5-1 illustrates OCM address usage. The OCM SRAM array size is 4KB. Address bits 20:31 select byte addresses for data-side accesses. Address bits 30:31 are ignored for instruction-side accesses, because instruction-side accesses return either one or two words per transfer.

Note that the instruction-side and data-side OCM address spaces overlap physically, even if defined as distinct logical address spaces, because the 4KB SRAM is shared. There is no distinction between data space or instruction space, except as defined by the programmer.

Addresses in the OCM array are aliased throughout the larger OCM address spaces. The larger OCM address spaces are filled with multiple images of the 4KB SRAM. Aliased addresses refer to the same physical memory locations.

**Programming Note:** To avoid possible memory coherency problems when using aliased addresses, align aliased addresses on 16KB boundaries rather than on 4KB boundaries. See "Store Data Bypass Behavior and Memory Coherency" on page 5-3 for details.

If address translation is enabled (MSR[IR, DR] = 1), one or more TLB entries for the OCM address space must exist to validate accesses. However, the virtual addresses are *not* translated, and 32-bit effective addresses (virtual addresses) are presented to OCM.

Data-side OCM contents can use big endian or little endian byte ordering. Instruction-side OCM contents *must* use big endian byte ordering. See "Byte Ordering" on page 3-28 for detailed information about byte ordering.

# 5.2 OCM Programming Guidelines

The following guidelines prevent potential problems associated with using OCM:

 Code that uses mtdcr to disable instruction-side OCM access should not run out of the instructionside OCM.

Instructions following an **mtdcr** are not guaranteed to be fetched before the instruction-side OCM is disabled.

- Do not change the value in OCM0\_ISARC while fetching from the instruction-side OCM.
- To change the value in OCM0\_ISARC or OCM0\_DSARC:
  - 1. Set OCM0\_ISCNTL[ISEN] = 0 to disable instruction-side OCM accesses, or set OCM0\_DSCNTL[DSEN] = 0 to disable data-side OCM accesses.

- Clear MSR[EE] and MSR[CE] to mask interrupts, to ensure that interrupts do not interfere with the cache invalidation described in Step 4. This avoids a potential problem with "dirty" cache addresses that would not be fetched from the cache because they have been marked as noncachable.
- 3. Mark the address region to be programmed as OCM address space as noncachable.
- 4. Invalidate the cache array that corresponds to the OCM (instruction-side or data-side) whose address range compare register is to be modified to ensure that no addresses to be programmed as OCM addresses exist in the cache. A single iccci instruction invalidates the ICU cache array. To invalidate the DCU cache array, use a sequence of dcbf instructions (one per cache line).
- 5. Modify the value in OCM0\_ISARC or OCM0\_DSARC.
- 6. Set OCM0\_ISCNTL[ISEN] = 1 to enable instruction-side OCM accesses, or set OCM0\_DSCNTL[DSEN] = 1 to enable data-side OCM accesses.
- Self-modifying code that accesses OCM to update instructions should not fetch instructions from the area being modified until a **sync** instruction executes, followed by an **isync** instruction.

The **sync** instruction ensures that instructions are updated. The **isync** instruction ensures that only updated instructions are fetched into the pipeline.

Instructions in OCM can be updated while instructions from non-OCM addresses execute. A **sync-isync** pair should still be used whenever such self-modifying code is updated.

 The CPU can become less efficient when instructions and data in OCM are accessed at the same time, because the SRAM has only one access port and instruction fetches have the lowest priority.

For example, instructions fetched from OCM that contain several sequential data-side loads accessing OCM can result in bubbles in the instruction pipeline. The sequential data-side loads dominate OCM accesses, resulting in the inability to fetch instructions from OCM.

 If aliased addresses are used, the aliased 4KB address spaces should be aligned on 16KB boundaries to eliminate potential store data bypass problems, as described in "Store Data Bypass Behavior and Memory Coherency."

# 5.3 Store Data Bypass Behavior and Memory Coherency

The OCM subsystem provides only one mechanism, data-side store operations, for writing both instructions and data into the OCM array. However, two independent mechanisms request read access of OCM contents; one for instruction-side fetches and the other for data-side loads.

The following description applies only to applications that alias the OCM address space and perform a mix of data-side loads and stores. It does not apply to applications that use data-side stores only to initialize OCM with instructions.

If a data-side OCM store is followed in the next cycle by a data-side load, the load actually accesses the OCM array before the store. This is due to the nature of the processor pipeline, the cycle availability of the store data, and the fact that data-side loads have a higher priority than data-side stores. In this scenario, store data is queued in a register while the load accesses the array. Further, if the store is immediately followed by a sequence of consecutive loads, it remains in the queue until the last of the consecutive loads has accessed the OCM array. The queued store data is written into the OCM array in the first cycle that does not have a data-side load operation accessing the array. Consider a scenario where such a situation causes store data to be held in the store data queue. If any of the loads access the same address as the address of the store operation whose data is being held in the store data queue, there is a need to bypass the store data from the store data queue to provide the correct data to the load operation.

A bypass is determined to be required by comparing the pending store address with the load address. However, the comparison is done with a 16KB address representation for the load and store operations, not the 4KB address (the physical size of the PPC405GP OCM array). If the 16KB address compares, the store data is bypassed to the load operation. This implies that a bypass results for address aliasing only when the OCM addresses match at a 16KB multiple, which corresponds to a match of address bits 18:29 (a word address that is further specified by byte enables). Although the physical address space is aliased at 4KB multiples, the bypass determination is made at 16KB multiples. Therefore, if bits 18:19 of an aliased load address do not match bits 18:19 of the 16KB store address of the data being held in the store data queue, the load data will not be coherent. Instead of returning the most recently stored data, which is being held in the store data queue, the load returns "old" data previously stored in and accessed from the OCM array.

Table 5-1 provides examples that describe bypass behavior when address aliasing is used.

| Example | Store Address | Load Address | 4KB Aliased<br>Address | 16KB Aliased<br>Address | Bypass |
|---------|---------------|--------------|------------------------|-------------------------|--------|
| 1       | 0x00000100    | 0x00000100   | Same                   | Same                    | Yes    |
| 2       | 0x00000100    | 0x00000400   | No                     | No                      | No     |
| 3       | 0x00000100    | 0x00001100   | Yes                    | No, loads old data      | No     |
| 4       | 0x00000100    | 0x00005100   | Yes                    | No, loads old data      | No     |
| 5       | 0x00000100    | 0x00004100   | Yes                    | Yes                     | Yes    |
| 6       | 0x00000100    | 0x00008100   | Yes                    | Yes                     | Yes    |

Table 5-1. Examples of Store Data Bypass

Example 1 provides the most basic example, in which the load and store addresses are the same. This results in the load accessing the queued store data, bypassing the OCM array to satisfy the load.

Example 2 shows two different addresses that are *not* aliased (both addresses are in the 4KB SRAM address space). No bypass occurs, and the load returns the correct data from the OCM array.

Examples 3 and 4 show aliased addresses that do not bypass data because the addresses do not compare within a 16KB address space. In both examples, address bits 18:19 do not match. In both examples, the load does not return the most recently stored data from the store data queue; the load returns the "old" data from the array. To avoid such problems, alias on 16KB boundaries. If addresses are aliased on 4KB boundaries, place at least one instruction that does not access the data-side OCM between a load and a store to the same aliased address so the store data has a cycle to be written - into the array.

Examples 5 and 6 bypass data out of the store data queue because the aliased addresses compare within a 16KB address space. In both examples, address bits 18:29 match, and load data is returned from the store data queue.

# 5.4 Registers

The OCM controller uses the Device Control Registers (DCRs) listed in Table 5-2.

| Register                                            | Mnemonic    | DCR Number | Access | Page |
|-----------------------------------------------------|-------------|------------|--------|------|
| OCM Instruction-Side Address Range Compare Register | OCM0_ISARC  | 0x018      | R/W    | 5-5  |
| OCM Instruction-Side Control Register               | OCM0_ISCNTL | 0x019      | R/W    | 5-6  |
| OCM Data-Side Address Range Compare Register        | OCM0_DSARC  | 0x01A      | R/W    | 5-6  |
| OCM Data-Side Control Register                      | OCM0_DSCNTL | 0x01B      | R/W    | 5-7  |

Table 5-2. OCM DCRs

# 5.4.1 OCM Instruction-Side Address Range Compare Register (OCM0\_ISARC)

OCM0\_ISARC defines the address range of the OCM controller when it is presented with instruction fetch requests. OCM0\_ISARC[ISAR] is compared to the high-order 6 bits of the requested instruction address, providing a 64MB address space. The address space can be shared with, or distinct from, the data-side OCM address space.

The OCM controller returns requested instructions if instruction-side OCM access is enabled (OCM0\_ISCNTL[ISEN] = 1) and OCM0\_ISARC[ISAR] matches the high-order 6 bits of the requested instruction address.

OCM0\_ISARC must be initialized before OCM0\_ISCNTL[ISEN] is set to 1 to enable instruction-side OCM accesses. See "OCM Initialization" on page 8-13 for details



| Figure 5-2.  | <b>OCM Instruction-Side</b> | Address Bang | e Compare Regi | ster (OCM0_ISARC | ١ |
|--------------|-----------------------------|--------------|----------------|------------------|---|
| I Iguic C Z. | oom monuon oluc             | Addicoo nung | s oompute negi |                  | , |

| 0:5  | ISAR | Instruction-side OCM address range |
|------|------|------------------------------------|
| 6:31 |      | Reserved                           |

# 5.4.2 OCM Instruction-Side Control Register (OCM0\_ISCNTL)

OCM0\_ISCNTL enables and disables instruction-side OCM access and controls whether instruction requests are satisfied in one or two cycles.

OCM0\_ISCNTL[ISEN] enables the OCM controller to respond to requests for instruction fetches to addresses in the instruction-side OCM address range defined by OCM0\_ISARC[ISAR]. At reset, OCM0\_ISCNTL[ISEN] = 0; instruction-side OCM is not enabled. If instruction-side OCM is to be accessed, this field must be set to 1 during chip initialization, as described in "OCM Initialization" on page 8-13.

Setting OCM0\_ISCNTL[ISTCM] = 1 places the instruction-side OCM in a mode in which accesses complete in no fewer than two cycles. Two-cycle mode is provided for chips that cannot make instruction-side timing to the processor core. The PPC405GP, however, meets the timing requirement. At reset, OCM0\_ISCNTL[ISTCM] = 1. This field should be set to 0 during chip initialization so that instruction-side accesses can complete in one cycle. OCM0\_ISCNTL[ISTCM] does not affect data-side OCM operation.



| 0    | ISEN  | <ul> <li>Instruction-Side OCM Enable</li> <li>Instruction-side OCM accesses are disabled.</li> <li>Instruction-side OCM accesses are enabled.</li> </ul>           |                                                                                                                                |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 1    | ISTCM | Instruction-Side Two Cycle Mode<br>0 Instruction-side OCM accesses are<br>returned in one cycle.<br>1 Instruction-side OCM accesses are<br>returned in two cycles. | OCM0_ISCNTL[ISTCM], which has a reset<br>value of 1, should be set to<br>OCM0_ISCNTL[ISTCM] = 0 during chip<br>initialization. |
| 2:31 |       | Reserved                                                                                                                                                           | · · · · · · · · · · · · · · · · · · ·                                                                                          |

Figure 5-3. OCM Instruction-Side Control Register (OCM0\_ISCNTL)

# 5.4.3 OCM Data-Side Address Range Compare Register (OCM0\_DSARC)

OCM0\_DSARC defines the address range of the OCM controller when it is presented with load and store requests. OCM0\_DSARC[DSAR] is compared to the high-order 6 bits of the requested data address, providing a 64MB address space. The address space can be shared with, or distinct from, the instruction-side OCM address space.

The OCM controller transfers the requested load/store data if data-side OCM access is enabled (OCM0\_DSCNTL[DSEN] = 1) and OCM0\_DSARC[DSAR] matches the high-order 6 bits of the requested data address.

OCM0\_DSARC must be initialized before OCM0\_DSCNTL[DSEN] is set to 1 to enable data-side OCM accesses. See "OCM Initialization" on page 8-13 for details.



#### Figure 5-4. OCM Data-Side Address Range Compare Register (OCM0\_DSARC)

| 0:5  | DSAR                  | Data-side OCM address range |
|------|-----------------------|-----------------------------|
| 6:31 | and Service Particles | Reserved                    |

# 5.4.4 OCM Data-Side Control Register (OCM0\_DSCNTL)

OCM0\_DSCNTL enables and disables data-side OCM access.

OCM0\_DSCNTL[DSEN] enables the OCM controller to respond to requests for data loads and stores within the data-side OCM address range defined by OCM0\_DSARC[DSAR]. At reset, OCM0\_DSCNTL[DSEN] = 0; data-side OCM is not enabled. If data-side OCM is to be accessed, this field must be set to 1 during chip initialization, as described in "OCM Initialization" on page 8-13.

The reset value of the DOF field is 1. This field should always remain set to 1 when writing OCM0\_DSCNTL.



|   |      | -                                      |                                    |
|---|------|----------------------------------------|------------------------------------|
| 0 | DSEN | Data-Side OCM Enable                   |                                    |
|   |      | 0 Data-side OCM accesses are disabled. |                                    |
|   |      | 1 Data-side OCM accesses are enabled.  |                                    |
| 1 | DOF  |                                        | This field should remain set to 1. |

| Figure 5-5. UCM Data-Side Control Register (UCMU DSCN1L | M Data-Side Control Register (OCM0_DSC | NTL) |
|---------------------------------------------------------|----------------------------------------|------|
|---------------------------------------------------------|----------------------------------------|------|

Reserved

2:31

5-8 PPC405GP User's Manual

# Chapter 6. Memory Management

The PPC405GP memory management unit (MMU) performs address translation and protection functions. With appropriate system software, the MMU supports:

- Translation of effective addresses to real addresses
- · Independent enabling of instruction and data address translation and protection
- · Page-level access control using the translation mechanism
- · Software control of page replacement strategy
- Additional virtual-mode control of protection using zones
- · Real-mode write protection

# 6.1 MMU Overview

The instruction and integer units generate 32-bit effective addresses (EAs) for instruction fetches and data accesses, respectively. Instruction EAs are generated for sequential instruction fetches, and for instruction fetches causing changes in program flow (branches and interrupts). Data EAs are generated for load/store and cache control instructions. The MMU translates EAs into real addresses; the instruction cache unit (ICU) and data cache unit (DCU) use real addresses to access memory.

The PPC405GP MMU supports demand-paged virtual memory and other memory management schemes that depend on precise control of effective to real address mapping and flexible memory protection. Translation misses and protection faults cause precise interrupts. Sufficient information is available to correct the fault and restart the faulting instruction.

The MMU divides storage into pages. A page represents the granularity of EA translation and protection controls. Eight page sizes (1KB, 4KB, 16KB, 64KB, 256KB, 1MB, 4MB, 16MB) are simultaneously supported. A valid entry for a page containing the EA to be translated must be in the translation lookaside buffer (TLB) for address translation to be performed. EAs for which no valid TLB entry exists cause TLB-miss interrupts.

# 6.2 Address Translation

Fields in the Machine State Register (MSR) control the use of the MMU for address translation. The instruction relocate (IR) field of the MSR controls translation for instruction accesses. The data relocate (DR) field of the MSR controls the translation mechanism for data accesses. These fields, specified independently, can be changed at any time by a program in supervisor state. Note that all interrupts clear MSR[IR, DR] and place the processor in the supervisor state. Subsequent discussion about translation and protection assumes that MSR[IR, DR] are set, enabling address translation.

The processor references memory when it fetches an instruction, and when it executes load/store, branch, and cache control instructions. Processor accesses to memory use EAs to references a memory location. When translation is enabled, the EA is translated into a real address, as illustrated in Figure 6-1 on page 6-2. The ICU or DCU uses the real address for the access. (When translation is not enabled, the EA is already a real address.)

In address translation, the EA is combined with an 8-bit process ID (PID) to create a 40-bit virtual address. The virtual address is compared to all of the TLB entries. A matching entry supplies the real address for the storage reference. Figure 6-1 illustrates the process.



Figure 6-1. Effective to Real Address Translation Flow

# 6.3 Translation Lookaside Buffer (TLB)

The TLB is hardware that controls translation, protection, and storage attributes. The instruction and data units share a unified fully-associative TLB, in which any page entry (TLB entry) can be placed anywhere in the TLB. TLB entries are maintained under program control. System software determines the TLB entry replacement strategy and the format and use of page state information. A TLB entry contains the information required to identify the page, to specify translation and protection controls, and to specify the storage attributes.

#### 6.3.1 Unified TLB

The unified TLB (UTLB) contains 64 entries; each has a TLBHI (tag) portion and a TLBLO (data) portion, as described in Figure 6-2 on page 6-3. TLBHI contains 36 bits; TLBLO contains 32 bits. When translation is enabled, the UTLB tag portion compares some or all of  $EA_{0:21}$  with some or all of the effective page number  $EPN_{0:21}$ , based on the size bits  $SIZE_{0:2}$ . All 64 entries are simultaneously checked for a match. If an entry matches, the corresponding data portion of the UTLB provides the

real page number (RPN), access control bits (ZSEL, EX, WR), and storage attributes (W, I, M, G, E, U0)..



#### Figure 6-2. TLB Entries

The virtual address space is extended by adding an 8-bit translation ID (TID) loaded from the Process ID (PID) register during a TLB access. The PID identifies one of 255 unique software entities, usually used as a process or thread ID. TLBHI[TID] is compared to the PID during a TLB look-up.

Tag and data entries are written by copying data from GPRs and the PID, using the **tlbwe** instruction. Tag and data entries are read by copying data to GPRs and the PID, using the **tlbre** instruction. Software can search for specific entries using the **tlbsx** instruction.

#### 6.3.2 TLB Fields

Each TLB entry describes a page that is enabled for translation and access controls. Fields in the TLB entry fall into four categories:

- Information required to identify the page to the hardware translation mechanism
- · Control information specifying the translation
- Access control information
- Storage attribute control information

#### 6.3.2.1 Page Identification Fields

When an EA is presented to the MMU for processing, the MMU applies several selection criteria to each TLB entry to select the appropriate entry. Although it is possible to place multiple entries into the TLB to match a specific EA and PID, this is considered a programming error, and the result of a TLB lookup for such an EA is undefined. The following fields in the TLB entry identify the page. Except as noted, all comparisons must succeed to validate an entry for subsequent use.

#### EPN (effective page number, 22 bits)

Compared to some number of the  $EA_{0:21}$  bits presented to the MMU. The number of bits corresponds to the page size.

The exact comparison depends on the page size, as shown in Table 6-1.

| Page<br>Size | SIZE<br>Field | <i>n</i> Bits<br>Compared | EPN to EA<br>Comparison                | RPN Bits<br>Set to 0 |
|--------------|---------------|---------------------------|----------------------------------------|----------------------|
| 1KB          | 000           | 22                        | $EPN_{0:21} \leftrightarrow EA_{0:21}$ | —                    |
| 4KB          | 001           | 20                        | $EPN_{0:19} \leftrightarrow EA_{0:19}$ | RPN <sub>20:21</sub> |
| 16KB         | 010           | 18                        | $EPN_{0:17} \leftrightarrow EA_{0:17}$ | RPN <sub>18:21</sub> |
| 64KB         | 011           | 16 .                      | $EPN_{0:15} \leftrightarrow EA_{0:15}$ | RPN <sub>16:21</sub> |
| 256KB        | 100           | 14                        | $EPN_{0:13} \leftrightarrow EA_{0:13}$ | RPN <sub>14:21</sub> |
| 1MB          | 101           | 12                        | $EPN_{0:11} \leftrightarrow EA_{0:11}$ | RPN <sub>12:21</sub> |
| 4MB          | 110           | 10                        | $EPN_{0:9} \leftrightarrow EA_{0:9}$   | RPN <sub>10:21</sub> |
| 16MB         | 111           | 8                         | $EPN_{0:7} \leftrightarrow EA_{0:7}$   | RPN <sub>8:21</sub>  |

Table 6-1. TLB Fields Related to Page Size

SIZE (page size, 3 bits)

Selects one of the eight page sizes, 1KB-16MB, listed in Table 6-1.

V (valid,1 bit)

Indicates whether a TLB entry is valid and can be used for translation.

A valid TLB entry implies read access, unless overridden by zone protection. TLB\_entry[V] can be written using a **tlbwe** instruction. The **tlbia** instruction invalidates all TLB entries.

#### TID (translation ID, 8 bits)

Loaded from the PID register during a **tIbwe** operation. The TID value is compared with the PID value during a TLB access. The TID provides a convenient way to associate a translation with one of 255 unique software entities, typically a process or thread ID maintained by operating system software. Setting TLBHI[TID] = 0x00 disables TID-PID comparison and identifies a TLB entry as valid for all processes; the value of the PID register is then irrelevant.

#### 6.3.2.2 Translation Field

When a TLB entry is identified as matching an EA (and possibly the PID), TLBLO[RPN] defines how the EA is translated.

RPN (real page number, 22 bits)

Replaces some, or all, of  $EA_{0:21}$ , depending on page size. For example, a 16KB page uses  $EA_{0:17}$  for comparison. The translation mechanism replaces  $EA_{0:17}$  with TLBLO[RPN]<sub>0:17</sub> to form the physical address, and  $EA_{18:31}$  becomes the real page offset, as illustrated in Figure 6-1.

**Programming Note:** Software must set all unused bits of RPN (as determined by page size) to 0. See Table 6-1.

# 6.3.2.3 Access Control Fields

Several access controls are available in the UTLB entries.

#### **ZSEL** (zone select, 4 bits)

Selects one of 16 zone fields (Z0—Z15) from the Zone Protection Register (ZPR). The ZPR field bits can modify the access protection specified by the TLB\_entry[V, EX, WR] bits of a TLB entry. Zone protection is described in detail in "Zone Protection" on page 6-13.

EX (execute enable, 1 bit)

When set (TLBLO[EX] = 1), enables instruction execution at addresses within a page. ZPR settings can override TLBLO[EX]; see "Zone Protection" on page 6-13, for more information.

WR (write-enable 1 bit)

When set (TLBLO[WR] = 1), enables store operations to addresses in a page. ZPR settings can override TLBLO[WR]; see "Zone Protection" on page 6-13.

#### 6.3.2.4 Storage Attribute Fields

TLB entries contain bits that control and provide information about the storage control attributes. Four of the attributes (W, I, M, and G) are defined in the PowerPC Architecture. The E storage attribute is defined in the IBM PowerPC Embedded Environment. The U0 attribute is implementation-specific. For the PPC405GP, U0 controls the CodePack instruction decompression function.

W (write-through,1 bit)

When set (TLBLO[W] = 1), stores are specified as write-through. If data in the referenced page is in the data cache, a store updates the cached copy of the data and the external memory location. Contrast this with a write-back strategy, which updates memory only when a cache line is flushed.

In real mode, the Data Cache Write-through Register (DCWR) controls the write strategy.

Note that the PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited. It is considered a programming error to use these memory models; the results are undefined.

I (caching inhibited, 1 bit)

When set (TLBLO[I] = 1), a memory access is completed by using the location in main memory, bypassing the cache arrays. During the access, the accessed location is not put into the cache arrays.

In real mode, the Instruction Cache Cachability Register (ICCR) and Data Cache Cachability Register (DCCR) control cachability. In these registers, the setting of the bit is reversed; 1 indicates that a storage control region is cachable, rather than caching inhibited.

Note that the PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited. It is considered a programming error to use these memory models; the results are undefined.

It is considered a programming error if the target location of a load/store, **dcbz**, or fetch access to caching inhibited storage is in the cache; the results are undefined. It is *not* considered a programming error for the target locations of other cache control instructions to be in the cache when caching is inhibited.

#### M (memory coherent,1 bit)

For implementations that support multiprocessing, the M storage attribute improves the performance of memory coherency management. Because the PPC405GP does not provide multi-processor support or hardware support for data coherency, the M bit is implemented, but has no effect.

#### G (guarded,1 bit)

When set (TLBLO[G] = 1), indicates that the hardware cannot speculatively access the location for pre-fetching or out-of-order load access. The G storage attribute is typically used to protect memory-mapped I/O from inadvertent access. Attempted execution of an instruction from a guarded data storage address while instruction address translation is enabled results in an instruction storage interrupt because data storage and memory mapped I/O (MMIO) addresses are not used to contain instructions.

An instruction fetch from a guarded region does not occur until the execution pipeline is empty, thus guaranteeing that the access is necessary and therefore not speculative. For this reason, performance is degraded when executing out of guarded regions, and software should avoid unnecessarily marking regions of instruction storage as guarded.

In real mode, the Storage Guarded Register (SGR) controls guarding.

U0 (user-defined attribute, 1 bit)

When set (TLBLO[U0] = 1), indicates the user-defined attribute applies to the data in the associated page. This storage attribute controls CodePack decompression for a page.

In real mode, the Storage User-defined 0 Register (SU0R) controls the setting of the U0 storage attribute.

E (endian, 1 bit)

When set (TLBLO[E] = 1), indicates that data in the associated page is stored in true little endian format.

In real mode, the Storage Little-Endian Register (SLER) controls the setting of the E storage attribute.

# 6.3.3 Shadow Instruction TLB

To enhance performance, four instruction-side TLB entries are kept in a four-entry fully-associative shadow array. This array, called the instruction TLB (ITLB), helps to avoid TLB contention between instruction accesses to the TLB and load/store operations. Replacement and invalidation of the ITLB entries is managed by hardware (see "Shadow TLB Consistency" on page 6-8 for details).

The ITLB can be considered a level-1 instruction-side TLB; the UTLB serves as the level-2 instruction-side TLB. The ITLB is used only by instruction fetches for storing instruction address translations. Each ITLB entry contains the translation information for a page. The processor uses the ITLB for address translation of instruction accesses when MSR[IR] = 1.

#### 6.3.3.1 ITLB Accesses

The instruction unit accesses the ITLB independently of the rest of the MMU. ITLB accesses are transparent to the executing program, except that ITLB hits contribute to higher overall instruction throughput by allowing data address translations to occur in parallel. Therefore, when instruction

accesses hit in the ITLB, the address translation mechanisms in the UTLB are available for use by data accesses simultaneously.

The ITLB requests a new entry from the UTLB when an ITLB miss occurs. A four-cycle latency occurs at each ITLB miss that is also a UTLB hit; the latency is longer if it is also a UTLB miss, or if there is contention for the UTLB from the data side. A round-robin replacement algorithm replaces existing entries with new entries.

#### 6.3.4 Shadow Data TLB

To enhance performance, eight data-side TLB entries are kept in a eight-entry fully-associative shadow array. This array, called the data TLB (DTLB), helps to avoid TLB contention between instruction accesses to the TLB and load/store operations. Replacement and invalidation of the DTLB entries is managed by hardware. See "Shadow TLB Consistency" on page 6-8 for details.

The DTLB can be considered a level-1 data-side TLB; the UTLB serves as the level-2 data-side TLB. The DTLB is used only by instructions in execute for storing data address translations. Each DTLB entry contains the translation information for a page. The processor uses the DTLB for address translation of data accesses when MSR[DR] = 1.

#### 6.3.4.1 DTLB Accesses

The execute unit accesses the DTLB independently of the rest of the MMU. DTLB accesses are transparent to the executing program, except that DTLB hits contribute to higher overall instruction throughput by allowing instruction address translations to occur in parallel. Therefore, when data accesses hit in the DTLB, the address translation mechanisms in the UTLB are available for use by instruction accesses simultaneously.

The DTLB requests a new entry from the UTLB when a DTLB miss occurs. A three-cycle latency occurs at each DTLB miss that is also a UTLB hit; the latency is longer if it is also a UTLB miss. If there is contention for the UTLB from the instruction side, the data side has priority. A round-robin replacement algorithm replaces existing entries with new entries.



Figure 6-3 illustrates the relationship of the shadow TLBs and UTLB in address translation:

Figure 6-3. ITLB/DTLB/UTLB Address Resolution

#### 6.3.4.2 Shadow TLB Consistency

The processor invalidates the entire ITLB contents when the following context-synchronizing events occur, to help to maintain ITLB integrity.

- isync instruction
- Processor context switch (all interrupts, rfi, rfci)

If software updates a translation/protection mechanism (UTLB, PID, ZPR, or MSR) and must synchronize these updates with the ITLB, the *software* must perform the necessary context synchronization.

A typical example is the manipulation of the TLB by an operating system within an interrupt handler for a TLB miss. Upon entry to the interrupt handler, the ITLB is invalidated and translation is disabled. If the operating system simply made the TLB updates and returned from the handler (using **rfi**), no additional explicit software action would be required to synchronize the ITLB.

If, instead, the operating system re-enables translation within the handler, and then performs TLB updates within the handler, those updates would not be effective in the ITLB until **rfi** is executed to return from the handler. For those TLB updates to be reflected in the ITLB *within* the handler, an **isync** must be issued after TLB updates finish. Failure to properly synchronize the ITLB can cause unexpected behavior.

**Programming Note:** As a rule of thumb, follow software manipulation of an translation mechanism (if performed while translation is active) with a context-synchronizing operation (usually **isync**).

## 6.4 TLB-Related Interrupts

The processor relies on interrupt handling software to implement paged virtual memory, and to enforce protection of specified memory pages.

When an interrupt occurs, the processor clears MSR[IR, DR]. Therefore, at the start of all interrupt handlers, the processor operates in real mode for instruction accesses and data accesses. Note that when address translation is disabled for an instruction fetch or load/store, the EA is equal to the real address and is passed directly to the memory subsystem (including cache units). Such untranslated addresses bypass all memory protection checks that would otherwise be performed by the MMU.

When translation is enabled, MMU accesses can result in the following interrupts:

- Data storage interrupt
- Instruction storage interrupt
- Data TLB miss interrupt
- Instruction TLB miss interrupt

#### 6.4.1 Data Storage Interrupt

A data storage interrupt is generated when data address translation is active, and the desired access to the EA is not permitted for one of the following reasons:

- In the problem state
  - icbi, load/store, dcbz, or dcbf with an EA whose zone field is set to no access (ZPR[Zn] = 00).
     In this case, dcbt and dcbtst no-op, rather than cause an interrupt. Privileged instructions cannot cause data storage interrupts.
  - Stores, or dcbz, to an EA having TLB\_entry[WR] = 0 (write access disabled) and ZPR[Zn] ≠ 11. (The privileged instructions dcbi and dccci are treated as "stores", but cause program interrupts, rather than data storage interrupts.)

- In supervisor state
  - Data store, dcbi, dcbz, or dccci to an EA having TLB\_entry[WR] = 0 and ZPR[Zn] other than 11 or 10.

**dcba** does not cause data storage exceptions. If conditions occur that would otherwise cause such an exception, **dcba** is treated as a no-op.

"Zone Protection" on page 6-13 describes zone protection in detail. See "Data Storage Interrupt" on page 10-36 for a detailed discussion of the data storage interrupt.

# 6.4.2 Instruction Storage Interrupt

An instruction storage interrupt is generated when instruction address translation is active and the processor attempts to execute an instruction at an EA for which fetch access is not permitted, for any of the following reasons:

- In the problem state
  - Instruction fetch from an EA with ZPR[Zn] = 00.
  - Instruction fetch from an EA having TLB\_entry[EX] = 0 and  $ZPR[Zn] \neq 11$ .
  - Instruction fetch from an EA having TLB\_entry[G] = 1.
- · In the supervisor state
  - Instruction fetch from an EA having TLB\_entry[EX] = 0 and ZPR[Zn] other than 11 or 10.
  - Instruction fetch from an EA having TLB\_entry[G] = 1.

See "Zone Protection" on page 6-13 for a detailed discussion of zone protection. See "Instruction Storage Interrupt" on page 10-38 for a detailed discussion of the instruction storage interrupt.

# 6.4.3 Data TLB Miss Interrupt

A data TLB miss interrupt is generated if data address translation is enabled and a valid TLB entry matching the EA and PID is not present. The interrupt applies to data access instructions and cache operations (excluding cache touch instructions).

See "Data TLB Miss Interrupt" on page 10-43 for a detailed discussion.

#### 6.4.4 Instruction TLB Miss Interrupt

The instruction TLB miss interrupt is generated if instruction address translation is enabled and execution is attempted for an instruction for which a valid TLB entry matching the EA and PID for the instruction fetch is not present.

See "Instruction TLB Miss Interrupt" on page 10-44 for a detailed discussion.

# 6.5 TLB Management

The processor does not imply any format for the page tables or the page table entries because there is no hardware support for page table management. Software has complete flexibility in implementing a replacement strategy, because software does the replacing. For example, software can "lock" TLB

entries that correspond to frequently used storage by electing to never replace them, so that those entries are never cast out of the TLB.

TLB management is performed by software with some hardware assist, consisting of:

- Storage of the missed EA in the Save/Restore Register 0 (SRR0) for an instruction-side miss, or in the Data Exception Address Register (DEAR) for a data-side miss.
- Instructions for reading, writing, searching, and invalidating the TLB, as described briefly in the following subsections. See Chapter 24, "Instruction Set," for detailed instruction descriptions.

#### 6.5.1 TLB Search Instructions (tlbsx/tlbsx.)

**tlbsx** locates entries in the TLB, to find the TLB entry associated with an interrupt, or to locate candidate entries to cast out. **tlbsx** searches the UTLB array for a matching entry. The EA is the value to be matched; EA = (RAI0)+(RB).

If the TLB entry is found, its index is placed in RT<sub>26:31</sub>. RT can then serve as the source register for a **tlbre** or **tlbwe** instruction to read or write the entry, respectively. If no match is found, the contents of RT are undefined.

**tlbsx.** sets the Condition Register (CR) bit CR0<sub>EQ</sub>. The value of CR0<sub>EQ</sub> depends on whether an entry is found: CR0<sub>EQ</sub> = 1 if an entry is found; CR0<sub>EQ</sub> = 0 if no entry is found.

## 6.5.2 TLB Read/Write Instructions (tlbre/tlbwe)

TLB entries can be accessed for reading and writing by **tlbre** and **tlbwe**, respectively. Separate extended mnemonics are available for the TLBHI (tag) and TLBLO (data) portions of a TLB entry.

#### 6.5.3 TLB Invalidate Instruction (tlbia)

tlbia sets TLB\_entry[V] = 0 to invalidate all TLB entries. All other TLB entry fields remain unchanged.

Using **tlbwe** to set TLB\_entry[V] = 0 invalidates a specific TLB entry.

#### 6.5.4 TLB Sync Instruction (tlbsync)

**tlbsync** guarantees that all TLB operations have completed for all processors in a multi-processor system. PPC405GP provides no multiprocessor support, so this instruction performs no function. The instruction is included to facilitate code portability.

# 6.6 Recording Page References and Changes

When system software manages virtual memory, the software views physical memory as a collection of pages. Each page is associated with at least one TLB entry. To manage memory effectively, system software often must know whether a particular page has been referenced or modified. Note that this involves more than knowing whether a particular TLB entry was used to reference or alter memory, because multiple TLB entries can translate to the same page.

When system software manages a demand-paged environment, and the software needs to replace the contents of a page with other data, previously referenced pages (accessed for any purpose) are more likely to be maintained than pages that were never referenced. If the contents of a page must be replaced, and data contained in that page was modified, system software generally must write the contents of the modified page to the backing store before replacing its contents. System software must maintain records to control the environment.

Similarly, when system software manages TLB entries, the software often must know whether a particular TLB entry was referenced. When the system software must select a TLB entry to cast out, previously referenced entries are more likely to be maintained than entries which were never referenced. System software must also maintain records for this purpose.

The PPC405GP does not provide hardware reference or change bits, but TLB miss interrupts and data storage interrupts enable system software to maintain reference information for TLB entries and their associated pages, respectively.

A possible algorithm follows. First, the TLB entries are built, with each TLB\_entry[V, WR] = 0. System software retains the index and EPN of each entry.

The first attempt by application code to access a page causes a TLB miss interrupt, because its TLB entry is marked invalid. The TLB miss handler records the reference to the TLB entry (and to the associated page) in a data structure, then sets TLB\_entry[V] = 1. (Note that TLB\_entry[V] can be considered a reference bit for the TLB entry.) Subsequent read accesses to the page associated with the TLB entry proceed normally.

In the example just given for recording TLB entry references, the first write access to the page using the TLB entry, after the entry is made valid, causes a data storage interrupt because write access was turned off. The TLB miss handler records the write to the page in a data structure, for use as a "changed" flag, then sets TLB\_entry[WR] = 1 to enable write access. (Note that TLB\_entry[WR] can be considered a change bit for the page.) Subsequent write accesses to the page proceed normally.

# 6.7 Access Protection

The PPC405GP provides virtual-mode access protection. The TLB entry enables system software to control general access for programs in the problem state, and control write and execute permissions for all pages. The TLB entry can specify zone protection that can override the other access control mechanisms supported in the TLB entries.

TLB entry and zone protection methods also support access controls for cache operation and string loads/stores.

# 6.7.1 Access Protection Mechanisms in the TLB

For MMU access protection to be in effect, one or both of MSR[IR] or MSR[DR] must be set to one to enable address translation. MSR[IR] enables protection on instruction fetches, which are inherently read-only. MSR[DR] enables protection on data accesses (loads/stores).

# 6.7.1.1 General Access Protection

The translation ID (TLB\_entry[TID]) provides the first level of MMU access protection. This 8-bit field, if non-zero, is compared to the contents of TLB\_entry[PID]. These fields must match in a valid TLB entry if any access is to be allowed. In typical use, it is assumed that a program in the supervisor state, such as a real-time operating system, sets the PID before starting a problem state program that is subject to access control.

If TLB\_entry[TID] = 0x00, the associated memory page is accessible to all programs, regardless of their PID. This enables multiple processes to share common code and data. The common area is still subject to all other access protection mechanisms. Figure 6-4 illustrates the PID.



#### Figure 6-4. Process ID (PID)

| 0:23  | Reserved   |  |
|-------|------------|--|
| 24:31 | Process ID |  |

#### 6.7.1.2 Execute Permissions

If instruction address translation is enabled, instruction fetches are subject to MMU translation and have MMU access protection. Fetches are inherently read-only, so write protection is not needed. Instead, using TLB\_entry[EX], a memory page is marked as executable (contains instructions) or not executable (contains only data or memory-mapped control hardware).

If an instruction is pre-fetched from a memory page for which  $TLB_entry[EX] = 0$ , the instruction is tagged as an error. If the processor subsequently attempts to execute this instruction, an instruction storage interrupt results. This interrupt is precise with respect to the attempted execution. If the fetcher discards the instruction without attempting to execute it, no interrupt will result.

Zone protection can alter execution protection.

#### 6.7.1.3 Write Permissions

If MSR[DR] = 1, data loads and stores are subject to MMU translation and are afforded MMU access protection. The existence of a TLB entry describing a memory page implies read access; write access is controlled by TLB\_entry[WR].

If a store (including those caused by **dcbz**, **dcbi**, or **dccci**) is made to an EA having TLB\_entry[WR] = 0, a data storage interrupt results. This interrupt is precise.

Zone protection can alter write protection (see "Zone Protection" on page 6-13). In addition, only zone protection can prevent read access of a page defined by a TLB entry.

#### 6.7.1.4 Zone Protection

Each TLB entry contains a 4-bit zone select (ZSEL) field. A zone is an arbitrary identifier for grouping TLB entries (memory pages) for purposes of protection. As many as 16 different zones may be defined. Any zone can have any number of member pages.

Each zone is associated with a 2-bit field (Z0–Z15) in the ZPR. The values of the field define how protection is applied to all pages that are member of that zone. Changing the value of the ZPR field can alter the protection attributes of all pages in the zone. Without ZPR, the change would require finding, reading, altering, and rewriting the TLB entry for each page in a zone, individually. The ZPR provides a much faster means of altering the protection for groups of memory pages.

The ZSEL values 0-15 select ZPR fields Z0-Z15, respectively.

The fields are defined within the ZPR as follows:

While it is common for TLB\_entry[EX, WR] to be identical for all member pages in a group, this is not required. The ZPR field alters the protection defined by TLB\_entry[EX] and TLB\_entry[WR], on a page-by-page basis, as shown in the ZPR illustration. An application program (presumed to be running in the problem state) can have execute and write permissions as defined by TLB\_entry[EX] and TLB\_entry[WR] for the individual pages, or no access (denies loads, as well as stores and execution), or complete access.



|       |     |                                                                                                                                                                                                                                                                     | • • •                                                                                                                                                                                                                                                                                                             |  |
|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0:1   | Z0  | TLB page access control for all pages in this                                                                                                                                                                                                                       | zone.                                                                                                                                                                                                                                                                                                             |  |
|       |     | In the problem state (MSR[PR] = 1):<br>00 No access<br>01 Access controlled by applicable<br>TLB_entry[EX, WR]<br>10 Access controlled by applicable<br>TLB_entry[EX, WR]<br>11 Accessed as if execute and write<br>permissions (TLB_entry[EX, WR]) are<br>granted. | In the supervisor state (MSR[PR] = 0):<br>00 Access controlled by applicable<br>TLB_entry[EX, WR]<br>01 Access controlled by applicable<br>TLB_entry[EX, WR]<br>10 Access controlled by applicable<br>TLB_entry[EX, WR]<br>11 Accessed as if execute and write<br>permissions (TLB_entry[EX, WR]) are<br>granted. |  |
| 2:3   | Z1  | See the description of Z0.                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                 |  |
| 4:5   | Z2  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 6:7   | Z3  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 8:9   | Z4  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 10:11 | Z5  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 12:13 | Z6  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 14:15 | Z7  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 16:17 | Z8  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 18:19 | Z9  | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 20:21 | Z10 | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 22:23 | Z11 | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 24:25 | Z12 | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 26:27 | Z13 | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |
| 28:29 | Z14 | See the description of Z0.                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                   |  |

Figure 6-5. Zone Protection Register (ZPR)

| 11 |       |      |                            |
|----|-------|------|----------------------------|
|    | 30:31 | Z15  | One the dependence of 70   |
|    | 3031  | Z15  | See the description of Z0. |
|    | 00.01 | 2.10 |                            |
|    |       |      |                            |

Setting ZPR[Zn] = 00 for a ZPR field is the only way to deny read access to a page defined by an otherwise valid TLB entry. TLB\_entry[EX] and TLB\_entry[WR] do not support read protection. Note that the **icbi** instruction is considered a load with respect to access protection; executed in user mode, it causes a data storage interrupt if MSR[DR] = 1 and ZPR[Zn] = 00 is associated with the EA.

For a given ZPR field value, a program in supervisor state always has equal or greater access than a program in the problem state. System software can never be denied read (load) access for a valid TLB entry.

## 6.7.2 Access Protection for Cache Control Instructions

Architecturally the instructions **dcba**, **dcbi**, and **dcbz** are treated as "stores" because they can change data, or cause loss of data by invalidating a dirty line (a modified cache block).

Table 6-2 summarizes the conditions under which the cache control instructions can cause data storage interrupts.

|             | Possible Data Storage interrupt |                         |  |
|-------------|---------------------------------|-------------------------|--|
| Instruction | When ZPR[Zn] = 00               | When TLB_entry[WR] = 0  |  |
| dcba        | No (instruction no-ops)         | No (instruction no-ops) |  |
| dcbf        | Yes                             | No                      |  |
| dcbi        | No                              | Yes                     |  |
| dcbst       | Yes                             | No                      |  |
| dcbt        | No (instruction no-ops)         | No                      |  |
| dcbtst      | No (instruction no-ops)         | No                      |  |
| dcbz        | Yes                             | Yes                     |  |
| dccci       | No                              | Yes                     |  |
| dcread      | No                              | No                      |  |
| icbi        | Yes                             | No                      |  |
| icbt        | No                              | No                      |  |
| iccci       | No                              | No                      |  |
| icread      | No                              | No                      |  |

Table 6-2. Protection Applied to Cache Control Instructions

If data address translation is enabled, and write permission is denied (TLB\_entry[WR] = 0), **dcbi** and **dcbz** can cause data storage interrupts. **dcbz** can cause a data storage interrupt when executed in the problem state and all access is denied (ZPR[Zn] = 00); **dcbi** cannot cause a data storage interrupt because it is a privileged instruction.

The **dcba** instruction enables "speculative" line establishment in the cache arrays; the established lines do not cause a line fill. Because the effects of **dcba** are speculative, interrupts that would otherwise result when ZPR[Zn] = 00 or TLB\_entry[WR] = 0 do not occur. In such cases, **dcba** is treated as a no-op.

The **dccci** instruction can also be considered a "store" because it can change data by invalidating a dirty line; however, **dccci** is not address-specific (it affects an entire congruence class regardless of the operand address of the instruction). To restrict possible damage from an instruction which can change data and yet avoids the protection mechanism, the **dccci** instruction is privileged.

If data address translation is enabled, **dccci** can cause data storage interrupts when TLB\_entry[WR] = 0; the operand is treated as if it were address-specific. **dccci** cannot cause a data storage interrupt when ZPR[Zn] = 00, because it is a privileged instruction.

Because **dccci** can cause data storage and TLB -miss interrupts, use of **dccci** is not recommended when MSR[DR] = 1; if **dccci** is used. Note that the specific operand address can cause an interrupt.

Architecturally, **dcbt** and **dcbtst** are treated as "loads" because they do not change data; they cannot cause data storage interrupts when TLB\_entry[WR] = 0.

The cache block touch instructions **dcbt** and **dcbtst** are considered "speculative" loads; therefore, if a data storage interrupt would otherwise result from the execution of **dcbt** or **dcbtst** when ZPR[Zn] = 00, the instruction is treated as a no-op and the interrupt does not occur. Similarly, TLB miss interrupts do not occur for these instructions.

Architecturally, **dcbf** and **dcbst** are treated as "loads". Flushing or storing a line from the cache is not architecturally considered a "store" because a store was performed to update the cache, and **dcbf** or **dcbst** only update main memory. Therefore, neither **dcbf** nor **dcbst** can cause data storage interrupts when TLB\_entry[WR] = 0. Because neither instruction is privileged, they can cause data storage interrupts when ZPR[Zn] = 00 and data address translation is enabled.

**dcread** is a "load" from a non-specific address, and is privileged. Therefore, it cannot cause data storage interrupts when ZPR[Zn] = 00 or TLB\_entry[WR] = 0.

**icbi** and **icbt** are considered "loads" and cannot cause data storage interrupts when TLB\_entry[WR] = 0. **icbi** can cause data storage interrupts when ZPR[Zn] = 00. Because **icbt** is privileged, it cannot cause data storage interrupts when ZPR[Zn] = 00.

The **iccci** instruction cannot change data; an instruction cache line cannot be dirty. The **iccci** instruction is privileged and is considered a load. It does not cause data storage interrupts when ZPR[Zn] = 00 or TLB\_entry[WR] = 0.

Because **iccci** can cause a TLB miss interrupt, using **iccci** is not recommended when data address translation is enabled; if it is used, note that the specific operand address can cause an interrupt.

**icread** is considered a "load" from a non-specific address, and is privileged. Therefore, it cannot cause data storage interrupts when ZPR[Zn] = 00 or  $TLB_entry[WR] = 0$ .

# 6.7.3 Access Protection for String Instructions

The stswx instruction with string length equal to 0(XER[TBC] = 0) is a no-op.

When data address translation is enabled and the Transfer Byte Count (TBC) field of the Fixed Point Exception Register (XER) is 0, neither **Iswx** nor **stswx** can cause TLB miss interrupts, or data storage interrupts when ZPR[Zn] = 0 or TLB\_entry[WR] = 0.

# 6.8 Real-mode Storage Attribute Control

The PowerPC Architecture and the PowerPC Embedded Environment define several SPRs to control the following storage attributes in real mode: W, I, G,U0, and E. Note that the U0 and E attributes are not defined in the PowerPC Architecture. The E attribute is defined in the IBM PowerPC Embedded Environment, and the U0 attribute is implementation-specific. No storage attribute control register is implemented for the M storage attribute because the PPC405GP does not provide multi-processor support or hardware support for data coherency.

These SPRs, called storage attribute control registers, control the various storage attributes when address translation is disabled. When address translation is enabled, these registers are ignored, and the storage attributes supplied by the TLB entry are used (see "TLB Fields" on page 6-3).

The storage attribute control registers divide the 4GB real address space into thirty-two 128MB regions. In a storage attribute control register, bit 0 controls the lowest addressed 128MB region, bit 1 the next higher-addressed 128MB region, and so on.  $EA_{0:4}$  specify a storage control region.

For detailed information on the function of the storage attributes, see "Storage Attribute Fields" on page 6-5.

# 6.8.1 Storage Attribute Control Registers

Figure 6-6 shows a generic storage attribute control register. The storage attribute control registers have the same bit numbering and address ranges.

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

| Bit | Address Range             | Bit | Address Range             |
|-----|---------------------------|-----|---------------------------|
| 0   | 0x0000 0000-0x07FF FFFF   | 16  | 0x8000 0000-0x87FF FFFF   |
| 1   | 0x0800 0000-0x0FFF FFFF   | 17  | 0x8800 0000-0x8FFF FFFF   |
| 2   | 0x1000 0000-0x17FF FFFF   | 18  | 0x9000 0000-0x97FF FFFF   |
| 3   | 0x1800 0000-0x1FFF FFFF   | 19  | 0x9800 0000-0x9FFF FFFF   |
| 4   | 0x2000 0000-0x27FF FFFF   | 20  | 0xA000 0000-0xA7FF FFFF   |
| 5   | 0x2800 0000-0x2FFF FFFF   | 21  | 0xA800 0000-0xAFFF FFFF   |
| 6   | 0x3000 0000-0x37FF FFFF   | 22  | 0xB000 0000-0xB7FF FFFF   |
| 7   | 0x3800 0000-0x3FFF FFFF   | 23  | 0xB800 0000-0xBFFF FFFF   |
| 8   | 0x4000 0000-0x47FF FFFF   | 24  | 0xC000 0000-0xC7FF FFFF   |
| 9   | 0x4800 0000-0x4FFF FFFF   | 25  | 0xC800 0000-0xCFFF FFFF   |
| 10  | 0x5000 0000-0x57FF FFFF   | 26  | 0xD000 0000 - 0xD7FF FFFF |
| 11  | 0x5800 0000-0x5FFF FFFF   | 27  | 0xD800 0000-0xDFFF FFFF   |
| 12  | 0x6000 0000-0x67FF FFFF   | 28  | 0xE000 0000-0xE7FF FFFF   |
| 13  | 0x6800 0000-0x6FFF FFFF   | 29  | 0xE800 0000-0xEFFF FFFF   |
| 14  | 0x7000 0000 - 0x77FF FFFF | 30  | 0xF000 0000-0xF7FF FFFF   |
| 15  | 0x7800 0000-0x7FFF FFFF   | 31  | 0xF800 0000-0xFFFF FFFF   |

Figure 6-6. Generic Storage Attribute Control Register

#### 6.8.1.1 Data Cache Write-through Register (DCWR)

The DCWR controls write-through policy (the W storage attribute) for the data cache unit (DCU). Write-through is not applicable to the instruction cache unit (ICU).

After any reset, all DCWR bits are set to 0, which establishes a write-back write strategy for all regions.

The PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited.

# 6.8.1.2 Data Cache Cachability Register (DCCR)

The DCCR controls the I storage attribute for data accesses and cache management instructions. Note that the polarity of the bits in this register is opposite to that of the I attribute in the TLB; DCCR[Sn] = 1 enables caching, while TLB\_entry[I] = 1 inhibits caching.

After any reset, all DCCR bits are set to 0. No memory regions are cachable. Before memory regions can be designated as cachable in the DCCR, it is necessary to execute the **dccci** instruction once for each congruence class in the DCU cache array. This procedure invalidates all congruence classes. The DCCR can then be reconfigured, and the DCU can begin normal operation.

The PowerPC Architecture does not support memory models in which write-through is enabled and caching is inhibited.

# 6.8.1.3 Instruction Cache Cachability Register (ICCR)

The ICCR controls the I storage attribute for instruction fetches. Note that the polarity of the bits in this register is opposite of that of the I attribute (ICCR[Sn] = 1 enables caching, while TLB\_entry[I] = 1 inhibits caching).

After any reset, all ICCR bits are set to 0. No memory regions are cachable. Before memory regions can be designated as cachable in the ICCR, it is necessary to execute the **iccci** instruction. This invalidates all congruence classes. The ICCR can then be reconfigured, and the ICU can begin normal operation.

# 6.8.1.4 Storage Guarded Register (SGR)

The SGR controls the G storage attribute for instruction and data accesses.

This attribute does not affect data accesses; the PPC405GP does not perform speculative loads or stores.

After any reset, all SGR bits are set to 1, marking all storage as guarded. For best performance, system software should clear the guarded attribute of appropriate regions as soon as possible. If MSR[IR] = 1, the G attribute comes from the TLB entry. Attempting to execute from a guarded region in translate mode causes an instruction storage interrupt. See "Instruction Storage Interrupt" on page 10-38 for more information.

# 6.8.1.5 Storage User-defined 0 Register (SU0R)

The Storage User-defined 0 Register (SU0R) controls the user-defined (U0) storage attribute for instruction and data accesses.

After any reset, all SUOR bits are set to 0.

# 6.8.1.6 Storage Little-Endian Register (SLER)

The SLER controls the E storage attribute for instruction and data accesses.

This attribute determines the byte ordering of storage. "Byte Ordering" on page 3-28 provides a detailed description of byte ordering in the IBM PowerPC Embedded Environment.

After any reset, all SLER bits are set to 0 (big endian).

6-20 PPC405GP User's Manual

Part III. PPC405GP System Operations

III-2 PPC405GP User's Manual

# Chapter 7. Clocking

Clocking in the PPC405GP is highly configurable and supports a wide range of clock ratios on the internal and external buses.

Figure 7-1 illustrates the clocking options for the PPC405GP. A phase-locked loop (PLL) is the source for the CPU clock. Generated clock frequencies are integer ratios of this reference clock. Optional external clock inputs are shown where appropriate. The clocking inputs, which are highlighted in the figure (IICSCL is I/O), are described in more detail in Chapter 26, "Signal Summary."



Figure 7-1. PPC405GP Clocking

#### 7.1 PLL Overview

The PLL V<sub>DD</sub>A input to the PPC405GP requires 2.5 V  $\pm$  0.2 V, which should be supplied from a 2.5 V filtered board voltage.

The PLL operating range is controlled by forward divide and feedback divide ratios, tuning bits, and SysClk. The voltage controlled oscillator (VCO) in the PLL must operate at a range of 400–800 MHz. The value of the forward divide and feedback divide ratios affects the CPU frequency and the VCO operating frequency.

Several strapping values are required to correctly configure the PPC405GP. When setting the values, pay close attention to the following information to avoid accidentally configuring the controller in an unusable state.

For any acceptable SysClk input, the VCO frequency is set by the feedback and forward dividers, and the CPU to PLB divider, as shown in the following equation:

VCO = Reference Clock  $\times M$ 

where M = Feedback Divide × Forward Divide × CPU to PLB Divide

For example, with an input reference frequency of 33.33 MHz, feedback divider of 3, CPU to PLB divider of 2, and forward divider of 3, the VCO frequency at which the PLL stabilizes is 600 MHz.

Strap selection for PLL tuning depends upon the value of *M*, which can range from 6 to 32. The upper limit is based on a minimum input reference clock frequency of 25 MHz and a maximum VCO frequency of 800 MHz. The lower limit is based on a maximum input reference clock of 66 MHz and a minimum VCO frequency of 400MHz. *M* decreases as the reference clock frequency increases.

### 7.2 Input Reference Clock (SysClk)

The input reference clock, SysClk, must be between 25 MHz and 66 MHz for the PLL to achieve a stable lock. *Input clocks outside this range are not supported*. When synchronous PCI mode is selected, clock generation logic ensures that the internally generated PCI clock and SysClk are phase-aligned. This means that rising edges will coincide as long as the frequencies are the same. In most cases, the input reference clock is expected to be the same as the PCI clock provided to other PCI devices outside of the 405GP. Therefore, the phase alignment that automatically occurs ensures that the internally generated PCI clock matches the clock used by other PCI devices.

Clock generation logic also ensures that the internally generated peripheral clock (PerClk) is phasealigned with SysClk, as long as both run at the same clock frequency. This is useful when an external device, such as an external master, cannot be synchronized with the PPC405GP PerClk.

# 7.3 External Clock Strapping Setup

The PPC405GP configures its clocking based on strapping resistors connected to module I/O pins. The state of the strapping pins is stored in the Chip Pin Strapping Register (CPC0\_PSR) upon poweron or system reset. Software can use this read-only register to determine clock strapping values. Table 7-1 indicates which CPC0\_PSR fields are assigned to clocking functions and how they are encoded. See Chapter 9, "Pin Strapping and Sharing" for a more information and a complete list of strapping values.

| Strap Option                                                                                                                                                                                                                                                                                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL Forward Divide Ratio<br>CPC0_PSR[PFWD]<br>00 Bypass mode<br>01 Divide by 3<br>10 Divide by 4<br>11 Divide by 6                                                                                                                                                                                                         | These bits indicate bypass mode or one of three valid PLL<br>forward divide ratios.<br>Bypass mode is useful when the PPC405GP is run with a low-<br>frequency reference clock input that is too low for the PLL to<br>lock. For example, if the PPC405GP is clocked at 1 MHz in an<br>emulation system, the PLL cannot be used and should be<br>placed in bypass mode.<br>The other three strapping combinations select one of three valid<br>PLL forward divide ratios: 3, 4, or 6. These ratios are the only<br>acceptable ratios. |
| PLL Feedback Divide Ratio<br>CPC0_PSR[PFBD]<br>00 Divide by 1<br>01 Divide by 2<br>10 Divide by 3<br>11 Divide by 4                                                                                                                                                                                                        | These bits indicate one of four valid PLL feedback divide ratios: 1, 2, 3, or 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PLL Tuning<br>CPC0_PSR[PT]<br>000 Choice 1; TUNE[5:0] = 010001<br>001 Choice 2; TUNE[5:0] = 010010<br>010 Choice 3; TUNE[5:0] = 010011<br>011 Choice 4; TUNE[5:0] = 010100<br>100 Choice 5; TUNE[5:0] = 010101<br>101 Choice 6; TUNE[5:0] = 010110<br>110 Choice 7; TUNE[5:0] = 010111<br>111 Choice 8; TUNE[5:0] = 100100 | Note: The tune bits adjust parameters that control PLL jitter.<br>The recommended values minimize jitter for the PLL<br>implemented in the PPC405GP. These bits are shown for<br>information only, and do not require modification except in<br>special clocking circumstances, such as spread spectrum<br>clocking. For details on the use of spread spectrum clock<br>generators (SSCGs) with the PPC405GP, visit the<br>technical documents area of the IBM PowerPC web site.                                                      |
| PLB Divide Ratio from CPU<br>CPC0_PSR[PDC]<br>00 Divide by 1<br>01 Divide by 2<br>10 Divide by 3<br>11 Divide by 4                                                                                                                                                                                                         | These bits indicate one of four PLB divide ratios from the CPU: 1, 2, 3, or 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| OPB Divide Ratio from PLB<br>CPC0_PSR[ODP]<br>00 Divide by 1<br>01 Divide by 2<br>10 Divide by 3<br>11 Divide by 4                                                                                                                                                                                                         | These bits indicate one of four OPB divide ratios from the PLB:<br>1, 2, 3, or 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Table 7-1. Clo | ock Strappin | y Values |
|----------------|--------------|----------|
|----------------|--------------|----------|

| Strap Option                                                                                                                   | Description                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| PCI Divide Ratio from PLB<br>CPC0_PSR[PDP]<br>00 Divide by 1<br>01 Divide by 2<br>10 Divide by 3<br>11 Divide by 4             | These bits indicate one of four PCI divide ratios from the PLB: 1, 2, 3 or 4.             |
| Peripheral Bus Divide Ratio from PLB<br>CPC0_PSR[EBDP]<br>00 Divide by 2<br>01 Divide by 3<br>10 Divide by 4<br>11 Divide by 5 | These bits indicate one of four peripheral bus divide ratios from the PLB: 2, 3, 4, or 5. |

#### Table 7-1. Clock Strapping Values (continued)

Table 7-2 lists PLL tuning settings, which are controlled by the pin strappings reported by CPC0\_PSR[PT]. The tune bits adjust parameters that control PLL jitter. The recommended values minimize jitter for the PLL implemented in the PPC405GP. These bits are shown for information only, and do not require modification except in special clocking circumstances, such as spread spectrum clocking. For details on the use of spread spectrum clock generators (SSCGs) with the PPC405GP, visit the technical documents area of the IBM PowerPC web site.

Table 7-2. PLL Tuning Settings

| • | M Range            | Recommended Choice | CPC0_PSR[PT] Value | Equivalent TUNE[5:0] |
|---|--------------------|--------------------|--------------------|----------------------|
|   | 6≤ <i>M</i> ≤7     | 3                  | 010                | 010011               |
|   | 7 ≤ <i>M</i> ≤ 12  | 5                  | 100                | 010101               |
|   | 12 ≤ <i>M</i> ≤ 32 | 6                  | 101                | 010110               |

# 7.4 Sample Clock Ratios

Table 7-3, Table 7-4, and Table 7-5 list all usable clocking ratio combinations that can be achieved using the strapping inputs for three different reference clock frequencies. VCO frequencies and *M* multipliers are calculated for each valid combination of forward divide (FWD), CPU to PLB divide (CPU/PLB), and feedback divide (FBK). The resulting clock frequencies for CPU and PLB are also shown. To simplify the table, PCI, OPB, external bus, and serial clock frequencies are not shown.

Ratios that result in unusable configurations are not listed. In some cases, the table indicates identical CPU and PLB frequencies. However, in such cases, the VCO frequency varies. When the table indicates a choice of VCO frequencies, select the highest frequency in the range of 400–800 MHz for best PLL performance.

| Strapping Options    |                                              |     | Calculated Values (MHz) |                |           |         |
|----------------------|----------------------------------------------|-----|-------------------------|----------------|-----------|---------|
| FWD                  | CPU/PLB                                      | FBK | м                       | vco            | CPU       | PLB     |
| By-pass <sup>2</sup> | 1                                            | x   |                         | — .            | refclk    | refclk  |
|                      | 2                                            | x   | —                       |                | refclk    | refclk/ |
|                      | 3                                            | x   |                         |                | refclk    | refclk/ |
|                      | 4                                            | x   |                         | —              | refclk    | refclk/ |
| 3                    | 1                                            | 4   | 12                      | 400            | 133       | 133     |
| 3                    | 2                                            | 2   | 12                      | 400            | 133       | 66      |
| 3                    | 2                                            | 3   | 18                      | 600            | 200       | 100     |
| 3                    | 2                                            | 4   | 24                      | 800            | 266       | 133     |
| 3                    | 3                                            | 2   | 18                      | 600            | 200       | 66      |
| 3                    | 4                                            | 1   | 12                      | 400            | 133       | 33      |
| 3                    | 4                                            | 2   | 24                      | 800            | 266       | 66      |
| 4                    | 1                                            | 3   | 12                      | 400            | 100       | 100     |
| 4                    | 1                                            | 4   | 16                      | 533            | 133       | 133     |
| 4                    | 2                                            | 2   | 16                      | 533            | 133       | 66      |
| 4                    | 2                                            | 3   | 24                      | 800            | 200       | 100     |
| 4                    | 3                                            | 1   | 12                      | 400            | 100       | 33      |
| 4                    | 3                                            | 2   | 24                      | 800            | 200       | 66      |
| 4                    | 4                                            | 1   | 16                      | 533            | 133       | 33      |
| 6                    | 1                                            | 2   | 12                      | 400            | 66        | 66      |
| 6                    | 1                                            | 3   | 18                      | 600            | 100       | 100     |
| 6                    | 1                                            | 4   | 24                      | 800            | 133       | 133     |
| 6                    | 2                                            | 1   | 12                      | 400            | 66        | 33      |
| 6                    | 2                                            | 2   | 24                      | 800            | 133       | 66      |
| 6                    | 3                                            | 1   | 18                      | 600            | 100       | 33      |
| 6                    | . 4                                          | 1   | 24                      | 800            | 133       | 33      |
| Note 2: B            | = don't care.<br>y-pass mode<br>presentative |     |                         | or use only. ( | Contact y | our IBN |

Table 7-3. Possible Clocking Ratios for Reference Clock of 33.3 MHz

Note 3: Not all PPC405GP parts support the frequencies shown. Check PPC405GP Datasheet for supported CPU and PLB frequencies for a specific part number.

| Strapping Options    |                                                                  |     | Calculated Values (MHz) |       |        |          |  |
|----------------------|------------------------------------------------------------------|-----|-------------------------|-------|--------|----------|--|
| FWD                  | CPU/PLB                                                          | FBK | М                       | VCO   | CPU    | PLB      |  |
| By-pass <sup>2</sup> | 1                                                                | х   | _                       |       | refclk | refclk   |  |
|                      | 2                                                                | x   | _                       | —     | refclk | refclk/2 |  |
|                      | 3                                                                | х   |                         | -     | refclk | refclk/3 |  |
|                      | 4                                                                | x   | _                       |       | refclk | refclk/4 |  |
| 3                    | 2                                                                | 3   | 18                      | 450   | 150    | 75       |  |
| 3                    | 2                                                                | 4   | 24                      | 600   | 200    | 100      |  |
| 3                    | 3                                                                | 2   | 18                      | 450   | 150    | 50       |  |
| 3                    | 3                                                                | 3   | 27                      | 675   | 225    | 75       |  |
| 3                    | 4                                                                | 2   | 24                      | 600   | 200    | 50       |  |
| 4                    | 1                                                                | 4   | 16                      | . 400 | 100    | 100      |  |
| 4                    | 2                                                                | 2   | 16                      | 400   | 100    | 50       |  |
| 4                    | 2                                                                | 3   | 24                      | 600   | 150    | 75       |  |
| 4                    | 2                                                                | 4   | 32                      | 800   | 200    | 100      |  |
| 4                    | 3                                                                | 2   | 24                      | 600   | 150    | 50       |  |
| 4                    | 4                                                                | 1   | 16                      | 400   | 100    | 25       |  |
| 4                    | 4                                                                | 2   | 32                      | 800   | 200    | 50       |  |
| 6                    | 1                                                                | 3   | 18                      | 450   | 75     | 75       |  |
| 6                    | 1                                                                | 4   | 24                      | 600   | 100    | 100      |  |
| 6                    | 2                                                                | 2   | 24                      | 600   | 100    | 50       |  |
| 6                    | 3                                                                | 1   | 18                      | 450   | 75     | 25       |  |
| 6                    | 4                                                                | 1   | 24                      | 600   | 100    | 25       |  |
| Note 1: x            | = don't care.                                                    | •   |                         |       |        |          |  |
| Note 2: B            | Note 2: By-pass mode is designed for hardware emulator use only. |     |                         |       |        |          |  |

Table 7-4. Possible Clocking Ratios for Reference Clock of 25 MHz

Note 2: By-pass mode is designed for hardware emulator use only. Contact your IBM representative for more information.

Note 3: Not all PPC405GP parts support the frequencies shown. Check PPC405GP Datasheet for supported CPU and PLB frequencies for a specific part number.

| Strapping Options                                                |                         |     | Calculate | d Value | s (MHz) |            |
|------------------------------------------------------------------|-------------------------|-----|-----------|---------|---------|------------|
| FWD                                                              | CPU/PLB                 | FBK | м         | VCO     | CPU     | PLB        |
| By-pass <sup>2</sup>                                             | 1                       | x   | —         | -       | refclk  | refclk     |
|                                                                  | 2                       | x   | —         | -       | refclk  | refclk/2   |
|                                                                  | 3                       | х   | -         | -       | refclk  | refclk/3   |
|                                                                  | 4                       | х   | —         | 1       | refclk  | refclk/4   |
| 3                                                                | 2                       | 2   | 12        | 500     | 166     | 83         |
| 3                                                                | 2                       | 3   | 18        | 750     | 250     | 125        |
| 3                                                                | 3                       | 2   | 18        | 750     | 250     | 83         |
| 3                                                                | 4                       | 1   | 12        | 500     | 166     | 41         |
| 4                                                                | 1                       | 3   | 12        | 500     | 125     | 125        |
| 4                                                                | 2                       | 2   | 16        | 666     | 166     | 83 -       |
| 4                                                                | . 3                     | 1   | 12        | 500     | 125     | 41         |
| 4                                                                | 4                       | 1   | 16        | 666     | 166     | 41         |
| 6                                                                | 1                       | 2   | 12        | 500     | 83      | 83         |
| 6                                                                | 1                       | 3   | 18        | 750     | 125     | 125        |
| 6                                                                | 2                       | 1   | 12        | 500     | 83      | 41         |
| 6                                                                | 3                       | 1   | 18        | 750     | 125     | 4 <b>1</b> |
| Note 1: x                                                        | Note 1: x = don't care. |     |           |         |         |            |
| Note 2: By-pass mode is designed for hardware emulator use only. |                         |     |           |         |         |            |

Table 7-5. Possible Clocking Ratios for Reference Clock of 41.6 MHz

Contact your IBM representative for more information.

Note 3: Not all PPC405GP parts support the frequencies shown. Check PPC405GP Datasheet for supported CPU and PLB frequencies for a specific part number.

#### 7.5 PCI Clocking

The PPC405GP PCI interface can run synchronously or asynchronously relative to the on-chip PLB. The state at reset of the PCI Asynchronous Mode Enable (PAME) strapping pin selects synchronous PCI mode or asynchronous PCI mode. The state of the PAME pin is reported in the PAME field of the CPC0\_PSR. For information about the strapping pins, refer to PowerPC 405GP Embedded Processor Data Sheet, which is available from your IBM representative and in the Technical Library on the IBM Microelectronics web site (www.chips.ibm.com).

Lower PCI latency through the PCI logic occurs in synchronous PCI mode, which should be used for host-bridge applications in which the PCI bus frequency is less than or equal to 33 Mhz, and the PLB frequency is an integer multiple of the PCI frequency. PPC405GP applications for higher PCI frequencies, or for PCI adapters, should use asynchronous PCI mode.

# 7.5.1 PCI Clocks

The following clocks are related to the PCI logic:

- The on-chip PLB clock
- The on-chip synchronous PCI clock
- An external asynchronous PCI clock, PCIClk

In synchronous PCI mode, the asynchronous PCI clock input is ignored and the on-chip PCI logic runs synchronously at the selected PLB:PCI divide ratio. In synchronous mode, the derived PCI clock must equal SysClk.

In asynchronous PCI mode, the asynchronous PCI clock attaches to logic that interfaces with the PCI bus. The synchronous clock must always be provided to the PCI logic, even when the asynchronous PCI clock is used. Table 7-6 describes the relationships between the synchronous PCI clock, the asynchronous PCI clock, and the PLB clock.

In asynchronous PCI mode, the synchronous PCI clock must meet certain requirements. The following equation describes the relationship that must be maintained between the asynchronous PCI clock and synchronous PCI clock. Select an appropriate PCI:PLB ratio to maintain the relationship:

 $AsyncPClclock \leq SyncPClclock \leq ((2 \times AsyncPClclock) + 1 MHz)$ 

Table 7-6 lists supported and commonly used combinations of synchronous and asynchronous PCI clocks. In general, higher synchronous PCI clock frequencies provides better performance, while lower synchronous PCI clock frequencies minimize power consumption.

| Asynchronous<br>PCI Frequency | Synchronous<br>PCI Frequency | PLB Frequency | Sync PCI:PLB<br>Ratio |
|-------------------------------|------------------------------|---------------|-----------------------|
| 20 MHz                        | 33.3 MHz                     | 133.3 MHz     | 1:4                   |
|                               | 33.3 MHz                     | 100 MHz       | 1:3                   |
|                               | 27.6 MHz                     | 83.3 MHz      | 1:3                   |
| 33.3 MHz                      | 44.4 MHz                     | 133.3 MHz     | 1:3                   |
|                               | 33.3 MHz                     | 133.3 MHz     | 1:4                   |
|                               | 50 MHz                       | 100 MHz       | 1:2                   |
|                               | 41.6 MHz                     | 83.3 MHz      | 1:2                   |
| 40 MHz                        | 44.4 MHz                     | 133.3 MHz     | 1:3                   |
|                               | 50 MHz                       | 100 MHz       | 1:2                   |
|                               | 41.6 MHz                     | 83.3 MHz      | 1:2                   |
| 66.6 MHz                      | 66.6 MHz                     | 133.3 MHz     | 1:2                   |
|                               | 100 MHz                      | 100 MHz       | 1:1                   |
|                               | 83.3 MHz                     | 83.3 MHz      | 1:1                   |

Table 7-6. Example Synchronous PCI Clock Frequencies in Asynchronous Mode

#### 7.5.2 PCI Adapter Applications

Because various systems run PCI expansion buses at different PCI frequencies, several PCI clock frequencies may need to be supported when the PPC405GP is used in PCI adapters. Using the PCI

clock as a PPC405GP system clock input, as required for synchronous PCI mode, can adversely affect PPC405GP CPU performance. In some cases, the PPC405GP might not function.

For example, if the PPC405GP is used on a PCI adapter and the PCI expansion bus frequency is 33MHz, the PPC405GP strapping pins can be configured to run the chip at 200 MHz. However, if the same strapping configuration is used and the PPC405GP is used in a system in which the PCI expansion bus frequency is 25 MHZ (an application supported by the PCI specification), the PPC405GP would run suboptimally at 150 MHz. Worse problems would be encountered if the PCI frequency were less than 25 Mhz (the PPC405GP PLL locking frequency). In this application, the PPC405GP might not function. For these reasons, asynchronous PCI mode is recommended when the PPC405GP is used in PCI adapter applications.

Asynchronous PCI mode uses an externally provided PCI clock that does not interact with an on-chip PLL, so there is no lower frequency limit imposed by loss of PLL lock. However, the requirements resulting from the relationship between the synchronous and asynchronous PCI clocks must still be satisfied.

Note: Satisfying the equation in "PCI Clocks" on page 7-8 presents a potential problem. The strapping pin selection needed to set an acceptable synchronous PCI clock for a 33 MHz asynchronous PCI clock differs from the strapping pin selection for a 66 MHz asynchronous PCI clock. External logic is required to detect the state of the M66 pin on the PCI adapter interface and select appropriate PPC405GP strapping pins during system reset.

#### 7.6 Serial Port Clocking

The two PPC405GP UARTs (serial ports) can be clocked individually, either from an external serial clock or from an internally generated serial clock. The internally generated clock is derived from the CPU clock, and is CPU/n, where n ranges from 1 to 32. The divisor *n* is programmed by setting a value of 0 to 31 in CPC0\_CR0[UDIV] (see "Chip Control Register 0 (CPC0\_CR0)" on page 7-11). Subsequently, the serial clock input to the UART is further divided in the UART to generate the desired serial data rate (baud rate).

Refer to Chapter 21, "Serial Port Operations," for more information about choosing CPU clock and serial input clock divisors.

#### 7.7 Clocking Registers

Table 7-7 summarizes the Device Control Registers (DCRs) that control clocking in the PPC405GP.

| Register   | Address | R/W | Description             |
|------------|---------|-----|-------------------------|
| CPC0_PLLMR | 0x0B0   | R/O | PLL Mode Register       |
| CPC0_CR0   | 0x0B1   | R/W | Chip Control Register 0 |

CPC0\_CR0 selects the internal serial clock source. The clocking registers are read and written using the **mtdcr** and **mfdcr** instructions.

#### 7.7.1 PLL Mode Register (CPC0\_PLLMR)

The read-only CPC0\_PLLMR contains a number of PLL and clock divisor values.

CPC0\_PLLMR fields are based on the external strapping options.

The CPC0\_PLLMR is big endian. However, values returned for the CPC0\_PLLMR[FWDV, FBDV, TUN] fields are little endian to enable easier comparison of these bits with the PLL documentation in *ASIC SA-12E Databook* (available from your IBM representative), which uses little endian formats.



| 0:2 | FWDV | Forward Divisor<br>000 Forward divisor is 8.<br>001 Forward divisor is 7.<br>010 Forward divisor is 6.<br>011 Forward divisor is 5.<br>100 Forward divisor is 4.<br>101 Forward divisor is 3.<br>110 Forward divisor is 2.<br>111 Forward divisor is 1.                                                                                                                                                                                                                                                                                 | PLLOUTA Value:<br>50 MHz–100 MHz<br>58 MHz–114 MHz<br>66 MHz–134 MHz<br>80 MHz–160 MHz<br>100 MHz–200 MHz<br>133 MHz–267 MHz<br>200 MHz–400 MHz<br>400 MHz–800 MHz<br>Note: PLLOUTA is the CPU clock in<br>PPC405GP. |
|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:6 | FBDV | Feedback Divisor<br>0000 Feedback divisor is 16.<br>0001 Feedback divisor is 1.<br>0010 Feedback divisor is 2.<br>0011 Feedback divisor is 3.<br>0100 Feedback divisor is 4.<br>0101 Feedback divisor is 5.<br>0110 Feedback divisor is 6.<br>0111 Feedback divisor is 7.<br>1000 Feedback divisor is 8.<br>1001 Feedback divisor is 9.<br>1010 Feedback divisor is 10.<br>1011 Feedback divisor is 11.<br>1100 Feedback divisor is 12.<br>1101 Feedback divisor is 13.<br>1110 Feedback divisor is 14.<br>1111 Feedback divisor is 15. |                                                                                                                                                                                                                      |

#### Figure 7-2. PLL Mode Register (CPC0\_PLLMR)

| 7:12  | TUN  | TUNE[5:0] Field                                                                                                                                                                                                    | Note: The tune bits adjust parameters that<br>control PLL jitter. The recommended<br>values minimize jitter for the PLL<br>implemented in the PPC405GP.<br>These bits are shown for information<br>only, and do not require modification<br>except in special clocking<br>circumstances, such as spread<br>spectrum clocking. For details on the<br>use of spread spectrum clock<br>generators (SSCGs) with the<br>PPC405GP, visit the technical<br>documents area of the IBM<br>PowerPC web site. |
|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:14 | CBDV | CPU:PLB Frequency Divisor<br>00 CPU:PLB divisor is 1<br>01 CPU:PLB divisor is 2<br>10 CPU:PLB divisor is 3<br>11 CPU:PLB divisor is 4                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:16 | OPDV | OPB-PLB Frequency Divisor<br>00 OPB-PLB divisor is 1<br>01 OPB-PLB divisor is 2<br>10 OPB-PLB divisor is 3<br>11 OPB-PLB divisor is 4                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17:18 | PPDV | PCI–PLB Frequency Divisor<br>00 PCI–PLB divisor is 1<br>01 PCI–PLB divisor is 2<br>10 PCI–PLB divisor is 3<br>11 PCI–PLB divisor is 4                                                                              | See "PCI Clocks" on page 7-8 for details<br>regarding asynchronous PCI clocking and<br>how it relates to synchronous clocking.                                                                                                                                                                                                                                                                                                                                                                     |
| 19:20 | EPDV | External Bus–PLB Frequency Divisor<br>00 External bus–PLB divisor ratio is 2:1<br>01 External bus–PLB divisor ratio is 3:1<br>10 External bus–PLB divisor ratio is 4:1<br>11 External bus–PLB divisor ratio is 5:1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 21:31 |      | Reserved                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 7.7.2 Chip Control Register 0 (CPC0\_CR0)

Only CPC0\_CR0 fields related to clocking are shown in Figure 7-3. CPC0\_CR0<sub>0:23</sub>, which control GPIO and UART functions, are summarized in "CPC0\_CR0" on page 25-17.

TRE G11E G13E G15E G17E G19E G21E G23E RDS DRE U0EC UDIV 0 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 30 31 T T T T T T T T T T G10E G12E G14E G16E G18E G20E G22E DCS DTE DAEC U1EC

| Figure 7-3.  | Chip Contro | l Register 0 | (CPC0_CR0) |
|--------------|-------------|--------------|------------|
| i iguio i o. |             | i nogiotor o |            |

| 0:3 |      | Reserved                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | TRE  | CPU Trace Enable<br>0 GPIO1-9 are enabled<br>1 GPIO1-9 are disabled                            | Trace interface cannot be used when GPIO is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5   | G10E | GPIO 10 Enable<br>0 Enable PerCS1 as a chip select<br>1 Enable PerCS1 as GPIO10                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6   | G11E | GPIO 11 Enable<br>0 Enable PerCS2 as a chip select<br>1 Enable PerCS2 as GPIO11                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7   | G12E | GPIO 12 Enable<br>0 Enable PerCS3 as a chip select<br>1 Enable PerCS3 as GPIO12                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8   | G13E | GPIO 13 Enable<br>0 Enable PerCS4 as a chip select<br>1 Enable PerCS4 as GPIO13                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9   | G14E | GPIO 14 Enable<br>0 Enable PerCS5 as a chip select<br>1 Enable PerCS5 as GPIO14                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10  | G15E | GPIO 15 Enable<br>0 Enable PerCS6 as a chip select<br>1 Enable PerCS6 as GPIO15                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11  | G16E | GPIO 16 Enable<br>0 Enable PerCS7 as a chip select<br>1 Enable PerCS7 as GPIO16                | · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12  | G17E | GPIO 17 Enable<br>0 Enable interrupt IRQ0 as an interrupt<br>1 Enable interrupt IRQ0 as GPIO17 | The purpose of GPIO_17_EN through<br>GPIO_23_EN is to isolate the interrupt<br>controller from activity on a shared pin<br>when that pin is being used as a GPIO. For<br>instance, when G17E is set to a 1, IRQ0 at<br>the UIC will always be forced to a zero.<br>Note: Setting G17E to a 0 will not prevent<br>GPIO channel 17 (if configured as an<br>output) from creating contention with<br>the off-chip source of the IRQ input.<br>Therefore, be sure to leave the shared<br>GPIO channel disabled when using<br>the pin as an interrupt input. |

| 13 | G18E | GPIO 18 Enable<br>0 Enable interrupt IRQ1 as an interrupt<br>1 Enable interrupt IRQ1 as GPIO18                                                                                                                                                                                   |
|----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14 | G19E | GPIO 19 Enable<br>0 Enable interrupt IRQ2 as an interrupt<br>1 Enable interrupt IRQ2 as GPIO19                                                                                                                                                                                   |
| 15 | G20E | GPIO 20 Enable<br>0 Enable interrupt IRQ3 as an interrupt<br>1 Enable interrupt IRQ3 as GPIO20                                                                                                                                                                                   |
| 16 | G21E | GPIO 21 Enable<br>0 Enable interrupt IRQ4 as an interrupt<br>1 Enable interrupt IRQ4 as GPIO21                                                                                                                                                                                   |
| 17 | G22E | GPIO 22 Enable<br>0 Enable interrupt IRQ5 as an interrupt<br>1 Enable interrupt IRQ5 as GPIO22                                                                                                                                                                                   |
| 18 | G23E | GPIO 23 Enable<br>0 Enable interrupt IRQ6 as an interrupt<br>1 Enable interrupt IRQ6 as GPIO23                                                                                                                                                                                   |
| 19 | DCS  | DSR/CTS select<br>0 DSR is selected.<br>1 CTS is selected.                                                                                                                                                                                                                       |
| 20 | RDS  | RTS/DTR select<br>0 RTS is selected.<br>1 DTR is selected.                                                                                                                                                                                                                       |
| 21 | DTE  | DMA Transmit Enable for UART0<br>0 DMA transmit channel is disabled.<br>1 DMA transmit channel is enabled.                                                                                                                                                                       |
| 22 | DRE  | DMA Receive Enable for UART0<br>0 DMA receive channel is disabled.<br>1 DMA receive channel is enabled.                                                                                                                                                                          |
| 23 | DAEC | <ul> <li>DMA Allow Enable Clear for UART0</li> <li>0 DTE and DRE for UART0 are not cleared<br/>when the UART receives a corresponding<br/>terminal count.</li> <li>1 DTE and DRE for UART0 are cleared<br/>when the UART receives a corresponding<br/>terminal count.</li> </ul> |
| 24 | UOEC | Select External Clock for UART0<br>0 UART0 uses the internally derived serial<br>clock<br>1 UART0 uses the external serial clock<br>input                                                                                                                                        |
| 25 | U1EC | Select External Clock for UART1<br>0 UART1 uses the internally derived serial<br>clock<br>1 UART1 uses the external serial clock<br>input                                                                                                                                        |

| 26:30 | UDIV | UART Internal Clock Divisor<br>00000 Divide by 1<br>00001 Divide by 2<br>00010 Divide by 3 | UDIV specifies the divisor of the CPU clock<br>frequency used to derive a UART serial<br>clock frequency. For example, if the CPU is<br>running at 200MHz, a divider value of 20<br>sets the serial clock frequency to 10MHz.<br><b>Note:</b> The maximum serial clock<br>frequency is less than 1/2 × OPB<br>frequency |
|-------|------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    |      | Reserved                                                                                   |                                                                                                                                                                                                                                                                                                                         |

# Chapter 8. Reset and Initialization

This chapter describes reset operations, the initial state of the PPC405GP processor core after a reset, and an example of the initialization code required to begin executing application code. Initialization of external system components or system-specific chip facilities must also be performed, in addition to the basic initialization described in this chapter.

Reset operations affect the PPC405GP at power on time as well as during normal operation, if programmed to do so. To understand how these operations work it is necessary to first understand the signal pins involved as well as the terminology of core, chip and system resets.

# 8.1 Reset Signals

The PPC405GP provides two reset signals, SysReset and ExtReset. SysReset is bidirectional and ExtReset is an output.

When the SysReset signal is an input (asserted by an off-chip device), such as during power on reset (POR), the chip responds by performing a system reset as described in a following section. An external assertion of SysReset is not extended by an assertion of the open drain bidirectional SysReset driver.

As an output, the PPC405GP asserts the SysReset signal when a system reset request is detected. The SysReset open drain driver is activated and the signal is driven low for 8192 SysClk periods. This enables the PPC405GP to reset itself and other devices attached to the same reset network.

The ExtReset signal is used by synchronous peripheral devices served by the PerClk external bus clock, such as ROM and external bus masters. During chip and system resets, ExtReset is asserted until the PerClk signal is stable and all internal resets are released.

# 8.2 Reset Types

Three types of reset, each with different scope, are possible in the PPC405GP. A core reset affects only the processor core. Chip resets affect the processor core and all on-chip peripherals. System resets affect the processor core, all on-chip peripherals, and any off-chip devices connected to the PPC405GP reset net. Refer to chapters describing the on-chip peripherals for detailed information about their reset behavior.

### 8.2.1 Core Reset

A core reset results in a reset of the processor core. No other on-chip logic is affected. Clocking logic, outside the processor core, detects the core reset request and asserts the reset input to the processor core for a period of 16 processor core clock cycles.

### 8.2.2 Chip Reset

A chip reset results in the reset of the processor core and on-chip peripherals. Clocking logic detects the request for a chip reset and asserts the reset input to the processor core for a period of 16 processor core clock cycles. Subsequently, PLL locking is performed as described for a system reset.

During chip reset, the ExtReset signal is driven low to ensure the reset of synchronous devices that use the external bus clock signal, PerClk.

#### 8.2.3 System Reset

A system reset results in a reset of all PPC405GP logic, including the processor core, internal phaselocked loop (PLL), and on-chip peripherals. A system reset can be initiated externally or internally. External system resets are initiated by the assertion of the SysReset signal for at least 16 SysClk cycles. Internal system resets are initiated by either the processor core or PCI power management logic.

When a system reset is requested internally, the bidirectional open drain SysReset signal is asserted to enable other chips to be reset at the same time. In this case, the SysReset signal is driven low for 8192 SysClk cycles, resulting in a System reset of the PPC405GP chip and all other devices attached to the reset network connected to SysReset.

After the SysReset signal is deasserted, the PLL begins its locking process, which also requires 8192 SysClk cycles. When 64 SysClk cycles remain, the internal PPC405GP clocks (OPB, PCI, EXT, and Serial) begin toggling. The PLB and CPU clocks toggle while SysReset is asserted, and during the PLL locking process. When the PLL lock timer expires, internal resets are released, and the processor core begins its initial instruction fetch.

During system reset, the ExtReset signal is driven low to ensure the reset of synchronous devices that use the external bus clock signal, PerClk.

# 8.3 PCI Power Management Initiated Resets

An external PCI master can write the Power Management Control/Status Register (PCIC0\_PMCSR) to request a change from the D3hot PCI power management state to the D0 state. The on-chip PCI logic always accepts such a write and assumes that requested state changes from D3hot are always to D0. After receiving such a write, the PCI logic asserts a signal that immediately results in an internally requested system reset.

### 8.4 **Processor Initiated Resets**

The processor core in the PPC405GP can request three types of processor resets: core, chip, and system. Each type of reset can be generated by a JTAG debug tool, by the second expiration of the watchdog timer, or by writing a non-zero value to the Reset (RST) field of the Debug Control Register 0 (DBCR0).

The effects of core and chip resets on the processor core are identical. To determine which reset type occurred, the most-recent reset (MRR) field of the Debug Status Register (DBSR) can be examined.

### 8.5 Processor State After Reset

After a reset, the contents of the Machine State Register (MSR) and the Special Purpose Registers (SPRs) control the initial processor state. The contents of Device Control Registers (DCRs) control the initial states of on-chip devices. Chapter 25, "Register Summary," contains descriptions of the registers.

In general, the contents of SPRs are undefined after a reset. Reset initializes the minimum number of SPR fields required for allow successful instruction fetching. "Contents of Special Purpose Registers after Reset" on page 8-4 describes these initial values. System software fully configures the processor.

"Machine State Register Contents after Reset" on page 8-3 describes the MSR contents.

The MCI field of the Exception Syndrome Register (ESR) is cleared so that it can be determined if there has been a machine check during initialization, before machine check exceptions are enabled.

Two SPRs contain status on the type of reset that has occurred. The Debug Status Register (DBSR) contains the most recent reset type. The Timer Status Register (TSR) contains the most recent watchdog reset.

#### 8.6 Processor Register Contents After Reset

After a reset, the contents of the SPRs control the initial processor state. The initial register contents vary with the type of reset that occurred.

Chapter 25, "Register Summary," contains descriptions of the registers referred to in Table 8-1 through Table 8-3.

#### 8.6.1 Machine State Register Contents after Reset

After all resets, all fields of the Machine State Register (MSR) contain zeros. Table 8-1 shows how this affects chip operation.

| Register | Field | Core<br>Reset | Chip<br>Reset | System<br>Reset | Comment                           |
|----------|-------|---------------|---------------|-----------------|-----------------------------------|
| MSR      | WE    | 0             | 0             | 0               | Wait state disabled               |
|          | CE    | 0             | 0             | 0               | Critical interrupts disabled      |
|          | EE    | . 0           | 0             | 0               | External interrupts disabled      |
|          | PR    | 0             | 0             | 0               | Supervisor mode                   |
|          | ME    | 0             | 0             | 0               | Machine check exceptions disabled |
|          | DWE   | 0             | 0             | 0               | Debug wait mode disabled          |
|          | DE    | 0             | 0             | 0               | Debug interrupts disabled         |
|          | DR    | 0             | 0             | 0               | Instruction translation disabled  |
|          | IR    | 0             | 0             | 0               | Data translation disabled         |

Table 8-1. MSR Contents after Reset

#### 8.6.2 Contents of Special Purpose Registers after Reset

In general, the contents of Special Purpose Registers (SPRs) are undefined after a core, chip, or system reset. Some SPRs retain the contents they had before a reset occurred.

Table 8-2 shows the contents of SPRs that are defined or unchanged after core, chip, and system resets.

| Register | Bits/Fields | Core Reset | Chip Reset | System Reset | Comment                             |
|----------|-------------|------------|------------|--------------|-------------------------------------|
| DBCR0    | EDM         | 0          | 0          | 0            | External debug mode disabled        |
| I        | RST         | 00         | 00         | 00           | No reset action.                    |
| DBCR1    | 0:31        | 0x00000000 | 0x00000000 | 0x00000000   | Instruction, data compares disabled |
| DBSR     | MRR         | 01         | 10         | 11           | Most recent reset                   |
| DCCR     | S0:S31      | 0x00000000 | 0x00000000 | 0x00000000   | Data cache disabled                 |
| ESR      | 0:31        | 0x00000000 | 0x00000000 | 0x00000000   | No exception syndromes              |
| ICCR     | S0:S31      | 0x00000000 | 0x00000000 | 0x00000000   | Instruction cache disabled          |
| PVR      | 0:31        |            |            |              | Processor version                   |
| SGR      | G0:G31      | 0xFFFFFFFF | 0xFFFFFFFF | 0xFFFFFFFF   | Storage is guarded                  |
| SLER     | S0:S31      | 0x00000000 | 0x00000000 | 0x00000000   | Storage is big endian               |
| SUOR     | K0:K31      | 0x00000000 | 0x00000000 | 0x00000000   | Storage is uncompressed             |

Table 8-2. SPR Contents After Reset

# 8.7 DCR Contents after Reset

DCR reset values are unaffected by core resets and are generally identical for chip and system resets.

| Register        | Bits    | Reset Value       | Comment                                                                                                   |
|-----------------|---------|-------------------|-----------------------------------------------------------------------------------------------------------|
| Chip Control    |         | ·····             |                                                                                                           |
| CP0_PSR         | 0:31    | · · · · · · · · · | At POR, CPC0_PSR fields are set to the strapping values of the corresponding pins. CPC0_PSR is read-only. |
| CPC0_CR0        | 0:31    | 0x0000003C        |                                                                                                           |
| CPC0_CR1        | 0:31    | 0x2B0DB800        |                                                                                                           |
| CPC0_JTAGID     | 0:31    |                   | Refer to <i>PPC405GP Embedded Processor Data Sheet</i> for the value of this read-only register.          |
| CPC0_PLLMR      | 0:31    |                   | At POR, CPC0_PLLMR fields are set to strapping values of the corresponding pins. CPC0_PLLMR is read-only. |
| Clock and Power | Managem | ent (CPM)         |                                                                                                           |
| CPC0_ER         | 0:31    | 0xFFFF8000        | CPC0_ER <sub>0:16</sub> return 1, CPC0_ER <sub>17:31</sub> return 0.                                      |

Table 8-3. DCR Contents After Reset

| CPC0_FR         0:31         0x0000000           CPC0_SR         0:31         0x0000000           Decompression Controller           DCP0_ADDR0         0:31         0x0000000           DCP0_ADDR1         0:31         0x0000000           DCP0_ADDR1         0:31         0x0000000           DCP0_MEMBEAR         0:31         0x0000000           DCP0_CFG         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_TR3         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x000000           DCP0_PLBBEAR         0:31         0x000000           DCP0_PLBAMOFF         1KB         Undefined           DCP0_RAMOF         1KB         0x000000           DMA0_CR1         0:31         0x000000           DMA0_CR2         0:31         0x000000           DMA0_CR3         0:31         0x000000           DMA0_CR3         0:31         0x000000           DMA0_CT1         0:31         0x000000 </th <th>Register</th> <th>Bits</th> <th>Reset Value</th> <th>Comment</th>                                                                        | Register           | Bits    | Reset Value | Comment                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------|-------------|---------------------------------------|
| Decompression Controller           DCP0_ADDR0         0:31         0x0000000           DCP0_ADDR1         0:31         0x0000000           DCP0_MEMBEAR         0:31         0x0000000           DCP0_ESR         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_RAM3FF         1KB         Undefined           DCP0_RAM3FF         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT3         0:31                                                                                                                                                          | CPC0_FR            | 0:31    | 0x00000000  |                                       |
| DCP0_ADDR0         0:31         0x0000000           DCP0_ADDR1         0:31         0x0000000           DCP0_MEMBEAR         0:31         0x0000000           DCP0_ESR         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_FLBBEAR         0:31         0x0000000           DCP0_VER         0:31         0x0000000           DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1                                                                                                                                                              | CPC0_SR            | 0:31    | 0x00000000  |                                       |
| DCP0_ADDR1         0:31         0x0000000           DCP0_MEMBEAR         0:31         0x0000000           DCP0_CFG         0:31         0x0000000           DCP0_ESR         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x000000           DCP0_ITOR1         0:31         0x000000           DCP0_ITOR2         0:31         0x000000           DCP0_ITOR3         0:31         0x000000           DCP0_RAM0-         0:31         0x000000           DCP0_RAM3FF         0:31         0x000000           DCP0_RAM3FF         0:31         0x0000000           Drect Memory Acces         DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT1         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT3         0:31         0x0000000         DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000 <td< td=""><td>Decompression Con</td><td>troiler</td><td>L</td><td></td></td<>                                          | Decompression Con  | troiler | L           |                                       |
| DCP0_MEMBEAR         0:31         0x0000000           DCP0_CFG         0:31         0x0000000           DCP0_ESR         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x000000           DCP0_ITOR1         0:31         0x000000           DCP0_ITOR2         0:31         0x000000           DCP0_ITOR3         0:31         0x000000           DCP0_RAM0-         0:31         0x000000           DCP0_RAM0-         0:31         0x000000           DCP0_RAM3FF         1KB         Undefined           DCP0_RAM3FF         0:31         0x0000000           Drect Memory Acces         DMA0_CR0         0:31           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1                                                                                                                                                                   | DCP0_ADDR0         | 0:31    | 0x00000000  |                                       |
| DCP0_CFG         0.31         0x0000001           DCP0_ESR         0.31         0x0000000           DCP0_ID         0.31         0x0000000           DCP0_ITOR0         0.31         0x0000000           DCP0_ITOR1         0.31         0x0000000           DCP0_ITOR2         0.31         0x0000000           DCP0_ITOR3         0.31         0x0000000           DCP0_ITOR3         0.31         0x0000000           DCP0_RAM0-         0.31         0x0000000           DCP0_RAM3FF         0.31         0x0000000           DCP0_VER         0.31         0x0000000           DMA0_CR0         0.31         0x0000000           DMA0_CR1         0.31         0x000000           DMA0_CR3         0.31         0x000000           DMA0_CR3         0.31         0x000000           DMA0_CT1         0.31         0x000000           DMA0_CT2         0.31         0x000000           DMA0_CT3         0.31         0x000000           DMA0_CT3         0.31         0x000000           DMA0_DA1         0.31         0x000000           DMA0_DA2         0.31         0x000000           DMA0_DA3         0.31                                                                                                                                                                        | DCP0_ADDR1         | 0:31    | 0x00000000  |                                       |
| DCP0_ESR         0:31         0x0000000           DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x0000000           DCP0_RAMO-         DCP0_KER         0:31         0x0000000           DCP0_VER         0:31         0x0000000         Dececccccccccccccccccccccccccccccccccc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DCP0_MEMBEAR       | 0:31    | 0x00000000  | · · · · · · · · · · · · · · · · · · · |
| DCP0_ID         0:31         0x0000000           DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_RAM0-         0:31         0x0000000           DCP0_RAM0-         1KB         Undefined           DCP0_VER         0:31         0x0000000           Drect Memory Access/         DMA0_CR0         0:31           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1                                                                                                                                                                   | DCP0_CFG           | 0:31    | 0x00000001  |                                       |
| DCP0_ITOR0         0:31         0x0000000           DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_RAM0-         0:31         0x0000000           DCP0_RAM0-         1KB         Undefined           DCP0_VER         0:31         0x0000000           Drett Memory Access/         DMA0_CR0         0:31           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0                                                                                                                                                          | DCP0_ESR           | 0:31    | 0x00000000  |                                       |
| DCP0_ITOR1         0:31         0x0000000           DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x0000000           DCP0_PLBMC         1KB         Undefined           DCP0_RAM0-         0:31         0x00000200           DCP0_VER         0:31         0x0000000           Drect Memory Access         DW           DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0                                                                                                                                                          | DCP0_ID            | 0:31    | 0x0000504D  |                                       |
| DCP0_ITOR2         0:31         0x0000000           DCP0_ITOR3         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x0000000           DCP0_RAM3FF         1KB         Undefined           DCP0_VER         0:31         0x0000000           Direct Memory Access         OMU           DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_POL         0:31         0x00000                                                                                                                                                          | DCP0_ITOR0         | 0:31    | 0x00000000  |                                       |
| DCP0_ITOR3         0:31         0x0000000           DCP0_PLBBEAR         0:31         0x0000000           DCP0_RAM0-<br>DCP0_RAM3FF         1KB         Undefined           DCP0_VER         0:31         0x0000000           Direct Memory Access         DMA0_<br>CR0         0:31         0x0000000           DMA0_CR0         0:31         0x0000000         DMA0_<br>CR1         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_<br>CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000         DMA0_<br>CR1         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_<br>DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000         DMA0_<br>DMA0_DA1         0:31         0x000000           DMA0_DA1         0:31         0x0000000         DMA0_<br>DMA0_DA3         0:31         0x000000           DMA0_DA2         0:31         0x0000000         DMA0_<br>DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_<br>DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000         DMA0_<br>DMA0_SA1         0:31<                     | DCP0_ITOR1         | 0:31    | 0x00000000  |                                       |
| DCP0_PLBBEAR         0:31         0x0000000           DCP0_RAM0-<br>DCP0_RAM3FF         1KB         Undefined           DCP0_VER         0:31         0x0000200           Direct Memory Access         DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_CR2         0:31         0x0000000           DMA0_CR2         0:31         0x0000000         DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT3         0:31         0x0000000         DMA0_CT3         0:31         0x0000000           DMA0_DA1         0:31         0x0000000         DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000                                                                          | DCP0_ITOR2         | 0:31    | 0x00000000  |                                       |
| DCP0_RAM0F_<br>DCP0_RAM3FF         1KB         Undefined           DCP0_VER         0:31         0x0000200           Direct Memory Access         DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_CR2         0:31         0x0000000           DMA0_CR2         0:31         0x0000000         DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT3         0:31         0x0000000         DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000         DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000         DMA0_DA2         0:31         0x0000000           DMA0_DA2         0:31         0x0000000         DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA2         0:31         0x0000000 <td< td=""><td>DCP0_ITOR3</td><td>0:31</td><td>0x00000000</td><td></td></td<> | DCP0_ITOR3         | 0:31    | 0x00000000  |                                       |
| DCP0_RAM3FF         Image: colored state           DCP0_VER         0:31         0x0000200           Direct Memory Access         DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000         DMA0_CR2         0:31         0x0000000           DMA0_CR2         0:31         0x0000000         DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000         DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000         DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000         DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000         DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_SA0         0:31         0x0000000         DMA0_DA3         0:31         0x0000000           DMA0_SA1         0:31         0x0000000         DMA0_DA3         0:31         0x0000000                                                                                               | DCP0_PLBBEAR       | 0:31    | 0x00000000  |                                       |
| Direct Memory Access (DMA)           DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                  |                    | 1KB     | Undefined   |                                       |
| DMA0_CR0         0:31         0x0000000           DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                   | DCP0_VER           | 0:31    | 0x00000200  |                                       |
| DMA0_CR1         0:31         0x0000000           DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Direct Memory Acce | ss (DM  | A)          |                                       |
| DMA0_CR2         0:31         0x0000000           DMA0_CR3         0:31         0x0000000           DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DMA0_CR0           | 0:31    | 0x00000000  |                                       |
| DMA0_CR3         0:31         0x0000000           DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DMA0_CR1           | 0:31    | 0x00000000  |                                       |
| DMA0_CT0         0:31         0x0000000           DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DMA0_CR2           | 0:31    | 0x00000000  |                                       |
| DMA0_CT1         0:31         0x0000000           DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMA0_CR3           | 0:31    | 0x00000000  |                                       |
| DMA0_CT2         0:31         0x0000000           DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DMA0_CT0           | 0:31    | 0x00000000  |                                       |
| DMA0_CT3         0:31         0x0000000           DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DMA0_CT1           | 0:31    | 0x00000000  |                                       |
| DMA0_DA0         0:31         0x0000000           DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DMA0_CT2           | 0:31    | 0x00000000  |                                       |
| DMA0_DA1         0:31         0x0000000           DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DMA0_CT3           | 0:31    | 0x00000000  |                                       |
| DMA0_DA2         0:31         0x0000000           DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DMA0_DA0           | 0:31    | 0x00000000  |                                       |
| DMA0_DA3         0:31         0x0000000           DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DMA0_DA1           | 0:31    | 0x00000000  |                                       |
| DMA0_POL         0:31         0x0000000           DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | DMA0_DA2           | 0:31    | 0x00000000  |                                       |
| DMA0_SA0         0:31         0x0000000           DMA0_SA1         0:31         0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMA0_DA3           | 0:31    | 0x0000000   |                                       |
| DMA0_SA1 0:31 0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DMA0_POL           | 0:31    | 0x0000000   |                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DMA0_SA0           | 0:31    | 0x0000000   |                                       |
| DMA0_SA2 0:31 0x0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DMA0_SA1           | 0:31    | 0x00000000  |                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DMA0_SA2           | 0:31    | 0x0000000   |                                       |

#### Table 8-3. DCR Contents After Reset (continued)

| Register              | Bits    | Reset Value | Comment                       |
|-----------------------|---------|-------------|-------------------------------|
| DMA0_SA3              | 0:31    | 0x00000000  |                               |
| DMA0_SG0              | 0:31    | 0x00000000  |                               |
| DMA0_SG1              | 0:31    | 0x00000000  |                               |
| DMA0_SG2              | 0:31    | 0x00000000  |                               |
| DMA0_SG3              | 0:31    | 0x00000000  |                               |
| DMA0_SGC              | 0:31    | 0x00000000  |                               |
| DMA0_SLP              | 0:31    | 0x7C000000  |                               |
| DMA0_SR               | 0:31    | 0x00000000  |                               |
| External Bus Control  | ler (EE | BC)         |                               |
| EBC0_B0AP             | 0:31    | 0x7F8FFE80  | Slowest possible bus timings. |
| EBC0_B0CR             | 0:31    | 0xFFE28000  | 2MB read-only bank.           |
| EBC0_B1AP             | 0:31    | 0x00000000  |                               |
| EBC0_B1CR             | 0:31    | 0x00000000  |                               |
| EBC0_B2AP             | 0:31    | 0x00000000  |                               |
| EBC0_B2CR             | 0:31    | 0x00000000  |                               |
| EBC0_B3AP             | 0:31    | 0x00000000  |                               |
| EBC0_B3CR             | 0:31    | 0x00000000  |                               |
| EBC0_B4AP             | 0:31    | 0x00000000  |                               |
| EBC0_B4CR             | 0:31    | 0x00000000  |                               |
| EBC0_B5AP             | 0:31    | 0x00000000  |                               |
| EBC0_B5CR             | 0:31    | 0x00000000  |                               |
| EBC0_B6AP             | 0:31    | 0x00000000  |                               |
| EBC0_B6CR             | 0:31    | 0x00000000  |                               |
| EBC0_B7AP             | 0:31    | 0x00000000  |                               |
| EBC0_B7CR             | 0:31    | 0x0000000   |                               |
| EBC0_BEAR             | 0:31    | 0x00000000  |                               |
| EBC0_BESR0            | 0:31    | 0x00000000  |                               |
| EBC0_BESR1            | 0:31    | 0x00000000  |                               |
| EBC0_CFG              | 0:31    | 0x00000000  |                               |
| Indirect Addressing F | Regist  | ers         |                               |
| DCP0_CFGADDR          |         | 0x00000000  |                               |
| DCP0_CFGDATA          |         | 0x00000000  |                               |
| EBC0_CFGADDR          |         | 0x00000000  |                               |

Table 8-3. DCR Contents After Reset (continued)

| Register             | Bits        | Reset Value | Comment                               |
|----------------------|-------------|-------------|---------------------------------------|
| EBC0_CFGDATA         |             | 0x00000000  |                                       |
| SDRAM0_CFGADDR       |             | 0x00000000  |                                       |
| SDRAM0_CFGDATA       |             | 0x00000000  | · · · · · · · · · · · · · · · · · · · |
| Media Access Layer ( | MAL)        | L           |                                       |
| MAL0_CFG             | 0:31        | 0x0007C000  |                                       |
| MAL0_ESR             | 0:31        | 0x00000000  |                                       |
| MAL0_IER             | 0:31        | 0x00000000  |                                       |
| MAL0_RCBS0           | 0:31        | Undefined   |                                       |
| MAL0_RXCASR          | 0:31        | 0x00000000  |                                       |
| MAL0_RXCTP0R         | 0:31        | Undefined   |                                       |
| MAL0_RXDEIR          | 0:31        | 0x00000000  |                                       |
| MAL0_RXEOBISR        | 0:31        | 0x00000000  |                                       |
| MAL0_TXCASR          | 0:31        | 0x00000000  |                                       |
| MAL0_TXCTP0R         | 0:31        | Undefined   |                                       |
| MAL0_TXCTP1R         | 0:31        | Undefined   | · · · · · · · · · · · · · · · · · · · |
| MAL0_TXDEIR          | 0:31        | 0x00000000  |                                       |
| MAL0_TXEOBISR        | 0:31        | 0x00000000  |                                       |
| On-Chip Buses        |             |             |                                       |
| PLB0_ACR             | 0:31        | 0x00000000  |                                       |
| PLB0_BEAR            | 0:31        | Undefined   |                                       |
| POB0_BEAR            | 0:31        | Undefined   |                                       |
| POB0_BESR0           | 0:31        | 0x00000000  |                                       |
| POB0_BESR1           | 0:31        | 0x00000000  |                                       |
| On-Chip Memory       | •           |             |                                       |
| OCM0_DSARC           | 0:31        | Undefined   |                                       |
| OCM0_DSCNTL          | 0:31        | 0x40000000  |                                       |
| OCM0_ISARC           | 0:31        | Undefined   |                                       |
| OCM0_ISCNTL          | 0:31        | 0x40000000  |                                       |
| SDRAM Controller     | • • • • • • | ·····       |                                       |
| SDRAM0_B0CR          | 0:31        | 0x00000000  |                                       |
| SDRAM0_B1CR          | 0:31        | 0x00000000  |                                       |
| SDRAM0_B2CR          | 0:31        | 0x00000000  |                                       |
| SDRAM0_B3CR          | 0:31        | 0x00000000  |                                       |

#### Table 8-3. DCR Contents After Reset (continued)

| Register              | Bits   | Reset Value | Comment |
|-----------------------|--------|-------------|---------|
| SDRAM0_BEAR           | 0:31   | 0x00000000  |         |
| SDRAM0_BESR0          | 0:31   | 0x00000000  |         |
| SDRAM0_BESR1          | 0:31   | 0x00000000  |         |
| SDRAM0_CFG            | 0:31   | 0x00000000  |         |
| SDRAM0_ECCCFG         | 0:31   | 0x00000000  |         |
| SDRAM0_ECCESR         | 0:31   | 0x00000000  |         |
| SDRAM0_PMIT           | 0:31   | 0x07C00000  |         |
| SDRAM0_RTR            | 0:31   | 0x05F00000  |         |
| SDRAM0_TR             | 0:31   | 0x00854009  |         |
| Universal Interrupt C | ontrol | ler (UIC)   |         |
| UIC0_CR               |        | Undefined   |         |
| UIC0_ER               |        | 0x00000000  |         |
| UIC0_MSR              |        | Undefined   |         |
| UIC0_PR               |        | Undefined   |         |
| UIC0_SR               |        | Undefined   |         |
| UIC0_TR               |        | Undefined   |         |
| UIC0_VCR              |        | Undefined   |         |
| UIC0_VR               |        | Undefined   |         |

Table 8-3. DCR Contents After Reset (continued)

# 8.8 MMIO Register Contents After Reset

MMIO registers are unaffected by core resets, and are generally identical for chip and system resets.

 Table 8-4.
 MMIO Register Contents After Reset

| Register        | Bits | Reset Value | Comment |
|-----------------|------|-------------|---------|
| Ethernet (EMAC) |      |             |         |
| EMAC0_GAHT1     | 0:31 | 0x00000000  |         |
| EMAC0_GAHT2     | 0:31 | 0x00000000  |         |
| EMAC0_GAHT3     | 0:31 | 0x00000000  |         |
| EMAC0_GAHT4     | 0:31 | 0x00000000  |         |
| EMAC0_IAHR      | 0:31 | 0x00000000  |         |
| EMAC0_IAHT1     | 0:31 | 0x00000000  |         |
| EMAC0_IAHT2     | 0:31 | 0x00000000  |         |
| EMAC0_IAHT3     | 0:31 | 0x00000000  |         |

| Register               | Bits                           | Reset Value | Comment                               |  |
|------------------------|--------------------------------|-------------|---------------------------------------|--|
| EMAC0_IAHT4            | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_IALR             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_IPGVR            | 0:31                           | 0x00000004  |                                       |  |
| EMAC0_ISER             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_ISR              | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_LSAH             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_LSAL             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_MR0              | 0:31                           | 0xC0000000  |                                       |  |
| EMAC0_MR1              | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_PTR              | 0:31                           | 0x0000FFFF  |                                       |  |
| EMAC0_RMR              | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_RWMR             | 0:31                           | 0x04001000  |                                       |  |
| EMAC0_STACR            | 0:31                           | 0x00008000  |                                       |  |
| EMAC0_TMR0             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_TMR1             | 0:31                           | 0x380F0000  |                                       |  |
| EMAC0_TRTR             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_VTCI             | 0:31                           | 0x00000000  |                                       |  |
| EMAC0_VTPID            | 0:31                           | 0x00008808  |                                       |  |
| General Purpose I/O (  | GPIO)                          |             |                                       |  |
| GPIO0_IR               | 0:31                           | Undefined   | Read-only; follows the GPIO_In input. |  |
| GPIO0_ODR              | 0:31                           | 0x00000000  |                                       |  |
| GPIO0_OR               | 0:31                           | 0x00000000  |                                       |  |
| GPIO0_TCR              | 0:31                           | 0x00000000  |                                       |  |
| Inter-Integrated Circu | Inter-Integrated Circuit (IIC) |             |                                       |  |
| IIC0_CLKDIV            | 0:7                            | 0x00        |                                       |  |
| IIC0_CNTL              | 0:7                            | 0x00        |                                       |  |
| IIC0_DIRECTCNTL        | 0:7                            | 0x0F        | · · · · · · · · · · · · · · · · · · · |  |
| IIC0_EXTSTS            | 0:7                            | 0x00        |                                       |  |
| IIC0_HMADR             | 0:7                            | Undefined   |                                       |  |
| IIC0_HSADR             | 0:7                            | Undefined   |                                       |  |
| IIC0_INTRMSK           | 0:7                            | 0x00        |                                       |  |
| IIC0_LMADR             | 0:7                            | Undefined   |                                       |  |
| IIC0_LSADR             | 0:7                            | Undefined   |                                       |  |
|                        |                                |             |                                       |  |

Table 8-4. MMIO Register Contents After Reset (continued)

| Register       | Bits | Reset Value | Comment                               |
|----------------|------|-------------|---------------------------------------|
| IIC0_MDBUF     | 0:7  | 0x00        |                                       |
| IIC0_MDCNTL    | 0:7  | 0x00        |                                       |
| IIC0_SDBUF     | 0:7  | 0x00        |                                       |
| IIC0_STS       | 0:7  | 0x00        |                                       |
| IIC0_XFRCNT    | 0:7  | 0x00        |                                       |
| IIC0_XTCNTLSS  | 0:7  | 0x00        |                                       |
| OPB Arbiter    |      |             |                                       |
| OPBA0_CR       | 0:31 | 0x00000000  |                                       |
| OPBA0_PR       | 0:31 | 0x00011011  |                                       |
| PCI Bridge     | L    | I           | ·                                     |
| PCIC0_BASECC   | 0:7  | 0x06        |                                       |
| PCIC0_BIST     | 0:7  | 0x00        |                                       |
| PCIC0_BRDGOPT1 | 0:15 | 0xFF60      |                                       |
| PCIC0_BRDGOPT2 | 0:15 | 0x0100      |                                       |
| PCIC0_CACHELS  | 0:7  | 0x00        |                                       |
| PCIC0_CAP      | 0:7  | 0x00        |                                       |
| PCIC0_CAPID    | 0:7  | 0x00        |                                       |
| PCIC0_CFGADDR  | 0:31 | 0x00000000  |                                       |
| PCIC0_CFGDATA  | 0:31 | 0x00000000  |                                       |
| PCIC0_CLS      | 0:23 | 0x060000    |                                       |
| PCIC0_CMD      | 0:15 | 0x0000      |                                       |
| PCIC0_DEVID    | 0:15 | 0x0156      |                                       |
| PCIC0_ERREN    | 0:7  | 0x00        |                                       |
| PCIC0_ERRSTS   | 0:7  | 0x00        |                                       |
| PCIC0_HDTYPE   | 0:7  | 0x00        |                                       |
| PCIC0_ICS      | 0:7  | 0x00        |                                       |
| PCIC0_INTCLS   | 0:7  | 0x00        |                                       |
| PCIC0_INTLN    | 0:7  | 0x00        |                                       |
| PCIC0_INTPN    | 0:7  | 0x01        | · · · · · · · · · · · · · · · · · · · |
| PCIC0_LATTIM   | 0:7  | 0x07        |                                       |
| PCIC0_MAXLTNCY | 0:7  | 0x00        |                                       |
| PCIC0_MINGNT   | 0:7  | 0x00        |                                       |
| PCIC0_NEXTIPTR | 0:7  | 0x00        |                                       |

Table 8-4. MMIO Register Contents After Reset (continued)

| Register        | Bits | Reset Value | Comment                                  |
|-----------------|------|-------------|------------------------------------------|
| PCIC0_PLBBEAR   | 0:31 | 0x00000000  |                                          |
| PCIC0_PLBBESR0  | 0:31 | 0x00000000  |                                          |
| PCIC0_PLBBESR1  | 0:31 | 0x00000000  |                                          |
| PCIC0_PMC       | 0:15 | 0x0202      |                                          |
| PCIC0_PMCSR     | 0:15 | 0x0000      |                                          |
| PCIC0_PMCSRBSE  | 0:7  | 0x00        | · · · · · · · · · · · · · · · · · · ·    |
| PCIC0_PMSCRR    | 0:7  | 0x10        |                                          |
| PCIC0_PTM1BAR   | 0:31 | 0x00000008  |                                          |
| PCIC0_PTM2BAR   | 0:31 | 0x00000000  |                                          |
| PCIC0_REVID     | 0:7  | 0x00        | Value corresponds to revision level.     |
| PCIC0_SBSYSID   | 0:15 | 0x0000      |                                          |
| PCIC0_SBSYSVID  | 0:15 | 0x0000      |                                          |
| PCIC0_STATUS    | 0:15 | 0x0210      |                                          |
| PCIC0_SUBCLS    | 0:7  | 0x00        |                                          |
| PCIC0_VENDID    | 0:15 | 0x1014      |                                          |
| PCILO_PMM0LA    | 0:31 | 0xFFFE0000  | Value if strapped for PCI boot at reset. |
| PCIL0_PMM0MA    | 0:31 | 0xFFFE0001  | Value if strapped for PCI boot at reset. |
| PCIL0_PMM0PCIHA | 0:31 | 0x00000000  | Value if strapped for PCI boot at reset. |
| PCIL0_PMM0PCILA | 0:31 | 0xFFFE0000  | Value if strapped for PCI boot at reset. |
| PCIL0_PMM1LA    | 0:31 | Undefined   |                                          |
| PCIL0_PMM1MA    | 0:31 | 0x00000000  |                                          |
| PCIL0_PMM1PCIHA | 0:31 | Undefined   |                                          |
| PCIL0_PMM1PCILA | 0:31 | Undefined   |                                          |
| PCIL0_PMM2LA    | 0:31 | Undefined   |                                          |
| PCIL0_PMM2MA    | 0:31 | 0x00000000  |                                          |
| PCIL0_PMM2PCIHA | 0:31 | Undefined   |                                          |
| PCIL0_PMM2PCILA | 0:31 | Undefined   |                                          |
| PCIL0_PTM1LA    | 0:31 | Undefined   |                                          |
| PCIL0_PTM1MS    | 0:31 | Undefined   |                                          |
| PCIL0_PTM2LA    | 0:31 | Undefined   |                                          |
| PCIL0_PTM2MS    | 0:31 | Undefined · |                                          |
| PCIC0_PLBBEAR2  | 0:31 | 0x00000000  |                                          |
| PCIC0_PLBBEAR3  | 0:31 | 0x00000000  |                                          |

### Table 8-4. MMIO Register Contents After Reset (continued)

| Register           | Bits | Reset Value | Comment                                                                                                        |
|--------------------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| Serial Port (UART) |      | <u> </u>    |                                                                                                                |
| UART0_DLL          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_DLM          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_FCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_IER          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_IIR          | 0:7  | 0x00000001  |                                                                                                                |
| UART0_LCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_LSR          | 0:7  | 0x01100000  |                                                                                                                |
| UART0_MCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_MSR          | 0:7  | 0xxxxx0000  | UART0_MSR <sub>0:3</sub> are driven by UART0_DCD, UART0_RI,<br>UART1_DSR[UART1_CTS], and UART1_RTS[UART1_DTR]. |
| UART0_RBR          | 0:7  | 0x00000000  |                                                                                                                |
| UART0_SCR          | 0:7  | Undefined   |                                                                                                                |
| UART0_THR          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_DLL          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_DLM          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_FCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_IER          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_IIR          | 0:7  | 0x00000001  |                                                                                                                |
| UART1_LCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_LSR          | 0:7  | 0x01100000  |                                                                                                                |
| UART1_MCR          | 0:7  | 0x00000000  |                                                                                                                |
| UART1_MSR          | 0:7  | Undefined   |                                                                                                                |
| UART1_RBR          | 0:7  | Undefined   |                                                                                                                |
| UART1_SCR          | 0:7  | Undefined   |                                                                                                                |
| UART1_THR          | 0:7  | 0x00000000  |                                                                                                                |

Table 8-4. MMIO Register Contents After Reset (continued)

# 8.9 PPC405GP Chip Initialization

The on-chip memory (OCM) controller and the universal Interrupt controller (UIC) require initialization for best performance (in the case of OCM) and proper operation (in the case of the UIC). The UART controller may require initialization, depending upon the application.

Other peripheral devices can be initialized as appropriate for the system design.

### 8.9.1 OCM Initialization

The following information applies if OCM is to be accessed.

If instruction-side OCM is to be accessed, the OCM Instruction-Side Address Range Compare Register (OCM0\_ISARC) must be initialized to locate the instruction-side OCM address space in the PPC405GP address map. If data-side OCM is to be accessed, the OCM Data-Side Address Range Compare Register (OCM0\_DSARC) must be initialized to locate the data-side OCM address space into the PPC405GP address map. "OCM Addressing" on page 5-1 provides details of the instructionside OCM and data-side OCM address spaces. See "Memory Organization and Addressing" on page 3-1 for information about the PPC405GP memory map.

#### 8.9.1.1 Initializing Instruction-Side OCM

The following procedure describes the steps to be taken If instruction-side OCM is to be accessed.

- Set the ISEN field of the OCM Instruction-Side Control Register to disable instruction-side OCM accesses (OCM0\_ISCNTL[ISEN] = 0).
- To ensure that interrupts do not interfere with the instruction cache array invalidation performed in step 4, set MSR[EE] = 0 and MSR[CE] to mask interrupts. This prevents a potential problem caused by dirty cache addresses that would not be fetched from the cache because they are marked as non-cachable.
- 3. Mark the address region to be programmed as OCM address space as non-cachable.
- 4. Invalidate the instruction cache array to ensure that no addresses to be programmed as OCM addresses are in the cache. The **iccci** instruction invalidates the instruction cache array.
- 5. Modify the value in OCM0\_ISARC.
- Set OCM0\_ISCNTL[ISEN] = 1 to enable instruction-side OCM accesses. Also, set OCM0\_ISCNTL[ISTCM] = 0.)

OCM0\_ISCNTL[ISTCM] should be initialized to 0 to take the instruction-side OCM controller out of two cycle mode, the default mode after a reset. This enables instruction-side fetches to complete in a single cycle, providing the same performance as cache hits. See "OCM Instruction-Side Control Register (OCM0\_ISCNTL)" on page 5-6 for details.

#### 8.9.1.2 Initializing Data-Side OCM

The following procedure describes the steps to be taken if data-side OCM is used to load the initial contents of instruction-side OCM, or if data-side OCM is to be accessed.

- 1. Set the DSEN field of the Data-Side Control Register to disable data-side OCM accesses (OCM0\_DSCNTL[DSEN] = 0).
- To ensure that interrupts do not interfere with the data cache array invalidation performed in step 4, set MSR[EE] = 0 and MSR[CE] to mask interrupts. This prevents a potential problem caused by dirty cache addresses that would not be fetched from the cache because they are marked as noncachable.
- 3. Mark the address region that is to be programmed as OCM address space as non-cachable.
- 4. Invalidate the data cache array to ensure that no addresses to be programmed as OCM addresses are in the cache. Use a sequence of **dcbf** instructions to invalidate the data cache.

5. Modify the value in OCM0\_DSARC.

6. Set OCM0\_DSCNTL[DSEN] = 1 to enable data-side OCM accesses.

OCM0\_DSCNTL[DOF] should remain at its reset value of 1. See "OCM Data-Side Control Register (OCM0\_DSCNTL)" on page 5-7 for details.

#### 8.9.2 UIC Initialization

The following information does not provide all initialization information for the UIC. Some initialization details are application-dependent.

The polarity and sensitivity of the on-chip interrupts must be initialized for proper chip operation. The fields controlling on-chip interrupts in the UIC Polarity Register (UIC0\_PR<sub>0:18</sub>) must be set to 1. See "UIC Polarity Register (UIC0\_PR)" on page 10-10 for details. The fields controlling on-chip interrupts in the UIC Trigger Register (UIC0\_TR<sub>0:2</sub> and UIC0\_TR<sub>4:18</sub>) must be set to 0. The field controlling the external master interrupt trigger (UIC0\_TR<sub>3</sub>) must be set to 1. See "UIC Trigger Register (UIC0\_TR)" on page 10-13 for details.

#### 8.9.3 UART Initialization

Bits 19 and 20 of Chip Control Register 0 (CPC0\_CR0) control which of two modem control signal pairs, Data Set Ready (DSR) and Data Terminal Ready (DTR) or Clear to Send (CTS) and Ready to Send (RSR), are used. The signal pairs are implemented using the multiplexed pins UART1\_DSR[UART1\_CTS], controlled by CPC0\_CR0<sub>19</sub>, and UART1\_RTS[UART1\_DTR], controlled by CPC0\_CR0<sub>20</sub> must be changed to achieve a required typical pairing.

### 8.10 PPC405GP Initial Processor Sequencing

After any reset, the processor core fetches the word at address 0xFFFFFFC and attempts to execute it. Because the only memory configured immediately after reset is the upper 2MB region (0xFFE00000–0xFFFFFFF), the instruction at 0xFFFFFFC must be a branch instruction.

Because the processor is initially in big endian mode, initialization code must be in big endian format until the endian storage attribute for the addressed region is changed, or until code branches to a region defined as little endian storage.

Before a reset operation begins, the system must provide non-volatile memory, or memory initialized by some mechanism external to the processor. This memory must be located at address 0xFFFFFFC in the upper 2MB region. This memory can be attached to the external bus controller (EBC) or to the system PCI bus. For memory attached to the EBC, the upper 2MB bank configuration after reset is 256 wait states, three cycles of address to chip select delay, three cycles of chip select to output enable delay, and seven cycles of hold time. The bus width (8-, 16-, or 32-bit) is controlled by the ROM width strapping signals. See "Pin Strapping" on page 9-1 for details. See "Local Processor Boot from PCI Memory" on page 17-64 for information about memory attached to the system PCI bus.

# 8.11 Initialization Requirements

When any reset is performed, the processor is initialized to a minimum configuration to start executing initialization code. Initialization code is necessary to complete the processor and system configuration.

The initialization code example in this section performs the configuration tasks required to prepare the PPC405GP to boot an operating system or run an application program.

Some portions of the initialization code work with system components that are beyond the scope of this manual.

Initialization code should perform the following tasks to configure the processor resources.

To improve instruction fetching performance: initialize the SGR appropriately for guarded or unguarded storage. Since all storage is initially guarded and speculative fetching is inhibited to guarded storage, reprogramming the SGR will improve performance for unguarded regions.

1. Configure the following storage attribute control registers, if necessary:

- Initialize the SLER to configure storage byte ordering.
- Initialize the SUOR to configure storage compression.
- 2. Before executing instructions as cachable:
  - Invalidate the instruction cache.
  - Initialize the ICCR to configure instruction cachability.
- 3. Before using storage access instructions:
  - Invalidate the data cache.
  - Initialize CRRO to determine if a store miss results in a line fill (SWOA).
  - Initialize the DCWR to select copy-back or write-through caching.
  - Initialize the DCCR to configure data cachability.
- 4. Before allowing interrupts (synchronous or asynchronous):
  - Initialize the EVPR to point to vector table.
  - Provide vector table with branches to interrupt handlers.
- 5. Before enabling asynchronous interrupts:
  - Initialize timer facilities.
  - Initialize MSR to enable appropriate interrupts.
- 6. Initialize other processor features, such as the MMU, debug, and trace.
- 7. Initialize non-processor resources.
  - Initialize system memory as required by the operating system or application code.
  - Initialize off-chip system facilities.
- 8. Start the execution of operating system or application code.

# 8.12 Initialization Code Example

The following initialization code illustrates the steps that should be taken to initialize the processor before an operating system or user programs begin execution. The example is presented in pseudo-code; function calls are named similarly to PPC405GP mnemonics where appropriate.

| FFFFFFC:`<br>a(init_code);                                                                                                                                                                                                                                                                                                          | /* initial instruction fetch from 0xFFFFFFC /* branch to initialization code                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| t_code:                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                            |
| k                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                            |
| Configure guarded attribute for pe                                                                                                                                                                                                                                                                                                  | rformance.                                                                                                                                                                                                                                 |
| mtspr(SGR, guarded_attribute);                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                            |
| * Configure endianness and compre                                                                                                                                                                                                                                                                                                   | ession.                                                                                                                                                                                                                                    |
| mtspr(SLER, endianness);<br>mtspr(SU0R, compression_attribu                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                            |
| * Invalidate the instruction cache an                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                            |
| *                                                                                                                                                                                                                                                                                                                                   | */                                                                                                                                                                                                                                         |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>f Invalidate the data cache and enal                                                                                                                                                                                                                                     | /* invalidate i-cache */<br>; /* enable I-ca                                                                                                                                                                                               |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>f Invalidate the data cache and enal<br>*                                                                                                                                                                                                                                | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability                                                                                                                                                                           |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>t Invalidate the data cache and enal<br>*<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<="" td=""><td>/* invalidate i-cache */<br/>; /* enable I-ca</td></m_lines;>                                                                                             | /* invalidate i-cache */<br>; /* enable I-ca                                                                                                                                                                                               |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>Invalidate the data cache and enal<br>*<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<br="">dccci(address);</m_lines;>                                                                                                                                          | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability<br>/* start at first line<br>/* D-cache has m_lines congruence classes<br>/* invalidate congruence class                                                                  |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>Invalidate the data cache and enal<br>*<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<="" td=""><td>/* invalidate i-cache */<br/>;; /* enable I-ca<br/>ble cachability<br/>/* start at first line<br/>/* D-cache has m_lines congruence classes</td></m_lines;> | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability<br>/* start at first line<br>/* D-cache has m_lines congruence classes                                                                                                    |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>*<br>*<br>Invalidate the data cache and enal<br>*<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<br="">dccci(address);<br/>address += 32;<br/>htspr(CCR0, store-miss_line-fill);</m_lines;>                                                                           | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability<br>/* start at first line<br>/* D-cache has m_lines congruence classes<br>/* invalidate congruence class<br>/* point to the next congruence class                         |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>t Invalidate the data cache and enal<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<br="">dccci(address);<br/>address += 32;</m_lines;>                                                                                                                               | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability<br>/* start at first line<br>/* D-cache has m_lines congruence classes<br>/* invalidate congruence class<br>/* point to the next congruence class<br>);                   |
| ccci;<br>mtspr(ICCR, i_cache_cachability)<br>sync;<br>t Invalidate the data cache and enal<br>ddress = 0;<br>or (line = 0; line <m_lines; line++)<br="">dccci(address);<br/>address += 32;<br/>htspr(CCR0, store-miss_line-fill);<br/>htspr(DCWR, copy-back_write-thru)<br/>htspr(DCCR, d_cache_cachability);</m_lines;>            | /* invalidate i-cache */<br>;; /* enable I-ca<br>ble cachability<br>/* start at first line<br>/* D-cache has m_lines congruence classes<br>/* invalidate congruence class<br>/* point to the next congruence class<br>); /* enable D-cache |

/\* Initialize vector table and interrupt handlers if not already done \*/

| mtspr(PIT, 0);       /* clear PIT so no PIT indication after TSR cleared mtspr(TSR, 0xFFFFFFF);       /* clear TSR       */         mtspr(TCR, timer_enable);       /* enable desired timers       */         mtspr(TBL, 0);       /* reset time base low first to avoid ripple       */         mtspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple       */         mtspr(TBL, time_base_l);       /* set time base, low       */         mtspr(TBL, time_base_l);       /* set desired PIT count       */         /* Initialize the MSR       */         /* Exceptions must be enabled immediately after timer facilities to avoid missing a       */         /* timer exception.       */         /* The MSR also controls privileged/user mode, translation, and the wait state.       */         /* These must be initialized by the operating system or application code.       */         /* If enabling translation, code must initialize the TLB.       */                                                                                                                                                                                                                                                                                                                                                                                                                              | /* Initialize and configure timer facilities<br>mtspr(PIT, 0); /* clear PIT so no f<br>mtspr(TSR, 0xFFFFFFF); /* clear TSR<br>mtspr(TCR, timer_enable); /* enable desired ti |                                |      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------|
| mtspr(PIT, 0);       /* clear PIT so no PIT indication after TSR cleared mtspr(TSR, 0xFFFFFFF);       /* clear TSR         mtspr(TCR, timer_enable);       /* enable desired timers       */         mtspr(TBL, 0);       /* reset time base low first to avoid ripple       */         mtspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple       */         mtspr(TBL, time_base_l);       /* set time base, low       */         mtspr(PIT, pit_count);       /* set desired PIT count       */         ** Initialize the MSR       */         ** timer exceptions       must be enabled immediately after timer facilities to avoid missing a       */         ** timer exception.       */         ** These must be initialized by the operating system or application code.       */         */* The MSR also controls privileged/user mode, translation, and the wait state.       */         */* These must be initialized by the operating system or application code.       */         */*       */       */         */*       */       */         */*       */       */         */*       */       */         */*       */       */         */*       */       */         */*       */       */         */*       */ </th <th>mtspr(PIT, 0); /* clear PIT so no F<br/>mtspr(TSR, 0xFFFFFFF); /* clear TSR<br/>mtspr(TCR, timer_enable); /* enable desired ti</th> <th></th> <th>*/</th> | mtspr(PIT, 0); /* clear PIT so no F<br>mtspr(TSR, 0xFFFFFFF); /* clear TSR<br>mtspr(TCR, timer_enable); /* enable desired ti                                                 |                                | */   |
| ntspr(TSR, 0xFFFFFFF);       /* clear TSR       */         ntspr(TCR, timer_enable);       /* enable desired timers       */         ntspr(TBL, 0);       /* reset time base low first to avoid ripple       */         ntspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple       */         ntspr(TBL, time_base_u);       /* set time base, low       */         ntspr(TBL, time_base_l);       /* set desired PIT count       */         */       Initialize the MSR       */         */* Initialize the MSR       */         ** Exceptions must be enabled immediately after timer facilities to avoid missing a       */         ** timer exception.       */         ** These must be initialized by the operating system or application code.       */         ** If enabling translation, code must initialize the TLB.       */         **                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ntspr(TSR, 0xFFFFFFFF); /* clear TSR<br>ntspr(TCR, timer_enable); /* enable desired ti                                                                                       |                                | '    |
| mtspr(TCR, timer_enable);       /* enable desired timers       */         mtspr(TBL, 0);       /* reset time base low first to avoid ripple       */         mtspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple       */         mtspr(TBL, time_base_I);       /* set time base, low       */         mtspr(PIT, pit_count);       /* set desired PIT count       */         /* Initialize the MSR       */         /* Exceptions must be enabled immediately after timer facilities to avoid missing a       */         /* The MSR also controls privileged/user mode, translation, and the wait state.       */         /* These must be initialized by the operating system or application code.       */         /* I f enabling translation, code must initialize the TLB.       */         /* Initialization of other processor facilities should be performed at this time.       */         /*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | mtspr(TCR, timer_enable); /* enable desired ti                                                                                                                               | PIT indication after TSR clear | red  |
| mtspr(TBL, 0);       /* reset time base low first to avoid ripple       */         mtspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple       */         mtspr(TBL, time_base_l);       /* set time base, low       */         mtspr(TBL, time_base_l);       /* set time base, low       */         mtspr(PIT, pit_count);       /* set desired PIT count       */         /* Initialize the MSR       */         /* Exceptions must be enabled immediately after timer facilities to avoid missing a       */         /* timer exception.       */         /* The MSR also controls privileged/user mode, translation, and the wait state.       */         /* These must be initialized by the operating system or application code.       */         /* If enabling translation, code must initialize the TLB.       */         /*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                              |                                | */   |
| ntspr(TBU, time_base_u);       /* set time base, hi first to catch possible ripple         ntspr(TBL, time_base_l);       /* set time base, low         ntspr(PIT, pit_count);       /* set desired PIT count         * Initialize the MSR       */         * Exceptions must be enabled immediately after timer facilities to avoid missing a       */         * timer exception.       */         * The MSR also controls privileged/user mode, translation, and the wait state.       */         * These must be initialized by the operating system or application code.       */         * If enabling translation, code must initialize the TLB.       */         *       */         * Initialization of other processor facilities should be performed at this time.       */         *       */         *       */         *       */         *       */         *       */         *       */         *       */         *       */         *       */         *       */         *       */         */       */         */       */         */       */         */       */         */       */                                                                                                                                                                                                                                                                                                                        | ntspr(TBL, 0); /* reset time base                                                                                                                                            | mers                           | */   |
| <pre>ntspr(TBL, time_base_I); /* set time base, low */ ntspr(PIT, pit_count); /* set desired PIT count */ * Initialize the MSR */ * Exceptions must be enabled immediately after timer facilities to avoid missing a */ * timer exception. */ * The MSR also controls privileged/user mode, translation, and the wait state. */ * The MSR also controls privileged/user mode, translation, and the wait state. */ * The MSR also controls privileged/user mode, translation, and the wait state. */ * These must be initialized by the operating system or application code. */ * If enabling translation, code must initialize the TLB. */ * Initialization of other processor facilities should be performed at this time. */ * Initialization of non-processor facilities should be performed at this time. */ * Initialization of non-processor facilities should be performed at this time. */ * * Initialization of non-processor facilities should be performed at this time. */ * * * * * * * * * * * * * * * * * *</pre>                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                              | ow first to avoid ripple       | */   |
| * Initialize the MSR * Exceptions must be enabled immediately after timer facilities to avoid missing a timer exception. * The MSR also controls privileged/user mode, translation, and the wait state. * The se must be initialized by the operating system or application code. * If enabling translation, code must initialize the TLB. * Intmsr(machine_state); * Initialization of other processor facilities should be performed at this time. * Initialization of non-processor facilities should be performed at this time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ntspr(TBU, time_base_u); /* set time base, hi                                                                                                                                | first to catch possible ripple | */   |
| * Initialize the MSR * Exceptions must be enabled immediately after timer facilities to avoid missing a timer exception. * The MSR also controls privileged/user mode, translation, and the wait state. * These must be initialized by the operating system or application code. * If enabling translation, code must initialize the TLB. * Intmsr(machine_state); * Initialization of other processor facilities should be performed at this time. * Initialization of non-processor facilities should be performed at this time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | mtspr(TBL, time_base_I); /* set time base, lo                                                                                                                                | w                              | */   |
| <ul> <li>* Exceptions must be enabled immediately after timer facilities to avoid missing a</li> <li>* timer exception.</li> <li>* The MSR also controls privileged/user mode, translation, and the wait state.</li> <li>* These must be initialized by the operating system or application code.</li> <li>* If enabling translation, code must initialize the TLB.</li> <li>* mtmsr(machine_state);</li> <li>* Initialization of other processor facilities should be performed at this time.</li> <li>* Initialization of non-processor facilities should be performed at this time.</li> <li>* Initialization of non-processor facilities should be performed at this time.</li> <li>* *</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ntspr(PIT, pit_count); /* set desired PIT of                                                                                                                                 | count                          | */   |
| * timer exception. * The MSR also controls privileged/user mode, translation, and the wait state. * These must be initialized by the operating system or application code. */* If enabling translation, code must initialize the TLB. * Intmsr(machine_state); * Initialization of other processor facilities should be performed at this time. */* Initialization of non-processor facilities should be performed at this time. */* Initialization of non-processor facilities should be performed at this time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | * Initialize the MSR                                                                                                                                                         |                                | */   |
| * timer exception. * The MSR also controls privileged/user mode, translation, and the wait state. * These must be initialized by the operating system or application code. * If enabling translation, code must initialize the TLB. *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | * Exceptions must be enabled immediately after timer                                                                                                                         | facilities to avoid missing a  | */   |
| * The MSR also controls privileged/user mode, translation, and the wait state. * These must be initialized by the operating system or application code. * If enabling translation, code must initialize the TLB. *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                              | 5                              | */   |
| * These must be initialized by the operating system or application code.  * If enabling translation, code must initialize the TLB. * mtmsr(machine_state);  * Initialization of other processor facilities should be performed at this time. * Initialization of non-processor facilities should be performed at this time. * Initialization of non-processor facilities should be performed at this time. * * * * * * * * * * * * * * * * * * *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | *                                                                                                                                                                            |                                | */   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * The MSR also controls privileged/user mode, translati                                                                                                                      | on, and the wait state.        | */   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * These must be initialized by the operating system or a                                                                                                                     | pplication code.               | */   |
| ntmsr(machine_state);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | * If enabling translation, code must initialize the TLB.                                                                                                                     |                                | */   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | /*                                                                                                                                                                           |                                | - */ |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | mtmsr(machine_state);                                                                                                                                                        |                                |      |
| ** * Initialization of non-processor facilities should be performed at this time. * **                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | /*                                                                                                                                                                           |                                |      |
| **  * Initialization of non-processor facilities should be performed at this time.  *  *  *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                              |                                |      |
| Initialization of non-processor facilities should be performed at this time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                              |                                | ,    |
| **                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                              |                                |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                              |                                |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                              |                                |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                              |                                |      |

8-18 PPC405GP User's Manual

# Chapter 9. Pin Strapping and Sharing

# 9.1 Pin Strapping

When power is applied to the PPC405GP, a start-up process is initiated in which internal functions are initialized. Some of these functions have optional choices. Which of the options are used for initialization is determined by the way a specific set of I/O pins (balls) are conditioned. The conditioning is achieved using external pull-up (indicated as 1) or pull-down (indicated as 0) resistors connected to the pins.

While the SysReset input signal is low (system reset), the state of the I/O pins is read to enable default initial conditions before PPC405GP start-up. The actual capture instant is the nearest SysClk clock edge before the deassertion of SysReset. The state of the pins as read is stored in the Chip Pin Strapping Register (CPC0\_PSR) shown in Figure 9-1. Refer to *PowerPC 405GP Embedded Processor Data Sheet*, which describes the strapping pins.

# 9.1.1 Chip Pin Strapping Register (CPC0\_PSR)

CPC0\_PSR contains the state of the strapping pins as read during system reset.



| 0:1 | PFWD | PLL Forward Divider<br>00 Bypass Mode<br>01 Divide by 3<br>10 Divide by 4<br>11 Divide by 6  |
|-----|------|----------------------------------------------------------------------------------------------|
| 2:3 | PFBD | PLL Feedback Divider<br>00 Divide By 1<br>01 Divide By 2<br>10 Divide By 3<br>11 Divide By 4 |

Figure 9-1. Chip Pin Strapping Register (CPC0\_PSR)

| 4:6   | PT   | PLL Tuning<br>000 Choice 1; TUNE[5:0] = 010001<br>001 Choice 2; TUNE[5:0] = 010010<br>010 Choice 3; TUNE[5:0] = 010011<br>011 Choice 4; TUNE[5:0] = 010101<br>100 Choice 5; TUNE[5:0] = 010101<br>101 Choice 6; TUNE[5:0] = 010110<br>110 Choice 7; TUNE[5:0] = 010111<br>111 Choice 8; TUNE[5:0] = 100100 | <b>Note:</b> The tune bits adjust parameters that<br>control PLL jitter. The recommended values<br>minimize jitter for the PLL implemented in<br>the PPC405GP. These bits are shown for<br>information only, and do not require<br>modification except in special clocking<br>circumstances, such as spread spectrum<br>clocking. For details on the use of spread<br>spectrum clock generators (SSCGs) with<br>the PPC405GP, visit the technical<br>documents area of the IBM PowerPC web<br>site. |
|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:8   | PDC  | PLB Divider from CPU<br>00 Divide By 1<br>01 Divide By 2<br>10 Divide By 3<br>11 Divide By 4                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9:10  | ODP  | OPB Divider from PLB<br>00 Divide By 1<br>01 Divide By 2<br>10 Divide By 3<br>11 Divide By 4                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11:12 | PDP  | PCI Divider from PLB<br>00 Divide By 1<br>01 Divide By 2<br>10 Divide By 3<br>11 Divide By 4                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:14 | EBDP | External Bus Divider from PLB<br>00 Divide By 2<br>01 Divide By 3<br>10 Divide By 4<br>11 Divide By 5                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:16 | RW   | ROM Width<br>00 8-bit ROM<br>01 16-bit ROM<br>10 32-bit ROM<br>11 Reserved                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17    | RL   | ROM Location<br>0 405GP Peripheral Attach<br>1 405GP PCI Attach                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18    |      | Reserved                                                                                                                                                                                                                                                                                                   | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 19    | PAME | PCI Asynchronous Mode Enable<br>0 Synchronous PCI Mode<br>1 Asynchronous Mode                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 20    |      | Reserved                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21    | PAE  | PCI Arbiter Enable<br>0 Internal Arbiter Disabled<br>1 Internal Arbiter Enabled                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 22:31 |      | Reserved                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 9.2 **Pin Sharing**

The PPC405GP uses pin (ball) multiplexing (sharing) to reduce the total pin requirement without significantly reducing functionality. Some of the pins that are multiplexed require DCR register programming to configure the pin for the desired function. It is expected that in an application, a particular pin is programmed to serve one function. While nothing prevents changing the function of a pin during operation, most applications configure a pin once at power-on reset (POR). Table 9-1 lists the multiplexed PPC405GP signals and indicates the DCR bit that controls the pin. The default signal appears first and the alternate signal is in brackets.

| Signal         | DCR Bit        | Description                                          |
|----------------|----------------|------------------------------------------------------|
| GPIO1[TS1E]    | CPC0_CR0[TRE]  | Set of GPIO pins that can be reconfigured for use as |
| GPIO2[TS2E]    | 1              | the CPU Trace interface.                             |
| GPIO3[TS10]    |                |                                                      |
| GPIO4[TS2O]    | 1              |                                                      |
| GPIO5[TS3]     | 1              |                                                      |
| GPIO6[TS4]     | 1              |                                                      |
| GPIO7[TS5]     | 1              |                                                      |
| GPIO8[TS6]     | 1              |                                                      |
| GPIO9[TrcClk]  | -              |                                                      |
| PerCS1[GPIO10] | CPC0_CR0[G10E] | Peripheral Chip selects that can be reconfigured for |
| PerCS2[GPIO11] | CPC0_CR0[G11E] | use as GPIOs.                                        |
| PerCS3[GPIO12] | CPC0_CR0[G12E] |                                                      |
| PerCS4[GPIO13] | CPC0_CR0[G13E] |                                                      |
| PerCS5[GPIO14] | CPC0_CR0[G14E] |                                                      |
| PerCS6[GPIO15] | CPC0_CR0[G15E] | · · · · · · · · · · · · · · · · · · ·                |
| PerCS7[GPIO16] | CPC0_CR0[G16E] | · · · · · ·                                          |
| IRQ0[GPIO17]   | CPC0_CR0[G17E] | External Interrupts that can be reconfigured for use |
| IRQ1[GPIO18]   | CPC0_CR0[G18E] | as GPIOs.                                            |
| IRQ2[GPIO19]   | CPC0_CR0[G19E] | 1                                                    |
| IRQ3[GPIO20]   | CPC0_CR0[G20E] | 1                                                    |
| IRQ4[GPIO21]   | CPC0_CR0[G21E] | 1                                                    |
| IRQ5[GPIO22]   | CPC0_CR0[G22E] | 1                                                    |
| IRQ6[GPIO23]   | CPC0_CR0[G23E] | 1                                                    |

| Table 9-1. | Multiplexed Pins |
|------------|------------------|
|------------|------------------|

| Signal                                                                                                                                                                                        | DCR Bit         | Description                                                                                                                                               |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| UART1_DSR[UART1_CTS] <sup>1</sup>                                                                                                                                                             | CPC0_CR0[DCS]   | UART1 DSR pin that can be reconfigured for use as UART1 CTS.                                                                                              |  |  |
| UART1_RTS[UART1_DTR] <sup>1</sup>                                                                                                                                                             | CPC0_CR0[RDS]   | UART1 RTS pin that can be reconfigured for use as UART1 DTR.                                                                                              |  |  |
| PCIINT[PerWE]                                                                                                                                                                                 | CPC0_CR1[PCIPW] | PCI Interrupt output that can be reconfigured for use<br>by peripherals as a Write Byte Enable (logical AND<br>of the four PerWBE0:3 write byte enables). |  |  |
| PCIReq0[Gnt]                                                                                                                                                                                  | CPC0_PSR[PAE]   | PCIReq0 when internal arbiter is used or Gnt when external arbiter is used.                                                                               |  |  |
| PCIGnt0[Req]                                                                                                                                                                                  | CPC0_PSR[PAE]   | PCIGnt0 when internal arbiter is used or Req when external arbiter is used.                                                                               |  |  |
| Note: Typically DSR and DTR are paired and CTS and RTS are paired. With the current multiplex defaults one of the pins must be changed during initialization to achieve the typical pairings. |                 |                                                                                                                                                           |  |  |

### Table 9-1. Multiplexed Pins (continued)

# **Chapter 10. Interrupt Controller Operations**

The PPC405GP contains a universal interrupt controller (UIC) that provides all necessary control, status, and communication between the various internal and external interrupt sources and the processor core.

### 10.1 UIC Overview

The UIC supports 19 internal interrupts and 7 external interrupts. Status reporting (using the UIC Status Register [UIC0\_SR]) is provided to ensure that systems software can determine the current and interrupting state of the system and respond appropriately. Software can generate interrupts to simplify software development and for diagnostics.

The interrupts can be programmed, using the UIC Critical Register (UIC0\_CR), to generate either a critical or a non-critical interrupt signal to the processor core.

The privileged **mtdcr** and **mfdcr** instructions, which are used by system software, are used to read and write the UIC registers.

An optional critical interrupt vector generator can reduce interrupt handling latency for critical interrupts. Vector calculation is described in detail in "UIC Vector Register (UIC0\_VR)" on page 10-18.

### 10.2 UIC Features

- Support for 19 internal and 7 external interrupts
- Support for asychronous level- or edge-sensitive interrupt types
- · Programmable polarity for all interrupt types
- · Programmable critical/non-critical interrupt selection for each interrupt bit
- Prioritized critical interrupt vector generation
- A UIC Status Register (UIC0\_SR) providing the following information:
  - Current state of interrupts
  - Current state of all enabled interrupts (those masked using the UIC Enable Register (UIC0\_ER))

## **10.3 UIC Interrupt Assignments**

The UIC supports various internal and external interrupt sources as shown in Table 10-1.

| Interrupt | Polarity | Sensitivity | Interrupt Source |
|-----------|----------|-------------|------------------|
| 0         | High     | Level       | UART0            |
| 1         | High     | Level       | UART1            |
| 2         | High     | Level       | liC              |

 Table 10-1. UIC Interrupt Assignments

| Interrupt | Polarity         | Sensitivity      | Interrupt Source               |  |
|-----------|------------------|------------------|--------------------------------|--|
| 3         | High             | Edge             | External Master                |  |
| 4         | High             | Level            | PCI                            |  |
| 5         | High             | Level            | DMA Channel 0                  |  |
| 6         | High             | Level            | DMA Channel 1                  |  |
| 7         | High             | Level            | DMA Channel 2                  |  |
| 8         | High             | Level            | DMA Channel 3                  |  |
| 9         | High             | Level            | Ethernet Wake Up               |  |
| 10        | High             | Level            | MAL System Error (SERR)        |  |
| 11        | High .           | Level            | MAL TX End of Buffer (TXEOB0)  |  |
| 12        | High             | Level            | MAL RX End of Buffer (RXEOB)   |  |
| 13        | High             | Level            | MAL TX Descriptor Error (TXDE) |  |
| 14        | High             | Level            | MAL RX Descriptor Error (RXDE) |  |
| 15        | High             | Level            | Ethernet                       |  |
| 16        | High             | Level            | External PCI SERR              |  |
| 17        | High             | Level            | ECC Correctable Error          |  |
| 18        | High Level       |                  | PCI Power Management           |  |
| 19        |                  |                  |                                |  |
| 20        |                  |                  |                                |  |
| 21        | Reserved         |                  |                                |  |
| 22        | neserveu         |                  |                                |  |
| 23        |                  |                  |                                |  |
| 24        |                  |                  |                                |  |
| 25        | Programmabl<br>e | Programmabl<br>e | External IRQ 0                 |  |
| 26        | Programmabl<br>e | Programmabl<br>e | External IRQ 1                 |  |
| 27        | Programmabl<br>e | Programmabl<br>e | External IRQ 2                 |  |
| 28 .      | Programmabl<br>e | Programmabl<br>e | External IRQ 3                 |  |
| 29        | Programmabl<br>e | Programmabl<br>e | External IRQ 4                 |  |
| 30        | Programmabl<br>e | Programmabl<br>e | External IRQ 5                 |  |
| 31        | Programmabl<br>e | Programmabl<br>e | External IRQ 6                 |  |

Table 10-1. UIC Interrupt Assignments (continued)

а

### **10.4 Interrupt Programmability**

The on-chip interrupts (interrupts 0–18) and the external IRQs (interrupts 25–31) are programmable. However, the polarity and sensitivity of the on-chip interrupts must be programmed as shown in Table 10-1, using the UIC Polarity Register (UIC0\_PR) and UIC Trigger Register (UIC0\_TR), respectively.

## 10.5 UIC Registers

The UIC includes the Device Control Registers (DCRs) listed in Table 10-2.

The registers are accessed using the **mfdcr** and **mtdcr** instructions.

| Mnemonic | Register                          | Address | Access     | Page  |
|----------|-----------------------------------|---------|------------|-------|
| UIC0_SR  | UIC Status Register               | 0x0C0   | Read/Clear | 10-3  |
| UIC0_ER  | UIC Enable Register               | 0x0C2   | R/W        | 10-6  |
| UIC0_CR  | UIC Critical Register             | 0x0C3   | R/W        | 10-8  |
| UIC0_PR  | UIC Polarity Register             | 0x0C4   | R/W        | 10-10 |
| UIC0_TR  | UIC Trigger Register              | 0x0C5   | R/W        | 10-13 |
| UIC0_MSR | UIC Masked Status Register        | 0x0C6   | Read-only  | 10-16 |
| UIC0_VR  | UIC Vector Register               | 0x0C7   | Write-only | 10-19 |
| UIC0_VCR | UIC Vector Configuration Register | 0x0C8   | Read-only  | 10-18 |

Table 10-2. UIC DCRs

### 10.5.1 UIC Status Register (UIC0\_SR)

To report interrupt status, the UIC0\_SR fields capture and hold internal and external interrupts until the fields are intentionally reset. To reset a field, write 1 to the field.

The values of other UIC registers do not affect UIC0\_SR fields.



| Figure 10-1. | <b>UIC Status</b> | Register | (UIC0_S | R) |
|--------------|-------------------|----------|---------|----|
|--------------|-------------------|----------|---------|----|

| 0 | UOIS | UART0 Interrupt Status<br>0 A UART0 interrupt has not occurred.<br>1 A UART0 interrupt occurred. |
|---|------|--------------------------------------------------------------------------------------------------|
| 1 | U1IS | UART1 Interrupt Status<br>0 A UART1 interrupt has not occurred.<br>1 A UART1 interrupt occurred. |

| 2  | IICIS | IIC Interrupt Status<br>0 An IIC interrupt has not occurred.<br>1 An IIC interrupt occurred.                                                             |
|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3  | EMIS  | External Master Interrupt Status<br>0 An external master interrupt has not<br>occurred.<br>1 An external master interrupt occurred.                      |
| 4  | PCIIS | PCI Interrupt Status<br>0 A PCI interrupt has not occurred.<br>1 A PCI interrupt occurred.                                                               |
| 5  | DOIS  | <ul> <li>DMA Channel 0 Interrupt Status</li> <li>0 A DMA channel 0 interrupt has not occurred.</li> <li>1 A DMA channel 0 interrupt occurred.</li> </ul> |
| 6  | D1IS  | <ul> <li>DMA Channel 1 Interrupt Status</li> <li>O A DMA channel 1 interrupt has not occurred.</li> <li>1 A DMA channel 1 interrupt occurred.</li> </ul> |
| 7  | D2IS  | <ul> <li>DMA Channel 2 Interrupt Status</li> <li>0 A DMA channel 2 interrupt has not occurred.</li> <li>1 A DMA channel 2 interrupt occurred.</li> </ul> |
| 8  | D3IS  | <ul> <li>DMA Channel 3 Interrupt Status</li> <li>A DMA channel 3 interrupt has not occurred.</li> <li>1 A DMA channel 3 interrupt occurred.</li> </ul>   |
| 9  | EWIS  | Ethernet Wake-up Interrupt Status<br>0 An Ethernet wake-up interrupt has not<br>occurred.<br>1 An Ethernet wake-up interrupt occurred.                   |
| 10 | MSIS  | MAL SERR Interrupt Status<br>0 A MAL SERR interrupt has not occurred.<br>1 A MAL SERR interrupt occurred.                                                |
| 11 | MTEIS | MAL TX EOB Interrupt Status<br>0 A MAL TX EOB interrupt has not<br>occurred.<br>1 A MAL TX EOB interrupt occurred.                                       |
| 12 | MREIS | <ul> <li>MAL RX EOB Interrupt Status</li> <li>A MAL RX EOB interrupt has not occurred.</li> <li>A MAL RX EOB interrupt occurred.</li> </ul>              |
| 13 | MTDIS | MAL TX DE Interrupt Status<br>0 A MAL TX DE interrupt has not occurred.<br>1 A MAL TX DE interrupt occurred.                                             |
| 14 | MRDIS | MAL RX DE Interrupt Status<br>0 A MAL RX DE interrupt has not occurred.<br>1 A MAL RX DE interrupt occurred.                                             |

| 15    | EIS   | Ethernet Interrupt Status<br>0 An Ethernet interrupt has not occurred.<br>1 An Ethernet interrupt occurred.                                                                             |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | EPSIS | External PCI SERR Interrupt Status<br>0 An external PCI SERR interrupt has not<br>occurred.<br>1 An external PCI SERR interrupt<br>occurred.                                            |
| 17    | ECIS  | <ul> <li>ECC Correctable Error Interrupt Status</li> <li>O An ECC correctable error interrupt did<br/>not occur.</li> <li>1 An ECC correctable error interrupt<br/>occurred.</li> </ul> |
| 18    | PPMIS | <ul> <li>PCI Power Management Interrupt Status</li> <li>0 A PCI power management interrupt did<br/>not occur.</li> <li>1 A PCI power management interrupt<br/>occurred.</li> </ul>      |
| 19:24 |       | Reserved                                                                                                                                                                                |
| 25    | EIR0S | External IRQ 0 Status<br>0 An external IRQ 0 interrupt has not<br>occurred.<br>1 An external IRQ 0 interrupt occurred.                                                                  |
| 26    | EIR1S | External IRQ 1 Status<br>0 An external IRQ 1 interrupt has not<br>occurred.<br>1 An external IRQ 1 interrupt occurred.                                                                  |
| 27    | EIR2S | External IRQ 2 Status<br>0 An external IRQ 2 interrupt has not<br>occurred.<br>1 An external IRQ 2 interrupt occurred.                                                                  |
| 28    | EIR3S | External IRQ 3 Status<br>0 An external IRQ 3 interrupt has not<br>occurred.<br>1 An external IRQ 3 interrupt occurred.                                                                  |
| 29    | EIR4S | External IRQ 4 Status<br>0 An external IRQ 4 interrupt has not<br>occurred.<br>1 An external IRQ 4 interrupt occurred.                                                                  |
| 30    | EIR5S | External IRQ 5 Status<br>0 An external IRQ 5 interrupt has not<br>occurred.<br>1 An external IRQ 5 interrupt occurred.                                                                  |
| 31    | EIR6S | External IRQ 6 Status<br>0 An external IRQ 6 interrupt has not<br>occurred.<br>1 An external IRQ 6 interrupt occurred.                                                                  |

### 10.5.2 UIC Enable Register (UIC0\_ER)

The fields of the UIC0\_ER, which correspond to the fields of the UIC0\_SR, enable or disable the reporting of the corresponding fields of the UIC0\_SR.

If a UIC0\_ER field is set to 1, the corresponding field of the UIC0\_SR generates a critical or noncritical interrupt signal to the processor core, if the UIC0\_SR field is set to 1. If a UIC0\_ER field is set to 0, the corresponding field of the UIC0\_SR does not generate a critical or non-critical interrupt signal to the processor core, regardless of the setting of the UIC0\_SR field. The critical and noncritical interrupt signals in the processor core are controlled by fields in the Machine State Register (MSR).

The class of generated signals (critical or non-critical) is controlled by the UIC0\_CR.



| 0 | UOIE  | UART0 Interrupt Enable<br>0 UART0 interrupt is disabled.<br>1 UART0 interrupt is enabled.                                    |
|---|-------|------------------------------------------------------------------------------------------------------------------------------|
| 1 | U1IE  | UART1 Interrupt Enable<br>0 UART1 interrupt is disabled.<br>1 UART1 interrupt is enabled.                                    |
| 2 | licie | IIC Interrupt Enable<br>0 IIC interrupt is disabled.<br>1 IIC interrupt is enabled.                                          |
| 3 | EMIE  | External Master Interrupt Enable<br>100 External master interrupt is disabled.<br>1 0xxExternal master interrupt is enabled. |
| 4 | PCIIE | PCI Interrupt Enable<br>0 PCI interrupt is disabled.<br>1 PCI interrupt is enabled.                                          |
| 5 | DOIE  | DMA Channel 0 Interrupt Enable<br>0 DMA channel 0 interrupt is disabled.<br>1 DMA channel 0 interrupt is enabled.            |
| 6 | D1IE  | DMA Channel 1 Interrupt Enable<br>0 DMA channel 1 interrupt is disabled.<br>1 DMA channel 1 interrupt is enabled.            |
| 7 | D2IE  | DMA Channel 2 Interrupt Enable<br>0 DMA channel 2 interrupt is disabled.<br>1 DMA channel 2 interrupt is enabled.            |

Figure 10-2. UIC Enable Register (UIC0\_ER)

| 8     | D3IE  | DMA Channel 3 Interrupt Enable<br>0 DMA channel 3 interrupt is disabled.<br>1 DMA channel 3 interrupt is enabled.                                                                 |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | EWIE  | Ethernet Wake-up Interrupt Enable<br>0 Ethernet wake-up interrupt is disabled.<br>1 Ethernet wake-up interrupt is enabled.                                                        |
| 10    | MSIE  | MAL SERR Interrupt Enable<br>0 MAL SERR interrupt is disabled.<br>1 MAL SERR interrupt is enabled.                                                                                |
| 11    | MTEIE | MAL TX EOB Interrupt Enable<br>0 MAL TX EOB interrupt is disabled.<br>1 MAL TX EOB interrupt is enabled.                                                                          |
| 12    | MREIE | MAL RX EOB Interrupt Enable<br>0 MAL RX EOB interrupt is disabled.<br>1 MAL RX EOB interrupt is enabled.                                                                          |
| 13    | MTDIE | MAL TX DE Interrupt Enable<br>0 MAL TX DE interrupt is disabled.<br>1 MAL TX DE interrupt is enabled.                                                                             |
| 14    | MRDIE | MAL RX DE Interrupt Enable<br>0 MAL RX DE interrupt is disabled.<br>1 MAL RX DE interrupt is enabled.                                                                             |
| 15    | EIE   | Ethernet Interrupt Enable<br>0 An Ethernet interrupt is disabled.<br>1 An Ethernet interrupt is enabled.                                                                          |
| 16    | EPSIE | External PCI SERR Interrupt Enable<br>0 External PCI SERR interrupt is disabled.<br>1 External PCI SERR interrupt is enabled.                                                     |
| 17    | ECIE  | <ul> <li>ECC Correctable Error Interrupt Enable</li> <li>0 ECC correctable error interrupt is<br/>disabled.</li> <li>1 ECC correctable error interrupt is<br/>enabled.</li> </ul> |
| 18    | PPMI  | <ul> <li>PCI Power management Interrupt Enable</li> <li>O PCI power management interrupt is<br/>disabled.</li> <li>1 PCI power management interrupt is<br/>enabled.</li> </ul>    |
| 19:24 |       | Reserved                                                                                                                                                                          |
| 25    | EIR0E | External IRQ 0 Enable<br>0 An external IRQ 0 interrupt is disabled.<br>1 An external IRQ 0 interrupt is enabled.                                                                  |
| 26    | EIR1E | External IRQ 1 Enable<br>0 An external IRQ 1 interrupt is disabled.<br>1 An external IRQ 1 interrupt is enabled.                                                                  |
| 27    | EIR2E | External IRQ 2 Enable<br>0 An external IRQ 2 interrupt is disabled.<br>1 An external IRQ 2 interrupt is enabled.                                                                  |
| ·     |       |                                                                                                                                                                                   |

.

| 28 | EIR3E | External IRQ 3 Enable<br>0 An external IRQ 3 interrupt is disabled.<br>1 An external IRQ 3 interrupt is enabled. |
|----|-------|------------------------------------------------------------------------------------------------------------------|
| 29 | EIR4E | External IRQ 4 Enable<br>0 An external IRQ 4 interrupt is disabled.<br>1 An external IRQ 4 interrupt is enabled. |
| 30 | EIR5E | External IRQ 5 Enable<br>0 An external IRQ 5 interrupt is disabled.<br>1 An external IRQ 5 interrupt is enabled. |
| 31 | EIR6E | External IRQ 6 Enable<br>0 An external IRQ 6 interrupt is disabled.<br>1 An external IRQ 6 interrupt is enabled. |

### 10.5.3 UIC Critical Register (UIC0\_CR)

The fields of the UIC0\_CR, which correspond to the fields of the UIC0\_SR and UIC0\_ER, determine whether an interrupt captured in the corresponding fields of the UIC0\_SR generates a non-critical or critical interrupt, if the interrupts are enabled in the corresponding fields of the UIC0\_ER. The processor handles critical interrupts when MSR[EE] = 1 and non-critical interrupts when MSR[CE]=1.

If a UIC0\_CR field is set to 0, an enabled interrupt (captured in the corresponding field of the UIC0\_SR and enabled in the corresponding field of the UIC0\_ER) generates a non-critical interrupt signal to the processor core. If a UIC0\_CR field is a 1, a critical interrupt signal is generated.



| Figure 10-3. UIC Critical Register (U |  | CR) |
|---------------------------------------|--|-----|
|---------------------------------------|--|-----|

| 0 | UOIC  | UART0 Interrupt Class<br>0 UART0 interrupt is non-critical.<br>1 UART0 interrupt is critical.                               |
|---|-------|-----------------------------------------------------------------------------------------------------------------------------|
| 1 | U1IC  | UART1 Interrupt Class<br>0 UART1 interrupt is non-critical.<br>1 UART1 interrupt is critical.                               |
| 2 | IICIC | IIC Interrupt Class<br>0 IIC interrupt is non-critical.<br>1 IIC interrupt is critical.                                     |
| 3 | EMIC  | External Master Interrupt Class<br>0 External master interrupt is non-critical.<br>1 External master interrupt is critical. |
| 4 | PCIIC | PCI Interrupt Class<br>0 PCI interrupt is non-critical.<br>1 PCI interrupt is critical.                                     |

| 5     | DOIC           | DMA Channel 0 Interrupt Class<br>0 DMA channel 0 interrupt is non-critical.<br>1 DMA channel 0 interrupt is critical.                                                               |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | D1IC           | DMA Channel 1 Interrupt Class<br>0 DMA channel 1 interrupt is non-critical.<br>1 DMA channel 1 interrupt is critical.                                                               |
| 7     | D2IC           | DMA Channel 2 Interrupt Class<br>0 DMA channel 2 interrupt is non-critical.<br>1 DMA channel 2 interrupt is critical.                                                               |
| 8     | D3IC           | DMA Channel 3 Interrupt Class<br>0 DMA channel 3 interrupt is non-critical.<br>1 DMA channel 3 interrupt is critical.                                                               |
| 9     | EWIC           | Ethernet Wake-up Interrupt Class<br>0 Ethernet wake-up interrupt is non-critical.<br>1 Ethernet wake-up interrupt is critical.                                                      |
| 10    | MSIC           | MAL SERR Interrupt Class<br>0 MAL SERR interrupt is non-critical.<br>1 MAL SERR interrupt is critical.                                                                              |
| 11    | MTEIC          | MAL TX EOB Interrupt Class<br>0 MAL TX EOB interrupt is non-critical.<br>1 MAL TX EOB interrupt is critical.                                                                        |
| 12    | MREIC          | MAL RX EOB Interrupt Class<br>0 MAL RX EOB interrupt is non-critical.<br>1 MAL RX EOB interrupt is critical.                                                                        |
| 13    | MTDIC          | MAL TX DE Interrupt Class<br>0 MAL TX DE interrupt is non-critical.<br>1 MAL TX DE interrupt is critical.                                                                           |
| 14    | MRDIC          | MAL RX DE Interrupt Class<br>0 MAL RX DE interrupt is non-critical.<br>1 MAL RX DE interrupt is critical.                                                                           |
| 15    | EIC            | Ethernet Interrupt Class<br>0 An Ethernet interrupt is non-critical.<br>1 An Ethernet interrupt is critical.                                                                        |
| 16    | EPSIC          | External PCI SERR Interrupt Class<br>0 External PCI SERR interrupt is non-<br>critical.<br>1 External PCI SERR interrupt is critical.                                               |
| 17    | ECIC           | <ul> <li>ECC Correctable Error Interrupt Class</li> <li>0 ECC correctable error interrupt is non-<br/>critical.</li> <li>1 ECC correctable error interrupt is critical.</li> </ul>  |
| 18    | PPMIC          | <ul> <li>PCI Power management Interrupt Class</li> <li>0 PCI power management interrupt is non-<br/>critical.</li> <li>1 PCI power management interrupt is<br/>critical.</li> </ul> |
| 19:24 | 10240304040406 | Reserved                                                                                                                                                                            |

| 25 | EIROC | External IRQ 0 Class<br>0 An external IRQ 0 interrupt is non-<br>critical.<br>1 An external IRQ 0 interrupt is critical. |
|----|-------|--------------------------------------------------------------------------------------------------------------------------|
| 26 | EIR1C | External IRQ 1 Class<br>0 An external IRQ 1 interrupt is non-<br>critical.<br>1 An external IRQ 1 interrupt is critical. |
| 27 | EIR2C | External IRQ 2 Class<br>0 An external IRQ 2 interrupt is non-<br>critical.<br>1 An external IRQ 2 interrupt is critical. |
| 28 | EIR3C | External IRQ 3 Class<br>0 An external IRQ 3 interrupt is non-<br>critical.<br>1 An external IRQ 3 interrupt is critical. |
| 29 | EIR4C | External IRQ 4 Class<br>0 An external IRQ 4 interrupt is non-<br>critical.<br>1 An external IRQ 4 interrupt is critical. |
| 30 | EIR5C | External IRQ 5 Class<br>0 An external IRQ 5 interrupt is non-<br>critical.<br>1 An external IRQ 5 interrupt is critical. |
| 31 | EIR6C | External IRQ 6 Class<br>0 An external IRQ 6 interrupt is non-<br>critical.<br>1 An external IRQ 6 interrupt is critical. |

### 10.5.4 UIC Polarity Register (UIC0\_PR)

The fields of the UIC0\_PR, which correspond to the fields of the UIC0\_SR, determine whether the corresponding fields in the UIC0\_SR have a positive or negative polarity.

For level-sensitive interrupts, a 0 in a UIC0\_PR field causes the corresponding interrupt to be negative active. A 1 in a UIC0\_PR field causes the corresponding interrupt to be positive active.

For edge-sensitive interrupts, a 0 in a UIC0\_PR field causes the corresponding interrupt to be detected on a falling edge (as polarity changes from 1 to 0). A 1 in a UIC0\_PR field causes the corresponding interrupt to be detected on a rising edge (as polarity changes from 0 to 1).

Because the on-chip interrupts (those controlled by UIC0\_PR $_{0:18}$ ) have positive polarity, the associated fields must be set to 1.



| 0  | UOIP  | UART0 Interrupt Polarity<br>0 UART0 interrupt has negative polarity.<br>1 UART0 interrupt has positive polarity.                                  | Must be set to 1. |
|----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 1  | U1IP  | UART1 Interrupt Polarity<br>0 UART1 interrupt has negative polarity.<br>1 UART1 interrupt has positive polarity.                                  | Must be set to 1. |
| 2  | IICIP | IIC Interrupt Polarity<br>0 IIC interrupt has negative polarity.<br>1 IIC interrupt has positive polarity.                                        | Must be set to 1. |
| 3  | EMIP  | External Master Interrupt Polarity<br>0 External master interrupt has negative polarity.<br>1 External master interrupt has positive polarity.    | Must be set to 1. |
| 4  | PCIIP | PCI Interrupt Polarity<br>0 PCI interrupt has negative polarity.<br>1 PCI interrupt has positive polarity.                                        | Must be set to 1. |
| 5  | DOIP  | DMA Channel 0 Interrupt Polarity<br>0 DMA channel 0 interrupt has negative polarity.<br>1 DMA channel 0 interrupt has positive polarity.          | Must be set to 1. |
| 6  | D1IP  | DMA Channel 1 Interrupt Polarity<br>0 DMA channel 1 interrupt has negative polarity.<br>1 DMA channel 1 interrupt has positive polarity.          | Must be set to 1. |
| 7  | D2IP  | DMA Channel 2 Interrupt Polarity<br>0 DMA channel 2 interrupt has negative polarity.<br>1 DMA channel 2 interrupt has positive polarity.          | Must be set to 1. |
| 8  | D3IP  | DMA Channel 3 Interrupt Polarity<br>0 DMA channel 3 interrupt has negative polarity.<br>1 DMA channel 3 interrupt has positive polarity.          | Must be set to 1. |
| 9  | EWIP  | Ethernet Wake-up Interrupt Polarity<br>0 Ethernet wake-up interrupt has negative polarity.<br>1 Ethernet wake-up interrupt has positive polarity. | Must be set to 1. |
| 10 | MSIP  | MAL SERR Interrupt Polarity<br>0 MAL SERR interrupt has negative polarity.<br>1 MAL SERR interrupt has positive polarity.                         | Must be set to 1. |
| 11 | MTEIP | MAL TX EOB Interrupt Polarity<br>0 MAL TX EOB interrupt has negative polarity.<br>1 MAL TX EOB interrupt has positive polarity.                   | Must be set to 1. |

### Figure 10-4. UIC Polarity Register (UIC0\_PR)

| 12    | MREIP | MAL RX EOB Interrupt Polarity<br>0 MAL RX EOB interrupt has negative polarity.<br>1 MAL RX EOB interrupt has positive polarity.                                                                  | Must be set to 1. |
|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 13    | MTDIP | MAL TX DE Interrupt Polarity<br>0 MAL TX DE interrupt has negative polarity.<br>1 MAL TX DE interrupt has positive polarity.                                                                     | Must be set to 1. |
| 14    | MRDIP | MAL RX DE Interrupt Polarity<br>0 MAL RX DE interrupt has negative polarity.<br>1 MAL RX DE interrupt has positive polarity.                                                                     | Must be set to 1. |
| 15    | EIP   | Ethernet Interrupt Polarity<br>0 An Ethernet interrupt has negative polarity.<br>1 An Ethernet interrupt has positive polarity.                                                                  | Must be set to 1. |
| 16    | EPSIP | External PCI SERR Interrupt Polarity<br>0 External PCI SERR interrupt has negative<br>polarity.<br>1 External PCI SERR interrupt has positive<br>polarity.                                       | Must be set to 1. |
| 17    | ECIP  | <ul> <li>ECC Correctable Error Interrupt Polarity</li> <li>0 ECC correctable error interrupt has negative polarity.</li> <li>1 ECC correctable error interrupt has positive polarity.</li> </ul> | Must be set to 1. |
| 18    | PPMIC | <ul> <li>PCI Power management Interrupt Class</li> <li>0 PCI power management interrupt has negative polarity.</li> <li>1 PCI power management interrupt has positive polarity.</li> </ul>       | Must be set to 1. |
| 19:24 |       | Reserved                                                                                                                                                                                         |                   |
| 25    | EIROP | External IRQ 0 Polarity<br>0 An external IRQ 0 interrupt has negative polarity.<br>1 An external IRQ 0 interrupt has positive polarity.                                                          |                   |
| 26    | EIR1P | External IRQ 1 Polarity<br>0 An external IRQ 1 interrupt has negative polarity.<br>1 An external IRQ 1 interrupt has positive polarity.                                                          |                   |
| 27    | EIR2P | External IRQ 2 Polarity<br>0 An external IRQ 2 interrupt has negative polarity.<br>1 An external IRQ 2 interrupt has positive polarity.                                                          |                   |
| 28    | EIR3P | External IRQ 3 Polarity<br>0 An external IRQ 3 interrupt has negative polarity.<br>1 An external IRQ 3 interrupt has positive polarity.                                                          |                   |
| 29    | EIR4P | External IRQ 4 Polarity<br>0 An external IRQ 4 interrupt has negative polarity.<br>1 An external IRQ 4 interrupt has positive polarity.                                                          |                   |
| 30    | EIR5P | External IRQ 5 Polarity<br>0 An external IRQ 5 interrupt has negative polarity.<br>1 An external IRQ 5 interrupt has positive polarity.                                                          |                   |
|       |       |                                                                                                                                                                                                  |                   |

| 31 | EIR6P | External IRQ 6 Polarity                              |  |
|----|-------|------------------------------------------------------|--|
|    |       | 0 An external IRQ 6 interrupt has negative polarity. |  |
|    |       | 1 An external IRQ 6 interrupt has positive polarity. |  |

### 10.5.5 UIC Trigger Register (UIC0\_TR)

The fields of the UIC0\_TR, which correspond to the fields of the UIC0\_SR, determine whether corresponding fields in the UIC0\_SR are edge-sensitive or level-sensitive.

Edge-sensitive interrupts are triggered depending on whether the associated interrupt signal is rising or falling (changing from 0 to 1 or 1 to 0, respectively). Whether a rising or falling edge causes the trigger is controlled by bits in the UIC0\_PR.

Level-sensitive interrupts are triggered depending on whether the associated interrupt signal is high (1) or low (0).

If a UIC0\_TR field is 0, the associated interrupt is level-sensitive. If the UIC0\_TR field is 1, the interrupt is edge-sensitive. Because the on-chip interrupts (those controlled by  $UIC0_TR_{0:2, 4:18}$ ) are level-sensitive, the associated fields must be set to 0. The external master interrupt trigger (controlled by  $UIC0_TR_3$ ) is edge-sensitive; this field must be set to 1.



| 0 | UOIT  | UARTO Interrupt Trigger<br>0 UARTO interrupt is level-sensitive.<br>1 UARTO interrupt is edge-sensitive.                                                                         | Must be set to 0. |
|---|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 1 | U1IT  | UART1 Interrupt Trigger<br>0 UART1 interrupt is level-sensitive.<br>1 UART1 interrupt is edge-sensitive.                                                                         | Must be set to 0. |
| 2 | IICIT | IIC Interrupt Trigger<br>0 IIC interrupt is level-sensitive.<br>1 IIC interrupt is edge-sensitive.                                                                               | Must be set to 0. |
| 3 | EMIT  | <ul> <li>External Master Interrupt Trigger</li> <li>0 External master interrupt is level-<br/>sensitive.</li> <li>1 External master interrupt is edge-<br/>sensitive.</li> </ul> | Must be set to 1. |
| 4 | PCIIT | PCI Interrupt Trigger<br>0 PCI interrupt is level-sensitive.<br>1 PCI interrupt is edge-sensitive.                                                                               | Must be set to 0. |

Figure 10-5. UIC Trigger Register (UIC0\_TR)

| 5  | DOIT  | DMA Channel 0 Interrupt Trigger                                                                                                                                                        | Must be set to 0. |
|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
|    |       | 0 DMA channel 0 interrupt is level-<br>sensitive.<br>1 DMA channel 0 interrupt is edge-                                                                                                |                   |
|    |       | sensitive.                                                                                                                                                                             |                   |
| 6  | D1IT  | <ul> <li>DMA Channel 1 Interrupt Trigger</li> <li>DMA channel 1 interrupt is level-<br/>sensitive.</li> <li>1 DMA channel 1 interrupt is edge-<br/>sensitive.</li> </ul>               | Must be set to 0. |
| 7  | D2IT  | <ul> <li>DMA Channel 2 Interrupt Trigger</li> <li>0 DMA channel 2 interrupt is level-<br/>sensitive.</li> <li>1 DMA channel 2 interrupt is edge-<br/>sensitive.</li> </ul>             | Must be set to 0. |
| 8  | D3IT  | <ul> <li>DMA Channel 3 Interrupt Trigger</li> <li>DMA channel 3 interrupt is level-<br/>sensitive.</li> <li>1 DMA channel 3 interrupt is edge-<br/>sensitive.</li> </ul>               | Must be set to 0. |
| 9  | EWIT  | Ethernet Wake-up Interrupt Trigger<br>0 Ethernet wake-up interrupt is level-<br>sensitive.<br>1 Ethernet wake-up interrupt is edge-<br>sensitive.                                      | Must be set to 0. |
| 10 | MSIT  | MAL SERR Interrupt Trigger<br>0 MAL SERR interrupt is level-sensitive.<br>1 MAL SERR interrupt is edge-sensitive.                                                                      | Must be set to 0. |
| 11 | MTEIT | MAL TX EOB Interrupt Trigger<br>0 MAL TX EOB interrupt is level-sensitive.<br>1 MAL TX EOB interrupt is edge-sensitive.                                                                | Must be set to 0. |
| 12 | MREIT | MAL RX EOB Interrupt Trigger<br>0 MAL RX EOB interrupt is level-sensitive.<br>1 MAL RX EOB interrupt is edge-sensitive.                                                                | Must be set to 0. |
| 13 | MTDIT | MAL TX DE Interrupt Trigger<br>0 MAL TX DE interrupt is level-sensitive.<br>1 MAL TX DE interrupt is edge-sensitive.                                                                   | Must be set to 0. |
| 14 | MRDIT | MAL RX DE Interrupt Trigger<br>0 MAL RX DE interrupt is level-sensitive.<br>1 MAL RX DE interrupt is edge-sensitive.                                                                   | Must be set to 0. |
| 15 | EIT   | Ethernet Interrupt Trigger<br>0 An Ethernet interrupt is level-sensitive.<br>1 An Ethernet interrupt is edge-sensitive.                                                                | Must be set to 0. |
| 16 | EPSIT | <ul> <li>External PCI SERR Interrupt Trigger</li> <li>0 External PCI SERR interrupt is level-<br/>sensitive.</li> <li>1 External PCI SERR interrupt is edge-<br/>sensitive.</li> </ul> | Must be set to 0. |

| 17    | ECIT  | <ul> <li>ECC Correctable Error Interrupt Trigger</li> <li>0 ECC correctable error interrupt is level-<br/>sensitive.</li> <li>1 ECC correctable error interrupt is edge-<br/>sensitive.</li> </ul> | Must be set to 0. |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| 18    | PPMIT | <ul> <li>PCI Power management Interrupt Trigger</li> <li>0 PCI power management interrupt is<br/>level-sensitive.</li> <li>1 PCI power management interrupt is<br/>edge-sensitive.</li> </ul>      | Must be set to 0. |
| 19:24 |       | Reserved                                                                                                                                                                                           |                   |
| 25    | EIROT | External IRQ 0 Trigger<br>0 An external IRQ 0 interrupt is level-<br>sensitive.<br>1 An external IRQ 0 interrupt is edge-<br>sensitive.                                                            |                   |
| 26    | EIR1T | External IRQ 1 Trigger<br>0 An external IRQ 1 interrupt is level-<br>sensitive.<br>1 An external IRQ 1 interrupt is edge-<br>sensitive.                                                            |                   |
| 27    | EIR2T | External IRQ 2 Trigger<br>0 An external IRQ 2 interrupt is level-<br>sensitive.<br>1 An external IRQ 2 interrupt is edge-<br>sensitive.                                                            |                   |
| 28    | EIR3T | External IRQ 3 Trigger<br>0 An external IRQ 3 interrupt is level-<br>sensitive.<br>1 An external IRQ 3 interrupt is edge-<br>sensitive.                                                            |                   |
| 29    | EIR4T | External IRQ 4 Trigger<br>0 An external IRQ 4 interrupt is level-<br>sensitive.<br>1 An external IRQ 4 interrupt is edge-<br>sensitive.                                                            |                   |
| 30    | EIR5T | <ul> <li>External IRQ 5 Trigger</li> <li>0 An external IRQ 5 interrupt is level-<br/>sensitive.</li> <li>1 An external IRQ 5 interrupt is edge-<br/>sensitive.</li> </ul>                          |                   |
| 31    | EIR6T | External IRQ 6 Trigger<br>0 An external IRQ 6 interrupt is level-<br>sensitive.<br>1 An external IRQ 6 interrupt is edge-<br>sensitive.                                                            |                   |

•

.

### 10.5.6 UIC Masked Status Register (UIC0\_MSR)

This read-only register contains the result of masking the UIC0\_SR with the UIC0\_ER. Reading this register, instead of the actual UIC0\_SR, eliminates the need for software to read and apply the enable mask to the contents of the UIC0\_SR to determine which enabled interrupt fields are active.

If an interrupt is configured as level-sensitive, and a clear is attempted on the UIC0\_SR, the UIC0\_SR field is not cleared if the incoming interrupt signal is at the asserted polarity. The interrupt signal must be reset before the UIC0\_SR can be successfully cleared.



| 0 | UOIS  | UART0 Masked Interrupt Status<br>0 A UART0 interrupt has not occurred.<br>1 A UART0 interrupt occurred.                                                         |
|---|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | U1IS  | UART1 Masked Interrupt Status<br>0 A UART1 interrupt has not occurred.<br>1 A UART1 interrupt occurred.                                                         |
| 2 | licis | IIC Masked Interrupt Status<br>0 An IIC interrupt has not occurred.<br>1 An IIC interrupt occurred.                                                             |
| 3 | EMIS  | External Master Masked Interrupt Status<br>0 An external master interrupt has not<br>occurred.<br>1 An external master interrupt occurred.                      |
| 4 | PCIIS | PCI Masked Interrupt Status<br>0 A PCI interrupt has not occurred.<br>1 A PCI interrupt occurred.                                                               |
| 5 | DOIS  | <ul> <li>DMA Channel 0 Masked Interrupt Status</li> <li>0 A DMA channel 0 interrupt has not occurred.</li> <li>1 A DMA channel 0 interrupt occurred.</li> </ul> |
| 6 | D1IS  | <ul> <li>DMA Channel 1 Masked Interrupt Status</li> <li>0 A DMA channel 1 interrupt has not occurred.</li> <li>1 A DMA channel 1 interrupt occurred.</li> </ul> |
| 7 | D2IS  | <ul> <li>DMA Channel 2 Masked Interrupt Status</li> <li>0 A DMA channel 2 interrupt has not occurred.</li> <li>1 A DMA channel 2 interrupt occurred.</li> </ul> |

### Figure 10-6. UIC Masked Status Register (UIC0\_MSR)

| 8     | D3IS  | <ul> <li>DMA Channel 3 Masked Interrupt Status</li> <li>0 A DMA channel 3 interrupt has not occurred.</li> <li>1 A DMA channel 3 interrupt occurred.</li> </ul>                                    |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | EWIS  | Ethernet Wake-up Masked Interrupt Status<br>0 An Ethernet wake-up interrupt has not<br>occurred.<br>1 An Ethernet wake-up interrupt occurred.                                                      |
| 10    | MSIS  | MAL SERR Masked Interrupt Status<br>0 A MAL SERR interrupt has not occurred.<br>1 A MAL SERR interrupt occurred.                                                                                   |
| 11    | MTEIS | MAL TX EOB Masked Interrupt Status<br>0 A MAL TX EOB interrupt has not<br>occurred.<br>1 A MAL TX EOB interrupt occurred.                                                                          |
| 12 .  | MREIS | MAL RX EOB Masked Interrupt Status<br>0 A MAL RX EOB interrupt has not<br>occurred.<br>1 A MAL RX EOB interrupt occurred.                                                                          |
| 13    | MTDIS | MAL TX DE Masked Interrupt Status<br>0 A MAL TX DE interrupt has not occurred.<br>1 A MAL TX DE interrupt occurred.                                                                                |
| 14    | MRDIS | MAL RX DE Masked Interrupt Status<br>0 A MAL RX DE interrupt has not occurred.<br>1 A MAL RX DE interrupt occurred.                                                                                |
| 15    | EIS   | Ethernet Masked Interrupt Status<br>0 An Ethernet interrupt has not occurred.<br>1 An Ethernet interrupt occurred.                                                                                 |
| 16    | EPSIE | External PCI SERR Masked Interrupt<br>Status<br>0 An external PCI SERR interrupt has not<br>occurred.<br>1 An external PCI SERR interrupt<br>occurred.                                             |
| 17    | ECIS  | ECC Correctable Error Masked Interrupt<br>Status<br>0 An ECC correctable error interrupt did<br>not occur.<br>1 An ECC correctable error interrupt<br>occurred.                                    |
| 18    | PPMIS | <ul> <li>PCI Power Management Masked Interrupt</li> <li>Status</li> <li>0 A PCI power management interrupt did<br/>not occur.</li> <li>1 A PCI power management interrupt<br/>occurred.</li> </ul> |
| 19:24 |       | Reserved                                                                                                                                                                                           |

|    |       |                                                                                                                               | and the second |
|----|-------|-------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 25 | EIROE | External IRQ 0 Masked Status<br>0 An external IRQ 0 interrupt has not<br>occurred.<br>1 An external IRQ 0 interrupt occurred. |                                                                                                                  |
| 26 | EIR1S | External IRQ 1 Masked Status<br>0 An external IRQ 1 interrupt has not<br>occurred.<br>1 An external IRQ 1 interrupt occurred. |                                                                                                                  |
| 27 | EIR2S | External IRQ 2 Masked Status<br>0 An external IRQ 2 interrupt has not<br>occurred.<br>1 An external IRQ 2 interrupt occurred. |                                                                                                                  |
| 28 | EIR3S | External IRQ 3 Masked Status<br>0 An external IRQ 3 interrupt has not<br>occurred.<br>1 An external IRQ 3 interrupt occurred. |                                                                                                                  |
| 29 | EIR4S | External IRQ 4 Masked Status<br>0 An external IRQ 4 interrupt has not<br>occurred.<br>1 An external IRQ 4 interrupt occurred. |                                                                                                                  |
| 30 | EIR5S | External IRQ 5 Masked Status<br>0 An external IRQ 5 interrupt has not<br>occurred.<br>1 An external IRQ 5 interrupt occurred. |                                                                                                                  |
| 31 | EIR6S | External IRQ 6 Masked Status<br>0 An external IRQ 6 interrupt has not<br>occurred.<br>1 An external IRQ 6 interrupt occurred. |                                                                                                                  |

## 10.5.7 UIC Vector Configuration Register (UIC0\_VCR)

The write-only UIC0\_VCR enables software control of interrupt vector generation for critical interrupts. UIC0\_VCR contains an address, used as an interrupt vector base address, and specifies interrupt ordering priority. Vector generation is not performed for non-critical interrupts.

UIC0\_VCR[VBA] can contain either the base address for an interrupt handler vector table or the base address for the interrupt handler associated with each interrupt. The actual interrupt vector (the address of the interrupt handler that services the interrupt) is generated in the UIC0\_VR, using UIC0\_VCR[VBA]. Vector generation is described in "UIC Vector Register (UIC0\_VR)" on page 10-19. Because the two lowest-order bits of an interrupt handler address are assumed to be 00 to ensure word alignment, 30 bits are sufficient to form the base address.

A general interrupt handler uses the vector to access a table of interrupt vectors. Each interrupt vector table entry contains the address of an interrupt handler for a specific interrupt. Alternatively, UIC0\_VCR[VBA] can directly address the interrupt handlers for specific interrupts, which in memory are separated by an offset calculated in UIC0\_VR.

UIC0\_VCR[PRO] controls whether the interrupt associated with UIC0\_SR[0] or UIC0\_SR[31] has the highest priority. If UIC0\_VCR[PRO] = 0, the interrupt associated with UIC0\_SR[0] has the highest priority; if UIC0\_VCR[PRO] = 1, the interrupt associated with UIC0\_SR[31] has the highest priority.

The bit closest to the highest priority field that is programmed in the UIC0\_CR as a interrupt has the second highest priority. Priority decreases across the UIC0\_SR to the end opposite the highest priority field.



| 0:29 | VBA | Vector Base Address                                                                                                                                                                                        |
|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   |     | Reserved                                                                                                                                                                                                   |
| 31   | PRO | Priority Ordering<br>0 UIC0_SR[0] is the highest priority<br>interrupt.<br>1 UIC0_SR[31] is the highest priority<br>interrupt.<br>Note: Vector generation is not performed<br>for non-critical interrupts. |

| Figure 10-7. | <b>UIC Vector Confi</b> | guration Register | (UIC0 VCR) |
|--------------|-------------------------|-------------------|------------|
|              |                         |                   |            |

### 10.5.8 UIC Vector Register (UIC0\_VR)

The read-only UIC0\_VR contains an interrupt vector that can reduce interrupt handling latency for critical interrupts. Vector generation logic adds an offset to UIC0\_VCR[VBA], and the sum is returned in the UIC0\_VR. Vectors are not computed for non-critical interrupts.

The interrupt vector is based on the field position of the current highest priority, enabled, active, critical interrupt relative to the highest priority interrupt in the UIC0\_SR. The generated vectors can be programmed to point directly to the interrupt handlers.

**Programming Note:** Regardless of the programming of UIC0\_VCR and UIC0\_VR registers, the processor always vectors to EVPR[0:16] II 0x100 when a critical interrupt occurs.

The interrupt vector offset is based on the bit position of the current highest priority, enabled, active, critical interrupt relative to the highest priority interrupt in the UIC0\_SR. The offset has a fixed value of 512 per bit. The main critical interrupt handler can interpret the vector returned by UIC0\_VR as the address of the interrupt handler for that interrupt, assuming the routine is 512 bytes or smaller. Alternatively, the main critical interrupt handler can interpret the vector as a look-up table entry for the address of the interrupt handler for that interrupt.

0

#### Figure 10-8. UIC Vector Register (UIC0 VR)

| 0:31 | 1 | Interrupt Vector |
|------|---|------------------|
|      |   |                  |

The following example illustrates the generation of a UIC0\_VR vector for external interrupt request IRQ2.

For the example, assume that UIC0\_VCR[PRO] = 1, so that UIC0\_SR[EIR6S] (UIC0\_SR<sub>31</sub>)has the highest interrupt priority, and that UIC0\_SR[EIR2S] (UIC0\_SR27) is the current highest priority, enabled, active, critical interrupt. To generate the vector for the interrupt associated with UIC0\_SR[EIR2S], internal logic multiplies the difference between the highest priority interrupt bit and the active enabled priority interrupt bit by 512. The interrupt vector offset is therefore (31 -27)  $\times$  512 = 4  $\times$  512. This offset is added to the base address in UIC0\_VCR[VBA], and the UIC0\_VR returns UIC0\_VCR[VBA] + (4 × 512).

#### 10.5.8.1 Using the Value in UIC0\_VR as a Vector Address or Entry Table Lookup

If an interrupt handler is 512 bytes or smaller, system software can interpret the value returned in the UIC0 VR as an address. In this case, when the interrupt is received, the UIC0 VR is read and software simply jumps to the address represented by the UIC0\_VR value. Alternatively, the routine can be at a different address, and system software can treat the value of the UIC0\_VR as a pointer, storing the interrupt handler address in the UIC0\_VR during system initialization. In this case, when the interrupt is handled, software must read the UIC0 VR, read the entry at the UIC0 VR value, and jump to the entry. Hardware has no knowledge of the method is used, which is determined by system software.

#### 10.5.8.2 Vector Generation Scenarios

For the following sequence, assume that the interrupts are enabled and critical (vectors are not generated for disabled or non-critical interrupts). The sequence illustrates several scenarios for vector generation.

- 1. An intermediate priority interrupt goes active; its vector is stored in UIC0\_VR.
- 2. A low priority interrupt goes active; UIC0\_VR is unchanged.
- Software reads the vector; UIC0\_VR is unchanged.
- 4. Software resets the intermediate priority interrupt; UIC0, VR contains the vector for the low priority interrupt.
- 5. A high priority interrupt goes active; UIC0\_VR contains the vector for the high priority interrupt.
- Software resets the high priority interrupt; UIC0\_VR contains the vector for the low priority interrupt.

31

- 7. Software resets the UIC0\_ER field for the low priority interrupt, disabling it; UIC0\_VR contains 0x00000000.
- 8. UIC0\_CR is reprogrammed to make the low priority interrupt non-critical and UIC0\_ER is reprogrammed to re-enable the low priority interrupt; UIC0\_VR continues to contain 0x00000000.

10-21

## 10.6 Interrupt Handling in the Processor Core

An *interrupt* is the action in which the processor saves its old context (MSR and instruction pointer) and begins execution at a pre-determined interrupt-handler address, with a modified MSR. *Exceptions* are events which, if enabled, cause the processor to take an interrupt. Exceptions are generated by signals from internal and external peripherals, instructions, internal timer facilities, debug events, or error conditions.

Table 10-4, "Interrupt Vector Offsets," on page 10-27, lists the interrupts handled by the PPC405GP in the order of interrupt vector offsets. Detailed descriptions of each interrupt follow, in the same order. Table 10-4 also provides an index to the descriptions.

Several registers support interrupt handling and control. "General Interrupt Handling Registers" on page 10-27 describes the general interrupt handling registers:

- Data Exception Address Register (DEAR)
- Exception Syndrome Register (ESR)
- Exception Vector Prefix Register (EVPR)
- Machine State Register (MSR)
- Save/Restore Registers (SRR0–SRR3)

### **10.7** Architectural Definitions and Behavior

*Precise* interrupts are those for which the instruction pointer saved by the interrupt must be either the address of the excepting instruction or the address of the next sequential instruction. *Imprecise* interrupts are those for which it is possible (but not required) for the saved instruction pointer to be something else, possibly prohibiting guaranteed software recovery.

Note that "precise" and "imprecise" are defined assuming that the interrupts are unmasked (enabled to occur) when the associated exception occurs. Consider an exception that would cause a precise interrupt, if the interrupt was enabled at the time of the exception, but that occurs while the interrupt is masked. Some exceptions of this type can cause the interrupt to occur later, immediately upon its enabling. In such a case, the interrupt is not considered precise with respect to the enabling instruction, but imprecise ("delayed precise") with respect to the cause of the exception.

Asynchronous interrupts are caused by events which are independent of instruction execution. All asynchronous interrupts are precise, and the following rules apply:

- All instructions prior to the one whose address is reported to the interrupt handling routine (in the save/restore register) have completed execution. However, some storage accesses generated by these preceding instructions may not have completed.
- 2. No subsequent instruction has begun execution, including the instruction whose address is reported to the interrupt handling routine.
- 3. The instruction having its address reported to the interrupt handler may appear not to have begun execution, or may have partially completed.

*Synchronous* interrupts are caused directly by the execution (or attempted execution) of instructions. Synchronous interrupts can be either precise or imprecise.

For synchronous precise interrupts, the following rules apply:

- 1. The save/restore register addresses either the instruction causing the exception or the next sequential instruction. Which instruction is addressed is determined by the interrupt type and status bits.
- All instructions preceding the instruction causing the exception have completed execution. However, some storage accesses generated by these preceding instructions may not have completed.
- The instruction causing the exception may appear not to have begun execution (except for causing the exception), may have partially completed, or may have completed, depending on the interrupt type.
- 4. No subsequent instruction has begun execution.

The PPC405GP does not implement any imprecise interrupts. Refer to *IBM PowerPC Embedded Environment* for an architectural description of imprecise interrupts.

*Machine check* interrupts are a special case typically caused by some kind of hardware or storage subsystem failure, or by an attempt to access an invalid address. A machine check can be indirectly caused by the execution of an instruction, but not recognized or reported until long after the processor has executed past the instruction that caused the machine check. As such, machine check interrupts cannot properly be thought of as synchronous, nor as precise or imprecise. For machine checks, the following general rules apply:

- 1. No instruction following the one whose address is reported to the machine check handler in the save/restore register has begun execution.
- 2. The instruction whose address is reported to the machine check handler in the save/restore register, and all previous instructions, may or may not have completed successfully. All previous instructions that would ever complete have completed, within the context existing before the machine check interrupt. No further interrupt (other than possible additional machine checks) can occur as a result of those instructions.

### 10.8 Behavior of the PPC405GP Implementation

All interrupts, except for machine checks, are handled precisely. Precise handling implies that the address of the excepting instruction (for synchronous exceptions other than the system call exception), or the address of the next instruction to be executed (asynchronous exceptions and the system call exception), is passed to an interrupt handling routine. Precise handling also implies that all instructions that precede the instruction whose address is reported to the interrupt handling routine have executed and that no subsequent instruction has begun execution. The specific instruction whose address is reported may not have begun execution or may have partially completed, as specified for each precise interrupt type.

Synchronous precise interrupts include most debug event interrupts, program interrupts, instruction and data storage interrupts, TLB miss interrupts, system call interrupts, and alignment interrupts.

Asynchronous precise interrupts include the critical and noncritical external interrupts, and can be caused by on-chip peripherals, timer facility interrupts, and some debug events.

In the PPC405GP, machine checks are handled as critical interrupts (see "Critical and Noncritical Interrupts" on page 10-26). If a machine check is associated with an instruction fetch, the critical

interrupt save/restore register contains the address of the instruction being fetched when the machine check occurred.

The synchronism of instruction-side machine checks (errors that occur while attempting to fetch an instruction from external memory) requires further explanation. Fetch requests to cachable memory that miss in the instruction cache unit (ICU) cause an instruction cache line fill (eight words). If any instructions (words) in the fetched line are associated with an exception, an interrupt occurs upon attempted execution and the cache line is invalidated.

It is improper to declare an exception when an erroneous word is passed to the fetcher; the address could be the result of an incorrect speculative access. It is quite likely that no attempt will be made to execute an instruction from the erroneous address. An instruction-side machine check interrupt occurs only when execution is attempted. If an exception occurs, execution is suppressed, SRR2 contains the erroneous address, and the ESR indicates that an instruction-side machine check occurred. Although such an interrupt is clearly asynchronous to the erroneous memory access, it is handled synchronously with respect to the attempted execution from the erroneous address.

Except for machine checks, all PPC405GP interrupts are handled precisely:

- The address of the excepting instruction (for synchronous exceptions, other than the system call
  exception) or the address of the next sequential instruction (for asynchronous exceptions and the
  system call exception) is passed to the interrupt handling routine.
- All instructions that precede the instruction whose address is reported to the interrupt handling
  routine have completed execution and that no subsequent instruction has begun execution. The
  specific instruction whose address is reported might not have begun execution or might have
  partially completed, as specified for each interrupt type.

### **10.9 Interrupt Handling Priorities**

The PPC405GP processor core handles only one interrupt at a time. Multiple simultaneous interrupts are handled in the priority order shown in Table 10-3 (assuming, of course, that the interrupt types are enabled).

Multiple interrupts can exist simultaneously, each of which requires the generation of an interrupt. The architecture does not provide for simultaneously reporting more than one interrupt of the same class (critical or non-critical). Therefore, interrupts are ordered with respect to each other. A masking mechanism is available for certain persistent interrupt types.

When an interrupt type is masked, and an event causes an exception which would normally generate an interrupt of that type, the exception *persists* as a *status* bit in a register. However, no interrupt is generated. Later, if the interrupt type is enabled (unmasked), and the exception status has not been cleared by software, the interrupt due to the original exception event is finally generated. All asynchronous interrupt types can be masked. In addition, certain synchronous interrupt types can be masked.

| Priority | Interrupt Type                                                 | Critical or<br>Noncritical | Causing Conditions                                                                                                                                                                    |  |
|----------|----------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1        | Machine check-data                                             | Critical                   | External bus error during data-side access                                                                                                                                            |  |
| 2        | Debug—IAC                                                      | Critical                   | IAC debug event (in internal debug mode)                                                                                                                                              |  |
| 3        | Machine check—<br>instruction                                  | Critical                   | Attempted execution of instruction for which an external bus error occurred during fetch                                                                                              |  |
| 4        | Debug—EXC, UDE                                                 | Critical                   | EXC or UDE debug event (in internal debug mode)                                                                                                                                       |  |
| 5        | Critical interrupt input                                       | Critical                   | Active level on the critical interrupt input                                                                                                                                          |  |
| 6        | Watchdog timer—first<br>time-out                               | Critical                   | Posting of an enabled first time-out of the watchdog timer in the TSR                                                                                                                 |  |
| 7        | Instruction TLB Miss                                           | Noncritical                | Attempted execution of an instruction at an address<br>and process ID for which a valid matching entry was not<br>found in the TLB                                                    |  |
| 8        | Instruction storage —<br>ZPR[Z <i>n</i> ] = 00                 | Noncritical                | Instruction translation is active, execution access to the translated address is not permitted because $ZPR[Zn] = 00$ in user mode, and an attempt is made to execute the instruction |  |
| 9        | Instruction storage —<br>TLB_entry[EX] = 0                     | Noncritical                | Instruction translation is active, execution access to the translated address is not permitted because TLB_entry[EX] = 0, and an attempt is made to execute the instruction           |  |
|          | Instruction storage —<br>TLB_entry[G] = 1                      | Noncritical                | Instruction translation is active, the page is marked guarded, and an attempt is made to execute the instruction                                                                      |  |
| 10       | Program                                                        | Noncritical                | Attempted execution of illegal instructions, TRAP instruction, privileged instruction in problem state                                                                                |  |
|          | System call                                                    | Noncritical                | Execution of the sc instruction                                                                                                                                                       |  |
| 11       | Data TLB miss                                                  | Noncritical                | Valid matching entry for the effective address and process ID of an attempted data access is not found in the TLB                                                                     |  |
| 12       | Data storage—<br>ZPR[Zn] = 00                                  | Noncritical                | Data translation is active and data-side access to the translated address is not permitted because<br>ZPR[Zn] = 00 in user mode                                                       |  |
| 13       | Data storage—<br>TLB_entry[WR] = 0                             | Noncritical                | Data translation is active and write access to the<br>translated address is not permitted because<br>TLB_entry[WR] = 0                                                                |  |
|          | Data storage—<br>TLB_entry[U0] = 1 or<br>SU0R[U <i>n</i> ] = 1 | Noncritical                | Data translation is active and write access to the translated address is not permitted because $TLB\_entry[U0] = 1$ or $SU0R[Un] = 1$                                                 |  |
| 14       | Alignment                                                      | Noncritical                | <b>dcbz</b> to non-cachable address or write-through<br>storage; non-word aligned <b>dcread</b> , <b>Iwarx</b> , and <b>stwcx</b> ,<br>as described in Table 10-13                    |  |
| 15       | Debug—BT, DAC, DVC,<br>IC, TIE                                 | Critical                   | BT, DAC, DVC, IC, TIE debug event (in internal debug mode)                                                                                                                            |  |

Table 10-3. Interrupt Handling Priorities

| Priority | Interrupt Type                       | Critical or<br>Noncritical | Causing Conditions                                                            |
|----------|--------------------------------------|----------------------------|-------------------------------------------------------------------------------|
| 16       | External interrupt input             | Noncritical                | Interrupts from the external interrupt (external to the processor core) input |
| 17       | Fixed Interval Timer (FIT)           | Noncritical                | Posting of an enabled FIT interrupt in the TSR                                |
| 18       | Programmable Interval<br>Timer (PIT) | Noncritical                | Posting of an enabled PIT interrupt in the TSR                                |

Table 10-3. Interrupt Handling Priorities (continued)

## **10.10 Critical and Noncritical Interrupts**

The PPC405GP processes interrupts as noncritical and critical. Twelve interrupts are defined as *noncritical*: data storage, instruction storage, an active external interrupt input, alignment, program, system call, programmable interval timer (PIT), fixed interval timer (FIT), data TLB miss, and instruction TLB miss. Five interrupts are defined as *critical*: machine check interrupts (instruction- and data-side), debug interrupts (any of the seven types), interrupts caused by an active critical interrupt input, and the first time-out from the watchdog timer.

When a *noncritical* interrupt is taken, Save/Restore Register 0 (SRR0) is written with the address of the excepting instruction (most synchronous interrupts) or the next sequential instruction to be processed (asynchronous interrupts and system call).

If the PPC405GP was executing a multicycle instruction (multiply, divide, or cache operation), the instruction is terminated and its address is written in SRR0.

Aligned scalar loads/stores that are interrupted do not appear on the PLB. An aligned scalar load/store cannot be interrupted after it is requested on the PLB, so the Guarded (G) storage attribute does not need to prevent the interruption of an aligned scalar load/store.

To enhance performance, the DCU can respond to non-cachable load requests by retrieving a line instead of a word. This is controlled by CCR0[LWL]. Note, however, that If CCR0[LWL] = 1, and the target non-cachable region is also marked as guarded (the G storage attribute is set to 1), that the DCU will request on the PLB only those bytes requested by the CPU.

Load/store multiples, load/store string, and misaligned scalar loads/stores that cross a word boundary can be interrupted and restarted upon return from the interrupt handler.

When load instructions terminate, the addressing registers are not updated. This ensures that the instructions can be restarted; if the addressing registers were in the range of registers to be loaded, this would be an invalid form in any event. Some target registers of a load instruction may have been written by the time of the interrupt; when the instruction restarts, the registers will simply be written again. Similarly, some of the target memory of a store instruction may have been written, and is written again when the instruction restarts.

Save/Restore Register 1 (SRR1) is written with the contents of the MSR; the MSR is then updated to reflect the new machine context. The new MSR contents take effect beginning with the first instruction of the interrupt handling routine.

Interrupt handling routine instructions are fetched at an address determined by the interrupt type. The address of the interrupt handling routine is formed by concatenating the 16 high-order bits of the

EVPR and the interrupt vector offset. (A user must initialize the EVPR contents at power-up using an **mtspr** instruction.)

Table 10-4 shows the interrupt vector offsets for the interrupt types. Note that there can be multiple sources of the same interrupt type; interrupts of the same type are mapped to the same interrupt vector, regardless of source. In such cases, the interrupt handling routine must examine status registers to determine the exact source of the interrupt.

At the end of the interrupt handling routine, execution of an **rfi** instruction forces the contents of SRR0 and SRR1 to be written to the program counter and the MSR, respectively. Execution then begins at the address in the program counter.

Critical interrupts are processed similarly. When a critical interrupt is taken, Save/Restore Register 2 (SRR2) and Save/Restore Register 3 (SRR3) hold the next sequential address to be processed when returning from the interrupt, and the contents of the MSR, respectively. At the end of the critical interrupt handling routine, execution of an **rfci** instruction writes the contents of SRR2 and SRR3 into the program counter and the MSR, respectively.

| Offset | Interrupt Type                                                                                                                     | Interrupt Class      | Category    | Page  |
|--------|------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|-------|
| 0x0100 | Critical input interrupt                                                                                                           | Asynchronous precise | Critical    | 10-34 |
| 0x0200 | Machine check—data                                                                                                                 |                      | Critical    | 10-35 |
|        | Machine check—instruction                                                                                                          |                      | Critical    | 10-35 |
| 0x0300 | Data storage interrupt—<br>MSR[DR]=1 and<br>ZPR[ $Zn$ ] = 0 or<br>TLB_entry[WR] = 0 or<br>TLB_entry[U0] = 1 or<br>SU0R[ $Un$ ] = 1 | Synchronous precise  | Noncritical | 10-36 |
| 0x0400 | Instruction storage interrupt                                                                                                      | Synchronous precise  | Noncritical | 10-38 |
| 0x0500 | External interrupt (external to the processor core)                                                                                | Asynchronous precise | Noncritical | 10-38 |
| 0x0600 | Alignment                                                                                                                          | Synchronous precise  | Noncritical | 10-39 |
| 0x0700 | Program                                                                                                                            | Synchronous precise  | Noncritical | 10-40 |
| 0x0C00 | System Call                                                                                                                        | Synchronous precise  | Noncritical | 10-41 |
| 0x1000 | PIT                                                                                                                                | Asynchronous precise | Noncritical | 10-41 |
| 0x1010 | FIT                                                                                                                                | Asynchronous precise | Noncritical | 10-42 |
| 0x1020 | Watchdog timer                                                                                                                     | Asynchronous precise | Critical    | 10-43 |
| 0x1100 | Data TLB miss                                                                                                                      | Synchronous precise  | Noncritical | 10-43 |
| 0x1200 | Instruction TLB miss                                                                                                               | Synchronous precise  | Noncritical | 10-44 |
| 0x2000 | Debug—BT, DAC, DVC,<br>IAC, IC, TIE                                                                                                | Synchronous precise  | Critical    | 10-44 |
|        | Debug—EXC, UDE                                                                                                                     | Asynchronous precise | Critical    |       |

#### Table 10-4. Interrupt Vector Offsets

### **10.11 General Interrupt Handling Registers**

The general interrupt handling registers are the Machine State Register (MSR), SRR0–SRR3, the Exception Vector Prefix Register (EVPR), the Exception Syndrome Register (ESR), and the Data Exception Address Register (DEAR).

### 10.11.1 Machine State Register (MSR)

The MSR is a 32-bit register that holds the current context of the PPC405GP. When a noncritical interrupt is taken, the MSR contents are written to SRR1; when a critical interrupt is taken, the MSR contents are written to SRR3. When an **rfi** or **rfci** instruction executes, the contents of the MSR are read from SRR1 or SRR3, respectively.

Programming Note: The rfi and rfci instructions can alter reserved MSR fields.

The MSR contents can be read into a general purpose register (GPRs) using an **mfmsr** instruction. The contents of a GPR can be written to the MSR using an **mtmsr** instruction. The MSR[EE] bit may be set/cleared atomically using the **wrtee** or **wrteei** instructions.

Figure 10-9 shows the MSR bit definitions and describes the function of each bit.



| 0:12 |    | Reserved                                                                                                                                           |                                                                                                                                                    |
|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | WE | Wait State Enable<br>0 The processor is not in the wait state.<br>1 The processor is in the wait state.                                            | If MSR[WE] = 1, the processor remains in<br>the wait state until an interrupt is taken, a<br>reset occurs, or an external debug tool<br>clears WE. |
| 14   | CE | Critical Interrupt Enable<br>0 Critical interrupts are disabled.<br>1 Critical interrupts are enabled.                                             | Controls the critical interrupt input and watchdog timer first time-out interrupts.                                                                |
| 15   |    | Reserved                                                                                                                                           |                                                                                                                                                    |
| 16   | EE | External Interrupt Enable<br>0 Asynchronous interrupts (external to the<br>processor core) are disabled.<br>1 Asynchronous interrupts are enabled. | Controls the non-critical external interrupt input, PIT, and FIT interrupts.                                                                       |
| 17   | PR | Problem State<br>0 Supervisor state (all instructions<br>allowed).<br>1 Problem state (some instructions not<br>allowed).                          |                                                                                                                                                    |
| 18   |    | Reserved                                                                                                                                           |                                                                                                                                                    |
| 19   | ME | Machine Check Enable<br>0 Machine check interrupts are disabled.<br>1 Machine check interrupts are enabled.                                        |                                                                                                                                                    |
| 20   |    | Reserved                                                                                                                                           |                                                                                                                                                    |

Figure 10-9. Machine State Register (MSR)

| 21    | DWE | Debug Wait Enable<br>0 Debug wait mode is disabled.<br>1 Debug wait mode is enabled.                                          |
|-------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| 22    | DE  | Debug Interrupts Enable<br>0 Debug interrupts are disabled.<br>1 Debug interrupts are enabled.                                |
| 23:25 |     | Reserved                                                                                                                      |
| 26    | IR  | Instruction Relocate<br>O Instruction address translation is<br>disabled.<br>1 Instruction address translation is<br>enabled. |
| 27    | DR  | Data Relocate<br>0 Data address translation is disabled.<br>1 Data address translation is enabled.                            |
| 28:31 |     | Reserved                                                                                                                      |

### 10.11.2 Save/Restore Registers 0 and 1 (SRR0–SRR1)

SRR0 and SRR1 are 32-bit registers that hold the interrupted machine context when a noncritical interrupt is processed. On interrupt, SRR0 is set to the current or next instruction address and the contents of the MSR are written to SRR1. When an **rfi** instruction is executed at the end of the interrupt handler, the program counter and the MSR are restored from SRR0 and SRR1, respectively.

The contents of SRR0 and SRR1 can be written into GPRs using the **mfspr** instruction. The contents of GPRs can be written to SRR0 and SRR1 using the **mtspr** instruction.

Figure 10-10 shows the bit definitions for SRR0.

| 0  | 20 30 31        |
|----|-----------------|
| 10 | 29 30 31        |
|    | لنقيب ومستكيبيا |

| Figure 10-10. | Save/Restore Register 0 (SRR0) |
|---------------|--------------------------------|
|---------------|--------------------------------|

|       |  | SRR0 receives an instruction address when a non-critical interrupt is taken; the Program Counter is restored from SRR0 when <b>rfi</b> executes. |
|-------|--|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:31 |  | Reserved                                                                                                                                         |

Figure 10-11 shows the bit definitions for SRR1.





| 0:31 | SRR1 receives a copy of the MSR when an interrupt is taken; the MSR is restored from |
|------|--------------------------------------------------------------------------------------|
|      | SRR1 when rfi executes.                                                              |

### 10.11.3 Save/Restore Registers 2 and 3 (SRR2–SRR3)

SRR2 and SRR3 are 32-bit registers that hold the interrupted machine context when a critical interrupt is processed. On interrupt, SRR2 is set to the current or next instruction address and the contents of the MSR are written to SRR3. When an **rfci** instruction is executed at the end of the interrupt handler, the program counter and the MSR are restored from SRR2 and SRR3, respectively.

The contents of SRR2 and SRR3 can be written to GPRs using the **mfspr** instruction. The contents of GPRs can be written to SRR2 and SRR3 using the **mtspr** instruction.

Figure 10-12 shows the bit definitions for SRR2.

|   |  | <br> | <br>         |
|---|--|------|--------------|
| 0 |  |      | <br>29 30 31 |
|   |  |      | 29 30 31     |
|   |  |      |              |
|   |  |      |              |

### Figure 10-12. Save/Restore Register 2 (SRR2)

| 0:29  | SRR2 receives an instruction address when a critical interrupt is taken; the Program Counter is restored from SRR2 when <b>rfci</b> executes. |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 30:31 | Reserved                                                                                                                                      |

Figure 10-13 shows the bit definitions for SRR3.





| 0:31 | SRR3 receives a copy of the MSR when a critical interrupt is taken; the MSR is restored |
|------|-----------------------------------------------------------------------------------------|
|      | from SRR3 when <b>rfci</b> executes.                                                    |

Because critical interrupts do not automatically clear MSR[ME], SRR2 and SRR3 can be corrupted by a machine check interrupt, if the machine check occurs while SRR2 and SRR3 contain valid data that has not yet been saved by the critical interrupt handler.

### 10.11.4 Exception Vector Prefix Register (EVPR)

The EVPR is a 32-bit register whose high-order 16 bits contain the prefix for the address of an interrupt handling routine. The 16-bit interrupt vector offsets (shown in Table 10-4, "Interrupt Vector Offsets," on page 10-27) are concatenated to the right of the high-order 16 bits of the EVPR to form the 32-bit address of an interrupt handling routine.

The contents of the EVPR can be written to a GPR using the **mfspr** instruction. The contents of a GPR can be written to EVPR using the **mtspr** instruction.

Figure 10-14 shows the EVPR bit definitions.



| Figure 10-14. | Exception | Vector Prefix | Register     | (EVPR) |
|---------------|-----------|---------------|--------------|--------|
| rigale to the | EXCOPTION | 100101 110117 | i logiotoi i |        |

| 0:15  | EVP | Exception Vector Prefix |
|-------|-----|-------------------------|
| 16:31 |     | Reserved                |

### 10.11.5 Exception Syndrome Register (ESR)

The ESR is a 32-bit register whose bits help to specify the exact cause of various synchronous interrupts. These interrupts include instruction and data side machine checks, data storage interrupts, and program interrupts, instruction storage interrupts, and data TLB miss interrupts.

"Instruction Machine Check Handling" on page 10-35 describes instruction machine checks. "Data Storage Interrupt" on page 10-36 describes data storage interrupts. "Program Interrupt" on page 10-40 describes program interrupts.

Although interrupt handling routines are not required to reset the ESR, it is recommended that instruction machine check handlers reset the ESR; "Instruction Machine Check Handling" on page 10-35 describes why such resets are recommended.

The contents of the ESR can be written to a GPR using the **mfspr** instruction. The contents of a GPR can be written to the ESR using the **mtspr** instruction.

Figure 10-15 shows the ESR bit definitions.



| Figure 10-15. Exception Syndrome Register (ESR) | Figure 10-15. | Exception | Svndrome | Register | (ESR) |
|-------------------------------------------------|---------------|-----------|----------|----------|-------|
|-------------------------------------------------|---------------|-----------|----------|----------|-------|

| 0     | MCI | Machine check—instruction<br>0 Instruction machine check did not occur.<br>1 Instruction machine check occurred.                                           |  |
|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1:3   |     | Reserved                                                                                                                                                   |  |
| 4     | PIL | Program interrupt—illegal<br>0 Illegal Instruction error did not occur.<br>1 Illegal Instruction error occurred.                                           |  |
| 5     | PPR | Program interrupt—privileged<br>0 Privileged instruction error did not occur.<br>1 Privileged instruction error occurred.                                  |  |
| 6     | PTR | Program interrupt—trap<br>0 Trap with successful compare did not<br>occur.<br>1 Trap with successful compare occurred.                                     |  |
| 7     |     | Reserved                                                                                                                                                   |  |
| 8     | DST | Data storage interrupt—store fault<br>0 Excepting instruction was not a store.<br>1 Excepting instruction was a store<br>(includes dcbi, dcbz, and dccci). |  |
| 9     | DIZ | Data/instruction storage interrupt—zone<br>fault<br>0 Excepting condition was not a zone fault.<br>1 Excepting condition was a zone fault.                 |  |
| 10:15 |     | Reserved                                                                                                                                                   |  |

| 16    | UOF | Data storage interrupt—U0 fault<br>0 Excepting instruction did not cause a U0<br>fault.<br>1 Excepting instruction did cause a U0<br>fault. |
|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 17:31 |     | Reserved                                                                                                                                    |

In general, ESR bits are set to indicate the type of precise interrupt that occurred; other bits are cleared. However, the machine check—instruction (ESR[MCI]) bit behaves differently. Because instruction-side machine checks can occur without an interrupt being taken (if MSR[ME] = 0), ESR[MCI] can be set even while other ESR-setting interrupts (program, data storage, DTLB-miss) occurring. Thus, data storage and program interrupts leave ESR[MCI] unchanged, clear all other ESR bits, and set the bits associated with any data storage or program interrupts occurred. Enabled instruction-side machine checks (MSR[ME] = 1) set ESR[MCI] and clear the data storage and program interrupt bits.

If a machine check—instruction interrupt occurs but is disabled (MSR[ME] = 0), it sets ESR[MCI] but leaves the data storage and program interrupt bits alone. If a machine check—instruction interrupt occurs while MSR[ME] = 0, and the instruction upon which the machine check—instruction interrupt is occurring also is some other kind of ESR-setting instruction (program, data storage, DTLB-miss, or instruction storage interrupt), ESR[MCI] is set to indicate that a machine check—instruction interrupt occurred; the other ESR bits are set or cleared to indicate the other interrupt. These scenarios are summarized in Table 10-5

| Scenario                                          | ESR <sub>4:</sub> | ESR <sub>8:9, 16</sub> |
|---------------------------------------------------|-------------------|------------------------|
| Program interrupt without machine check interrupt | Set to type       | Cleared                |
| Enabled MCI                                       | Cleared           | Cleared                |
| Disabled MCI, no others                           | Unchanged         | Unchanged              |
| Disabled MCI and program interrupt                | Set to type       | Cleared                |

#### Table 10-5. ESR Alteration by Various Interrupts

#### Table 10-6. ESR Alteration by Various Interrupts

| Scenario                           | ECR[MCI]  | ESR4:       | ESR <sub>8:9, 16</sub> |
|------------------------------------|-----------|-------------|------------------------|
| Program interrupt                  | Unchanged | Set to type | Cleared                |
| Data storage interrupt             | Unchanged | Cleared     | Set to Type            |
| Data TLB miss interrupt            | Unchanged | Cleared     | Cleared                |
| Machine check—instruction          | Set to 1  | Cleared     | Cleared                |
| Disabled MCI, no others            | Unchanged | Unchanged   | Unchanged              |
| Disabled MCI and program interrupt | Unchanged | Set to type | Cleared                |

### 10.11.6 Data Exception Address Register (DEAR)

The DEAR is a 32-bit register that contains the address of the access for which one of the following synchronous precise errors occurred: alignment error, data TLB miss, or data storage interrupt.

The contents of the DEAR can be written to a GPR using the **mfspr** instruction. The contents of a GPR can be written to the DEAR using the **mtspr** instruction.

Figure 10-16 shows the DEAR bit definitions.

| Γ | 0 |  |  | <br> | 31 |
|---|---|--|--|------|----|

### Figure 10-16. Data Exception Address Register (DEAR)

| 0:31 Address of Data Error (synchronous) | _ |      |                                     |  |
|------------------------------------------|---|------|-------------------------------------|--|
|                                          |   | 0:31 | Address of Data Error (synchronous) |  |

# **10.12 Critical Input Interrupts**

The UICCR can be programmed so that any UIC interrupt can be presented as a critical interrupt input to the processor core. See "UIC Trigger Register (UIC0\_TR)" on page 10-13 for details. Critical interrupts are recognized only if enabled by MSR[CE].

MSR[CE] also enables the watchdog timer first-time-out interrupt. However, the watchdog interrupt has a different interrupt vector than the critical pin interrupt. See "Watchdog Timer Interrupt" on page 10-43.

After detecting a critical interrupt, if no synchronous precise interrupts are outstanding, the PPC405GP immediately takes the critical interrupt and writes the address of the next instruction to be executed in SRR2. Simultaneously, the contents of the MSR are saved in SRR3. MSR[CE] is reset to 0 to prevent another critical interrupt or the watchdog timer first time-out interrupt from interrupting the critical interrupt handler before SRR2 and SRR3 get saved. MSR[DE] is reset to 0 to disable debug interrupts during the critical interrupt handler.

The MSR is also written with the values shown in Table 10-7, "Register Settings during Critical Input Interrupts," on page 10-35. The high-order 16 bits of the program counter are then loaded with the contents of the EVPR and the low-order 16 bits of the program counter are loaded with 0x0100. Interrupt processing begins at the address in the program counter.

Inside the interrupt handling routine, after the contents of SRR2/SRR3 are saved, critical interrupts can be enabled again by setting MSR[CE] = 1.

Executing an **rfci** instruction restores the program counter from SRR2 and the MSR from SRR3, and execution resumes at the address in the program counter.

| SRR2 | Written with the address of the next instruction to be executed |
|------|-----------------------------------------------------------------|
| SRR3 | Written with the contents of the MSR                            |
| MSR  | WE, CE, EE, PR, DWE, DE,IR, DR←0<br>ME← unchanged               |
| PC   | EVPR[0:15]    0x0100                                            |

Table 10-7. Register Settings during Critical Input Interrupts

# **10.13 Machine Check Interrupts**

When an external bus error occurs on an instruction fetch, and execution of that instruction is subsequently attempted, a machine check—instruction interrupt occurs.

When an external bus error occurs while attempting data accesses, a machine check—data interrupt occurs.

When an instruction-side machine check interrupt occurs, the PPC405GP stores the address of the excepting instruction in SRR2. When a data-side machine check occurs, the PPC405GP stores the address of the next sequential instruction in SRR2. Simultaneously, for all machine check interrupts, the contents of the MSR are loaded into SRR3.

The MSR Machine Check Enable bit (MSR[ME]) is reset to 0 to disable another machine check from interrupting the machine check interrupt handling routine. The other MSR bits are loaded with the values shown in Table 10-8, "Register Settings during Machine Check—Instruction Interrupts," on page 10-36 and Table 10-9, "Register Settings during Machine Check—Data Interrupts," on page 10-36. The high-order 16 bits of the program counter are then written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x0200. Interrupt processing begins at the new address in the program counter.

Executing an **rfci** instruction restores the program counter from SRR2 and the MSR from SRR3, and execution resumes at the address in the program counter.

### **10.13.1 Instruction Machine Check Handling**

When a machine check occurs on an instruction fetch, *and execution of that instruction is subsequently attempted*, a machine check—instruction interrupt occurs. If enabled by MSR[ME], the processor reports the machine check—instruction interrupt by vectoring to the machine check handler (EVPR[0:15] II 0x0200), setting ESR[MCI]. Note that only a bus error can cause a machine check—instruction interrupt. Taking the vector automatically clears MSR[ME] and the other MSR fields.

Note that it is improper to declare a machine check—instruction interrupt when the instruction is fetched, because the address is possibly the result of an incorrect speculation by the fetcher. It is quite likely that no attempt will be made to execute an instruction from the erroneous address. The interrupt will occur only if execution of the instruction is subsequently attempted.

When a machine check occurs on an instruction fetch, the erroneous instruction is never validated in the instruction cache unit (ICU). Fetch requests to cachable memory that miss in the ICU cause an instruction cache line fill (eight words). If any words in the fetched line are associated with an error, an

interrupt occurs upon attempted execution and the cache line is invalidated. If any word in the line is in error, the cache line is invalidated after the line fill.

ESR[MCI] is set, even if MSR[ME] = 0. This means that if a machine check—instruction interrupt occurs while running in code in which MSR[ME] is disabled, the machine check—instruction interrupt is recorded in the ESR, but no interrupt occurs. Software running with MSR[ME] disabled can sample ESR[MCI] to determine whether at least one machine check—instruction interrupt occurred during the disabled execution.

If a new machine check—instruction interrupt occurs after MSR[ME] is enabled again, the new machine check—instruction interrupt is recorded in ESR[MCI] and the machine check—instruction interrupt handler is invoked. However, enabling MSR[ME] again does *not* cause a machine Check interrupt to occur simply due to the presence of ESR[MCI] indicating that a machine check—instruction interrupt occurred while MSR[ME] was disabled. The machine check—instruction interrupt must occur while MSR[ME] is enabled for the machine check interrupt to be taken. Software should, in general, clear the ESR bits before returning from a machine check interrupt to avoid any ambiguity when handling subsequent machine check interrupts.

| SRR2                                      | Written with the address that caused the machine check. |
|-------------------------------------------|---------------------------------------------------------|
| SRR3 Written with the contents of the MSR |                                                         |
| MSR                                       | WE, CE, EE, PR, ME, DWE, DE,IR, DR←0                    |
| PC                                        | EVPR[0:15]    0x0200                                    |
| ESR                                       | $MCI \leftarrow 1$<br>All other bits are cleared.       |

| Table 10-8. | Register Settings | s during Machine | e Check—Instruction | Interrupts |
|-------------|-------------------|------------------|---------------------|------------|
|             |                   |                  |                     |            |

### 10.13.2 Data Machine Check Handling

When a machine check occurs on an data access, a machine check—data interrupt occurs. To determine the cause of a machine check, examine the various error reporting registers of the external PLB slaves.

| Table 10-9. | Register Settings during | Machine Check—Data Interrupts |
|-------------|--------------------------|-------------------------------|
|-------------|--------------------------|-------------------------------|

| SRR2 | Written with the address of the next sequential instruction. |  |
|------|--------------------------------------------------------------|--|
| SRR3 | Written with the contents of the MSR                         |  |
| MSR  | WE, CE, EE, PR, ME, DWE, DE, IR, DR←0                        |  |
| PC   | EVPR[0:15]    0x0200                                         |  |

## 10.14 Data Storage Interrupt

The data storage interrupt occurs when the desired access to the effective address is not permitted for any of the following reasons:

• A U0 fault: any store to an EA with the U0 storage attribute set and CCR0[U0XE] = 1

- In the problem state with data translation enabled:
  - A zone fault, which is any user-mode storage access (data load, store, icbi, dcbz, dcbst, or dcbf) with an effective address with (ZPR field) = 00. (dcbt and dcbtst will no-op in this situation, rather than cause an interrupt. The instructions dcbi, dccci, icbt, and iccci, being privileged, cannot cause zone fault data storage interrupts.)
  - Data store or dcbz to an effective address with the WR bit clear and (ZPR field) ≠ 11. (The privileged instructions dcbi and dccci are treated as "stores," but will cause privileged program interrupts, rather than data storage interrupts.)
- · In the supervisor state with data translation enabled:
  - Data store, dcbi, dcbz, or dccci to an effective address with the WR bit clear and (ZPR field) other than 11 or 10.

**Programming Note:** The **icbi**, **icbt**, and **iccci** instructions are treated as loads from the addressed byte with respect to address translation and protection. Instruction cache operations use MSR[DR], not MSR[IR], to determine translation of their operands. Instruction storage interrupts and Instruction-side TLB Miss Interrupts are associated with the *fetching* of instructions, not with the execution of instructions. Data storage interrupts and data TLB miss interrupts are associated with the *execution* of instruction cache operations.

When a data storage interrupt is detected, the PPC405GP suppresses the instruction causing the interrupt and writes the instruction address in SRR0. The Data Exception Address Register (DEAR) is loaded with the data address that caused the access violation. ESR bits are loaded as shown in Table 10-10, "Register Settings during Data Storage Interrupts," on page 10-37 to provide further information about the error. The current contents of the MSR are loaded into SRR1, and MSR bits are then loaded with the values shown in Table 10-10.

The high-order 16 bits of the program counter are then loaded with the contents of the EVPR and the low-order 16 bits of the program counter are loaded with 0x0300. Interrupt processing begins at the new address in the program counter. Executing the return from interrupt instruction (**rfi**) restores the contents of the program counter and the MSR from SRR0 and SRR1, respectively, and the PPC405GP resumes execution at the new program counter address.

For instructions that can simultaneously generate program interrupts (privileged instructions executed in Problem State) and data storage interrupts, the program interrupt has priority.

| SRR0 | Written with the EA of the instruction causing the data storage interrupt                                                                                                                                                                                                                                                                                                               |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRR1 | Written with the value of the MSR at the time of the interrupt                                                                                                                                                                                                                                                                                                                          |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged                                                                                                                                                                                                                                                                                                             |
| PC   | EVPR[0:15]    0x0300                                                                                                                                                                                                                                                                                                                                                                    |
| DEAR | Written with the EA of the failed access                                                                                                                                                                                                                                                                                                                                                |
| ESR  | $DST \leftarrow 1$ if excepting operation is a store (includes <b>dcbi</b> and <b>dcbz</b> )<br>$DIZ \leftarrow 1$ if access failure caused by a zone protection fault (ZPR[Zn] = 00 in<br>user mode)<br>$UOF \leftarrow 1$ if access failure caused by a U0 fault (the U0 storage attribute is<br>set and CCR0[U0XE] = 1)<br>$MCI \leftarrow$ unchanged<br>All other bits are cleared. |

Table 10-10. Register Settings during Data Storage Interrupts

# **10.15 Instruction Storage Interrupt**

The instruction storage interrupt is generated when instruction translation is active and execution is attempted for an instruction whose fetch access to the effective address is not permitted for any of the following reasons:

- In Problem State:
  - Instruction fetch from an effective address with (ZPR field) = 00.
  - Instruction fetch from an effective address with the EX bit clear and (ZPR field)  $\neq$  11.
  - Instruction fetch from an effective address contained within a Guarded region (G=1).
- In Supervisor State:
  - Instruction fetch from an effective address with the EX bit clear and (ZPR field) other than 11 or 10.
  - Instruction fetch from an effective address contained within a Guarded region (G=1).

SRR0 will save the address of the instruction causing the instruction storage interrupt.

ESR is set to indicate the following conditions:

- If ESR[DIZ] = 1, the excepting condition was a zone fault: the attempted execution of an instruction
  address fetched in user-mode with (ZPR field) = 00.
- If ESR[DIZ] = 0, then the excepting condition was either EX = 0 or G = 1.

The interrupt is precise with respect to the attempted execution of the instruction. Program flow vectors to EVPR[0:15] || 0x0400.

The following registers are modified to the specified values:

| SRR0 | Set to the EA of the instruction for which execute access was not permitted                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| SRR1 | Set to the value of the MSR at the time of the interrupt                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| PC   | EVPR[0:15]    0x0400                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| ESR  | $DIZ \leftarrow 1If$ access failure due to a zone protection fault (ZPR[Zn] = 00 in user<br>mode)<br><b>Note:</b> If ESR[DIZ] is not set, the interrupt occurred because TBL_entry[EX]<br>was clear in an otherwise accessible zone, or because of an instruction<br>fetch from a storage region marked as guarded. See "Exception Syndrome<br>Register (ESR)" on page 10-31 for details of ESR operation.<br>MCI $\leftarrow$ unchanged<br>All other bits are cleared. |  |  |

| Table 10-11. F | Register Settings during Instruction Storage Interrupts |  |
|----------------|---------------------------------------------------------|--|
|----------------|---------------------------------------------------------|--|

### **10.16 External Interrupt**

External interrupts (external to the processor core) are triggered by active levels for non-critical interrupts in the UIC. All external interrupting events are presented to the processor as a single external interrupt. External interrupts are enabled or disabled by MSR[EE].

**Programming Note:** MSR[EE] also enables PIT and FIT interrupts. However, after timer interrupts, control passes to different interrupt vectors than for the interrupts discussed in the preceding paragraph. Therefore, these timer interrupts are described in "Programmable Interval Timer (PIT) Interrupt" on page 10-41 and "Fixed Interval Timer (FIT) Interrupt" on page 10-42.

### 10.16.1 External Interrupt Handling

When MSR[EE] = 1 (external interrupts are enabled), a noncritical external interrupt occurs, and this interrupt is the highest priority interrupt condition, the processor immediately writes the address of the next sequential instruction into SRR0. Simultaneously, the contents of the MSR are saved in SRR1.

When the processor takes a noncritical external interrupt, MSR[EE] is set to 0. This disables other external interrupts from interrupting the interrupt handler before SRR0 and SRR1 are saved. The MSR is also written with the other values shown in Table 10-12, "Register Settings during External Interrupts," on page 10-39. The high-order 16 bits of the program counter are written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x0500. Interrupt processing begins at the address in the program counter.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter.

| SRR0 | Written with the address of the next sequential instruction |  |
|------|-------------------------------------------------------------|--|
| SRR1 | Written with the contents of the MSR                        |  |
| MSR  | WE, EE, PR, DWE, IR, DR ← 0<br>CE, ME, DE ← unchanged       |  |
| PC   | EVPR[0:15]    0x0500                                        |  |

Table 10-12. Register Settings during External Interrupts

## **10.17 Alignment Interrupt**

Alignment interrupts are caused by **dcbz** instructions to non-cachable or write-through storage and. Table 10-13 summarizes the instructions and conditions causing alignment interrupts.

| Instructions Causing Alignment<br>Interrupts | Conditions                                  |  |
|----------------------------------------------|---------------------------------------------|--|
| dcbz                                         | EA in non-cachable or write-through storage |  |
| dcread, Iwarx, stwcx.                        | EA not word-aligned                         |  |

Execution of an instruction causing an alignment interrupt is prohibited from completing. SRR0 is written with the address of that instruction and the current contents of the MSR are saved into SRR1. The DEAR is written with the address that caused the alignment error. The MSR bits are written with the values shown in Table 10-14, "Register Settings during Alignment Interrupts," on page 10-40. The high-order 16 bits of the program counter are written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x0600. Interrupt processing begins at the new address in the program counter.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter

Alignment interrupts cannot be disabled. To avoid overwrites of SRR0 and SRR1 by alignment interrupts that occur within a handler, interrupt handlers should save these registers as soon as possible.

| SRR0 | Written with the address of the instruction causing the alignment interrupt |  |  |
|------|-----------------------------------------------------------------------------|--|--|
| SRR1 | Written with the contents of the MSR                                        |  |  |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged |  |  |
| PC   | EVPR[0:15]    0x0600                                                        |  |  |
| DEAR | Written with the address that caused the alignment violation                |  |  |

Table 10-14. Register Settings during Alignment Interrupts

### **10.18 Program Interrupt**

Program interrupts are caused by attempting to execute:

- An illegal instruction
- · A privileged instruction while in the problem state
- Executing a trap instruction with conditions satisfied

The ESR bits that differentiate these situations are listed and described in Table 10-15. When a program interrupt occurs, the appropriate bit is set and the others are cleared. These interrupts are not maskable.

| Bits     | Interrupts             | Cause                                                        |  |
|----------|------------------------|--------------------------------------------------------------|--|
| ESR[PIL] | Illegal instruction    | Opcode not recognized                                        |  |
| ESR[PPR] | Privileged instruction | Attempt to use a privileged instruction in the problem state |  |
| ESR[PTR] | Trap                   | Excepting instruction is a trap                              |  |

Table 10-15. ESR Usage for Program Interrupts

The program interrupt handler does not need to reset the ESR.

When one of the following occurs, the PPC405GP does not execute the instruction, but writes the address of the excepting instruction into SRR0:

- Attempted execution of a privileged instruction in problem state
- Attempted execution of an illegal instruction (including memory management instructions when memory management is disabled

Trap instructions can be used as a program interrupt or a debug event, or both (see "Debug Events" on page 12-16 for information about debug events). When a trap instruction is detected as a program interrupt, the PPC405GP writes the address of the trap instruction into SRR0. See **tw** on page 24-190 and **twi** on page 24-193 (both in Chapter 24, "Instruction Set") for a detailed discussion of the behavior of trap instructions with various interrupts enabled.

After any program interrupt, the contents of the MSR are written into SRR1 and the MSR bits are written with the values shown in Table 10-16. The high-order 16 bits of the program counter are written with the contents of the EVPR; the low-order 16 bits of the program counter are written with 0x0700. Interrupt processing begins at the new address in the program counter.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter.

| SRR0 | Written with the address of the excepting instruction                                                                |  |
|------|----------------------------------------------------------------------------------------------------------------------|--|
| SRR1 | Written with the contents of the MSR                                                                                 |  |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0 . CE, ME, DE $\leftarrow$ unchanged                                           |  |
| PC   | EVPR[0:15] II 0x0700                                                                                                 |  |
| ESR  | Written with the type of program interrupt. (See Table 10-15) MCI $\leftarrow$ unchanged All other bits are cleared. |  |

Table 10-16. Register Settings during Program Interrupts

## 10.19 System Call Interrupt

System call interrupts occur when a **sc** instruction is executed. The PPC405GP writes the address of the instruction following the **sc** into SRR0. The contents of the MSR are written into SRR1 and the MSR bits are written with the values shown in Table 10-17. The high-order 16 bits of the program counter are then written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x0C00. Interrupt processing begins at the new address in the program counter.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter.

| SRR0 | Written with the address of the instruction following the sc instruction             |  |
|------|--------------------------------------------------------------------------------------|--|
| SRR1 | Written with the contents of the MSR                                                 |  |
| MSR  | AP, APE, WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged |  |
| PC   | EVPR[0:15] II 0x0C00                                                                 |  |

 Table 10-17. Register Settings during System Call Interrupts

# 10.20 Programmable Interval Timer (PIT) Interrupt

For a discussion of the PPC405GP timer facilities, see Chapter 11, "Timer Facilities." The PIT is described in "Programmable Interval Timer (PIT)" on page 11-4.

If the PIT interrupt is enabled by TCR[PIE] and MSR[EE], the PPC405GP initiates a PIT interrupt after detecting a time-out from the PIT. Time-out is detected when, at the beginning of a clock cycle, TSR[PIS] = 1. (This occurs on the cycle after the PIT decrements on a PIT count of 1.) The PPC405GP immediately takes the interrupt. The address of the next sequential instruction is saved in SRR0; simultaneously, the contents of the MSR are written into SRR1 and the MSR is written with the values shown in Table 10-18. The high-order 16 bits of the program counter are then written with the

contents of the EVPR and the low-order 16 bits of the program counter are written with 0x1000. Interrupt processing begins at the address in the program counter.

To clear a PIT interrupt, the interrupt handling routine must clear the PIT interrupt bit, TSR[PIS]. Clearing is performed by writing a word to TSR, using an **mtspr** instruction, that has 1 in bit positions to be cleared and 0 in all other bit positions. The data written to the TSR is not direct data, but a mask; a 1 clears the bit and 0 has no effect.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter.

| SRR0 | Written with the address of the next instruction to be executed             |  |  |
|------|-----------------------------------------------------------------------------|--|--|
| SRR1 | Written with the contents of the MSR                                        |  |  |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged |  |  |
| PC   | EVPR[0:15] II 0x1000                                                        |  |  |
| TSR  | PIS ← 1                                                                     |  |  |

Table 10-18. Register Settings during Programmable Interval Timer Interrupts

# 10.21 Fixed Interval Timer (FIT) Interrupt

For a discussion of the PPC405GP timer facilities, see Chapter 11, "Timer Facilities." The FIT is described in "Fixed Interval Timer (FIT) Interrupt" on page 10-42.

If the FIT interrupt is enabled by TCR[FIE] and MSR[EE], the PPC405GP initiates a FIT interrupt after detecting a time-out from the FIT. Time-out is detected when, at the beginning of a clock cycle, TSR[FIS] = 1. (This occurs on the second cycle after the  $0 \rightarrow 1$  transition of the appropriate time-base bit.) The PPC405GP immediately takes the interrupt. The address of the next sequential instruction is written into SRR0; simultaneously, the contents of the MSR are written into SRR1 and the MSR is written with the values shown in Table 10-19. The high-order 16 bits of the program counter are then written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x1010. Interrupt processing begins at the address in the program counter.

To clear a FIT interrupt, the interrupt handling routine must clear the FIT interrupt bit, TSR[FIS]. Clearing is performed by writing a word to TSR, using an **mtspr** instruction, that has 1 in any bit positions to be cleared and 0 in all other bit positions. The data written to the TSR is not direct data, but a mask; a 1 clears a bit and 0 has no effect.

Executing an **rfi** instruction restores the program counter from SRR0 and the MSR from SRR1, and execution resumes at the address in the program counter.

| SRR0 | Written with the address of the next sequential instruction                 |   |
|------|-----------------------------------------------------------------------------|---|
| SRR1 | Written with the contents of the MSR                                        |   |
| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged |   |
| PC   | EVPR[0:15] II 0x1010                                                        | - |
| TSR  | FIS ← 1                                                                     |   |

Table 10-19. Register Settings during Fixed Interval Timer Interrupts

## **10.22 Watchdog Timer Interrupt**

For a general description of the PPC405GP timer facilities, see Chapter 11, "Timer Facilities." The watchdog timer (WDT) is described in "Watchdog Timer" on page 11-6.

If the WDT interrupt is enabled by TCR[WIE] and MSR[CE], the PPC405GP initiates a WDT interrupt after detecting the first WDT time-out. First time-out is detected when, at the beginning of a clock cycle, TSR[WIS] = 1. (This occurs on the second cycle after the  $0\rightarrow$ 1 transition of the appropriate time-base bit while TSR[ENW] = 1 and TSR[WIS] = 0.) The PPC405GP immediately takes the interrupt. The address of the next sequential instruction is saved in SRR2; simultaneously, the contents of the MSR are written into SRR3 and the MSR is written with the values shown in Table 10-20. The high-order 16 bits of the program counter are then written with the contents of the EVPR and the low-order 16 bits of the program counter are written with 0x1020. Interrupt processing begins at the address in the program counter.

To clear the WDT interrupt, the interrupt handling routine must clear the WDT interrupt bit TSR[WIS]. Clearing is done by writing a word to TSR (using **mtspr**), with a 1 in any bit position that is to be cleared and 0 in all other bit positions. The data written to the status register is not direct data, but a mask; a 1 causes the bit to be cleared, and a 0 has no effect.

Executing the return from critical interrupt instruction (**rfci**) restores the contents of the program counter and the MSR from SRR2 and SRR3, respectively, and the PPC405GP resumes execution at the contents of the program counter.

| SRR2 | Written with the address of the next sequential instruction                 |  |
|------|-----------------------------------------------------------------------------|--|
| SRR3 | Written with the contents of the MSR                                        |  |
| MSR  | WE, CE, EE, PR, DE, DWE, IR, DR $\leftarrow$ 0<br>ME $\leftarrow$ unchanged |  |
| PC   | EVPR[0:15]    0x1020                                                        |  |
| TSR  | WIS ← 1                                                                     |  |

#### Table 10-20. Register Settings during Watchdog Timer Interrupts

### **10.23 Data TLB Miss Interrupt**

The data TLB miss interrupt is generated if data translation is enabled and a valid TLB entry matching the EA and PID is not present. The address of the instruction generating the untranslatable effective data address is saved in SRR0. In addition, the hardware also saves the data address (that missed in the TLB) in the DEAR.

The ESR is set to indicate whether the excepting operation was a store (includes dcbz, dcbi, dccci).

The interrupt is precise. Program flow vectors to EVPR[0:15] || 0x1100.

The following registers are modified to the values specified in Table 10-21.

| SRR0 | Set to the address of the instruction generating the effective address for which no valid translation exists. |
|------|---------------------------------------------------------------------------------------------------------------|
| SRR1 | Set to the value of the MSR at the time of the interrupt                                                      |

 Table 10-21. Register Settings during Data TLB Miss Interrupts

| MSR  | WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged                                                                                   |  |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PC   | EVPR[0:15]    0x1100                                                                                                                                          |  |  |
| DEAR | Set to the effective address of the failed access                                                                                                             |  |  |
| ESR  | $DST \leftarrow 1$ if excepting operation is a store operation (includes dcbi, dcbz, and dccci).<br>MCI $\leftarrow$ unchanged<br>All other bits are cleared. |  |  |

Table 10-21. Register Settings during Data TLB Miss Interrupts (continued)

**Programming Note:** Data TLB miss interrupts can happen whenever data translation is enabled. Therefore, ensure that SRR0 and SRR1 are saved before enabling translation in an interrupt handler.

# **10.24 Instruction TLB Miss Interrupt**

The instruction TLB miss interrupt is generated if instruction translation is enabled and execution is attempted for an instruction for which a valid TLB entry matching the EA and PID for the instruction fetch is not present. The instruction whose fetch caused the TLB miss is saved in SRR0.

The interrupt is precise with respect to the attempted execution of the instruction. Program flow vectors to EVPR[0:15 || 0x1200.

The following are modified to the values specified in Table 10-22

|      | ÷ • • •                                                                              |
|------|--------------------------------------------------------------------------------------|
| SRR0 | Set to the address of the instruction for which no valid translation exists.         |
| SRR1 | Set to the value of the MSR at the time of the interrupt                             |
| MSR  | AP, APE, WE, EE, PR, DWE, IR, DR $\leftarrow$ 0<br>CE, ME, DE $\leftarrow$ unchanged |
| PC   | EVPR[0:15]    0x1200                                                                 |

| Table 10-22. | <b>Register Setting</b> | s during Instruction | TLB Miss Interrupts |
|--------------|-------------------------|----------------------|---------------------|
|--------------|-------------------------|----------------------|---------------------|

**Programming Note:** Instruction TLB miss interrupts can happen whenever instruction translation is active. Therefore, insure that SRR0 and SRR1 are saved before enabling translation in an interrupt handler.

# 10.25 Debug Interrupt

Debug interrupts can be either *synchronous* or *asynchronous*. These debug events generate synchronous interrupts: branch taken (BT), data address compare (DAC), data value compare (DVC), instruction address compare (IAC), instruction completion (IC), and trap instruction (TIE). The exception (EXC) and unconditional (UDE) debug events generate asynchronous interrupts. See "Debug Events" on page 12-16 for more information about debug events.

For debug events, SRR2 is written with an address, which varies with the type of debug event, as shown in Table 10-23.

| Debug Event | Address Saved in SRR2                                                                   |
|-------------|-----------------------------------------------------------------------------------------|
| BT<br>DAC   | Address of the instruction causing the event                                            |
| IAC         |                                                                                         |
| DVC<br>IC   | Address of the instruction following the instruction that causing the event             |
| EXC         | Interrupt vector address of the initial exception that caused the exception debug event |
| UDE         | Address of next instruction to be executed at time of UDE                               |

Table 10-23. SRR2 during Debug Interrupts

SRR3 is written with the contents of the MSR and the MSR is written with the values shown in Table 10-24, "Register Settings during Debug Interrupts," on page 10-45. The high-order 16 bits of the program counter are then written with the contents of the EVPR; the low-order 16 bits of the program counter are written with 0x2000. Interrupt processing begins at the address in the program counter.

Executing an **rfci** instruction restores the program counter from SRR2 and the MSR from SRR3, and execution resumes at the address in the program counter.

| SRR2 | Written with an address as described in Table 10-23                         |  |
|------|-----------------------------------------------------------------------------|--|
| SRR3 | Written with the contents of the MSR                                        |  |
| MSR  | WE, CE, EE, PR, DE, DWE, IR, DR $\leftarrow$ 0<br>ME $\leftarrow$ unchanged |  |
| PC   | EVPR[0:15] II 0x2000                                                        |  |
| DBSR | Set to indicate type of debug event.                                        |  |

 Table 10-24. Register Settings during Debug Interrupts

10-46 PPC405GP User's Manual

# **Chapter 11. Timer Facilities**

The PPC405GP provides four timer facilities: a time base, a Programmable Interval Timer (PIT), a fixed interval timer (FIT), and a watchdog timer. The PIT is a Special Purpose Register (SPR). These facilities, which are driven by the same base clock, can, among other things, be used for:

- · Time-of-day functions
- Data logging functions
- Peripherals requiring periodic service
- Periodic task switching

Additionally, the watchdog timer can help a system to recover from faulty hardware or software.

Figure 11-1 shows the relationship of the timers and the clock source to the time base.





### 11.1 Time Base

The PPC405GP implements a 64-bit time base as required in *The PowerPC Architecture*. The time base, which increments once during each period of the source clock, provides a time reference. The source clock is either the CPU clock or an external clock connected to the TmrClk input. The CETE field of Chip Control Register 1 (CPC0\_CR1[CETE]) selects the clock source.

Read access to the time base is through the **mftb** instruction. **mftb** provides user-mode read-only access to the time base. The TBR numbers (0x10C and 0x10D; TBL and TBU, respectively) that specify the time base registers to **mftb** are not SPR numbers. However, the PowerPC Architecture allows an implementation to handle **mftb** as **mfspr**. Accordingly, these register numbers cannot be used for other SPRs. PowerPC compilers cannot use **mftb** with register numbers other than those specified in the PowerPC Architecture as read-access time base registers (0x10C and 0x10D).

Write access to the time base, using **mtspr**, is privileged. Different register numbers are used for read access and write access. Writing the time base is accomplished by using SPR 0x11C and SPR 0x11D (TBL and TBU, respectively) as operands for **mtspr**.

The period of the 64-bit time base is approximately 2925 years for a 200 MHz clock source. The time base does not generate interrupts, even when it wraps. For most applications, the time base is set once at system reset and only read thereafter. Note that the FIT and the watchdog timer (discussed below) are driven by  $0 \rightarrow 1$  transitions of bits from the TBL. Transitions caused by software alteration of TBL have the same effect as transitions caused by normal incrementing of the time base.

Figure 11-2 illustrates the TBL.

|   | 01  |
|---|-----|
|   | 311 |
| 5 | 01  |

| Figure 11-2. | Time Base Low | er (TBL) |
|--------------|---------------|----------|
|--------------|---------------|----------|

| 0:31 | <br>Time Base Lower | Current count; low-order 32 bits of time |
|------|---------------------|------------------------------------------|
|      |                     | base.                                    |

Figure 11-3 illustrates the TBU.

0 31

#### Figure 11-3. Time Base Upper (TBU)

| 0:31 | Time Base Upper | Current count, high-order 32 bits of time |
|------|-----------------|-------------------------------------------|
|      |                 | base.                                     |

Table 11-1 summarizes the TBRs, instructions used to access the TBRs, and access restrictions.

| Table | 11-1. | Time | Base | Access |
|-------|-------|------|------|--------|
|-------|-------|------|------|--------|

|              | Instructions                                      | Register<br>Number | Access Restrictions    |
|--------------|---------------------------------------------------|--------------------|------------------------|
| TBU<br>Upper | mftbu RT<br>Extended mnemonic for<br>mftb RT,TBU  | 0x10D              | Read-only              |
| 32 bits      | mttbu RS<br>Extended mnemonic for<br>mtspr TBU,RS | 0x11D              | Privileged; write-only |
| TBL          | mftb RT<br>Extended mnemonic for<br>mftb RT,TBL   | 0x10C              | Read-only              |
| 32 bits      | mttbl<br>Extended mnemonic for<br>mtspr TBL,RS    | 0x11C              | Privileged; write-only |

### 11.1.1 Reading the Time Base

The following code provides an example of reading the time base. **mftb** moves the low-order 32 bits of the time base to a GPR; **mftbu** moves the high-order 32 bits of the time base to a second GPR.

loop:

| mftbu Rx    | # load from TBU                    |
|-------------|------------------------------------|
| mftb Ry     | # load from TBL                    |
| mftbu Rz    | # load from TBU                    |
| cmpw Rz, Rx | # see if old = new                 |
| bne loop    | # loop/reread if rollover occurred |

The comparison and loop ensure that a consistent pair of values is obtained.

### 11.1.2 Writing the Time Base

The following code provides an example of writing the time base. Writing the time base is privileged. **mttbl** moves the contents of a GPR to the low-order 32 bits of the time base; **mttbu** moves the contents of a second GPR to the high-order 32 bits of the time base.

| lwz   | Rx, upper | # load 64-bit time base value into Rx and Ry         |
|-------|-----------|------------------------------------------------------|
| lwz   | Ry, lower |                                                      |
| li    | Rz, 0     | ,                                                    |
| mttbl | Rz        | # force TBL to 0 to avoid rollover while writing TBU |
| mttbu | Rx        | # set TBU                                            |
| mttbl | Ry        | # set TBL                                            |
|       |           |                                                      |

# **11.2 Programmable Interval Timer (PIT)**

The PIT is a 32-bit SPR that decrements at the same rate as the time base. The PIT is read and written using **mfspr** and **mtspr**, respectively. Writing to the PIT also simultaneously writes to a hidden reload register. Reading the PIT using **mfspr** returns the current PIT contents; the hidden reload register cannot be read. When a non-zero value is written to the PIT, it begins to decrement. A PIT event occurs when a decrement occurs on a PIT count of 1. When a PIT event occurs, the following occurs:

1. If the PIT is in auto-reload mode (the ARE field of the Timer Control Register (TCR) is 1), the PIT is loaded with the last value an **mtspr** wrote to the PIT. A decrement from a PIT count of 1 immediately causes a reload; no intermediate PIT content of 0 occurs.

If the PIT is not in auto-reload mode (TCR[ARE] = 0), a decrement from a PIT count of 1 simply causes a PIT content of 0.

- 2. TSR[PIS] is set to 1.
- 3. If enabled (TCR[PIE] = 1 and the EE field of the Machine State Register (MSR) is 1), a PIT interrupt is taken. See "Programmable Interval Timer (PIT) Interrupt" on page 10-41 for details of register behavior during a PIT interrupt.

The interrupt handler should use software to reset the PIS field of the Timer Status Register (TSR). This is done by using **mtspr** to write a word to the TSR having a 1 in TSR[PIS] and any other bits to be cleared, and a 0 in all other bits. The data written to the TSR is not direct data, but a mask. A 1 clears a bit; a 0 has no effect.

Using **mtspr** to force the PIT to 0 *does not* cause a PIT interrupt. However, decrementing that was ongoing at the instant of the **mtspr** instruction can cause the appearance of an interrupt. To eliminate the PIT as a source of interrupts, write a 0 to TCR[PIE], the PIT interrupt enable bit.

To eliminate all PIT activity:

- 1. Write a 0 to TCR[PIE]. This prevents PIT activity from causing interrupts.
- 2. Write a 0 to TCR[ARE]. This disables the PIT auto-reload feature.
- 3. Write zeroes to the PIT to halt PIT decrementing. Although this action does not cause a pit PIT interrupt to become pending, a near-simultaneous decrement to 0 might have done so.
- 4. Write a 1 to TSR[PIS] (PIT Interrupt Status bit). This clears TSR[PIS] to 0 (see "Timer Status Register (TSR)" on page 11-8). This also clears any pending PIT interrupt. Because the PIT stops decrementing, no further PIT events are possible.

If the auto-reload feature is disabled (TCR[ARE] = 0) when the PIT decrements to 0, the PIT remains 0 until software uses **mtspr** to reload it.

After a reset, TCR[ARE] = 0, which disables the auto-reload feature.

| Figure 11-4. Programmable Interval Timer (PIT | Figure 11-4 | . Program | mable Interva | Timer ( | (PIT) |
|-----------------------------------------------|-------------|-----------|---------------|---------|-------|
|-----------------------------------------------|-------------|-----------|---------------|---------|-------|

| 0:: | 31 | Programmed interval remaining | Number of clocks remaining until the PIT event |
|-----|----|-------------------------------|------------------------------------------------|
|     | 1  |                               |                                                |

### 11.2.1 Fixed Interval Timer (FIT)

The FIT provides timer interrupts having a repeatable period. The FIT is functionally similar to an auto-reload PIT, except that only a smaller fixed selection of interrupt periods are available.

The FIT exception occurs on  $0 \rightarrow 1$  transitions of selected bits from the time base, as shown in Table 11-2.

| TCR[FP] | TBL Bit | Period<br>(Time Base Clocks) | Period<br>(200 Mhz Clock) |
|---------|---------|------------------------------|---------------------------|
| 0, 0    | .23     | 2 <sup>9</sup> clocks        | 2.56 µsec                 |
| 0, 1    | 19      | 2 <sup>13</sup> clocks       | 40.96 µsec                |
| 1, 0    | 15      | 2 <sup>17</sup> clocks       | 0.655 msec                |
| 1, 1    | 11      | 2 <sup>21</sup> clocks       | 10.49 msec                |

Table 11-2. FIT Controls

The TSR[FIS] field logs a FIT exception as a pending interrupt. A FIT interrupt occurs if TCR[FIE] and MSR[EE] are enabled at the time of the FIT exception. "Fixed Interval Timer (FIT) Interrupt" on page 10-42 describes register settings during a FIT interrupt.

The interrupt handler should reset TSR[FIS]. This is done by using **mtspr** to write a word to the TSR having a 1 in TSR[FIS] and any other bits to be cleared, and a 0 in all other bits. The data written to the TSR is not direct data, but a mask. A 1 clears a bit and a 0 has no effect.

## 11.3 Watchdog Timer

The watchdog timer aids system recovery from software or hardware faults.

A watchdog timeout occurs on  $0 \rightarrow 1$  transitions of a selected bit from the time base, as shown in the following table.

| TCR[WP] | TBL Bit | Period<br>(Time Base Clocks) | Period<br>(200 MHz Clock) |
|---------|---------|------------------------------|---------------------------|
| 0,0     | 15      | 2 <sup>17</sup> clocks       | 0.655 msec                |
| 0,1     | 11      | 2 <sup>21</sup> clocks       | 10.49 msec                |
| 1,0     | 7       | 2 <sup>25</sup> clocks       | 0.168 sec                 |
| 1,1     | 3       | 2 <sup>29</sup> clocks       | 2.684 sec                 |

Table 11-3. Watchdog Timer Controls

If a watchdog timeout occurs while TSR[WIS] = 0 and TSR[ENW] = 1, a watchdog interrupt occurs if the interrupt is enabled by TCR[WIE] and MSR[CE]. "Watchdog Timer" on page 11-6 describes register behavior during a watchdog interrupt.

The interrupt handler should reset the TSR[WIS] bit. This is done by using **mtspr** to write a word to the TSR having a 1 in TSR[WIS] and any other bits to be cleared, and a 0 in all other bits. The data written to the TSR is not direct data, but a mask. A 1 clears a bit and a 0 has no effect.

If a watchdog timeout occurs while TSR[WIS] = 1 and TSR[ENW] = 1, a hardware reset occurs if enabled by a non-zero value of TCR[WRC]. In other words, a reset can occur if a watchdog timeout occurs while a previous watchdog timeout is pending. The assumption is that TSR[WIS] was not cleared because the processor could not execute the watchdog handler, leaving reset as the only way to restart the system. Note that after TCR[WRC] is set to a non-zero value, it cannot be reset by software. This prevents errant software from disabling the watchdog timer reset capability. After a reset, the initial value of TCR[WRC] = 00. Figure 11-5 describes the watchdog state machine. In the figure, numbers in parentheses refer to descriptions of operating modes that follow the table.





| Enable Next<br>Watchdog<br>TSR[ENW] | Watchdog<br>Timer Status<br>TSR[WIS] | Action When Timer Interval Expires                                                                                                                            |
|-------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                   | 0                                    | Set TSR[ENW] = 1.                                                                                                                                             |
| 0                                   | 1                                    | Set TSR[ENW] = 1.                                                                                                                                             |
| 1                                   | 0                                    | Set TSR[WIS] = 1.<br>If TCR[WIE] = 1 and MSR[CE] = 1, then interrupt.                                                                                         |
| 1                                   | 1                                    | Cause the watchdog reset action specified by<br>TCR[WRC].<br>On reset, copy current TCR[WRC] to TSR[WRS] and<br>clear TCR[WRC], disabling the watchdog timer. |

The controls described in Figure 11-5 imply three different ways of using the watchdog timer. The modes assume that TCR[WRC] was set to allow processor reset by the watchdog timer:

- 1. Always take a pending watchdog interrupt, and never attempt to prevent its occurrence. (This mode is described in the preceding text.)
  - a. Clear TSR[WIS] in the watchdog timer handler.
  - b. Never use TSR[ENW].
- Always take a pending watchdog interrupt, but avoid it whenever possible by delaying a reset until a second watchdog timer occurs.

This assumes that a recurring code loop of known maximum duration exists outside the interrupt handlers, or that a FIT interrupt handler is operational. One of these mechanisms clears TSR[ENW] more frequently than the watchdog period.

a. Clear TSR[ENW] to 0 in loop or in FIT interrupt handler.

To clear TSR[ENW], use **mtspr** to write a 1 to TSR[ENW] (and to any other bits that are to be cleared), with 0 in all other bit locations.

b. Clear TSR[WIS] in watchdog timer handler.

It is not expected that a watchdog interrupt will occur every time, but only if an exceptionally high execution load delays clearing of TSR[ENW] in the usual time frame.

3. Never take a watchdog interrupt.

This assumes that a recurring code loop of reliable duration exists outside the interrupt handlers, or that a FIT interrupt handler is operational. This method only guarantees one watchdog timeout period before a reset occurs.

- a. Clear TSR[WIS] in the loop or in FIT handler.
- b. Never use TSR[ENW] but have it set.

# 11.4 Timer Status Register (TSR)

The TSR can be accessed for read or write-to-clear.

Status registers are generally set by hardware and read and cleared by software. The **mfspr** instruction reads the TSR. Clearing the TSR is performed by writing a word to the TSR, using **mtspr**, having a 1 in all fields to be cleared and a 0 in all other fields. The data written to the TSR is not direct data, but a mask. A 1 clears the field and a 0 has no effect.



|     |     | -                                                                                                                                                                                                       | 5 ( )                                                             |
|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| 0   | ENW | <ul> <li>Enable Next Watchdog</li> <li>0 Action on next watchdog event is to set<br/>TSR[ENW] = 1.</li> <li>1 Action on next watchdog event is<br/>governed by TSR[WIS].</li> </ul>                     | Software must reset TSR[ENW] = 0 after each watchdog timer event. |
| 1   | WIS | Watchdog Interrupt Status<br>0 No Watchdog interrupt is pending.<br>1 Watchdog interrupt is pending.                                                                                                    |                                                                   |
| 2:3 | WRS | Watchdog Reset Status<br>00 No Watchdog reset has occurred.<br>01 Core reset was forced by the watchdog.<br>10 Chip reset was forced by the watchdog.<br>11 System reset was forced by the<br>watchdog. |                                                                   |
| 4   | PIS | PIT Interrupt Status<br>0 No PIT interrupt is pending.<br>1 PIT interrupt is pending.                                                                                                                   |                                                                   |

Figure 11-6. Timer Status Register (TSR)

| 5    | FIS | FIT Interrupt Status<br>0 No FIT interrupt is pending.<br>1 FIT interrupt is pending. |
|------|-----|---------------------------------------------------------------------------------------|
| 6:31 |     | Reserved                                                                              |

# 11.5 Timer Control Register (TCR)

The TCR controls PIT, FIT, and watchdog timer operation.

The TCR[WRC] field is cleared to 0 by all processor resets. (Chapter 8, "Reset and Initialization," describes the types of processor reset.) This field is set only by software. However, hardware does not allow software to clear the field after it is set. After software writes a 1 to a bit in the field, that bit remains a 1 until any reset occurs. This prevents errant code from disabling the watchdog timer reset function.

All processor resets clear TCR[ARE] to 0, disabling the auto-reload feature of the PIT.



| 0:1 | WP  | Watchdog Period<br>00 2 <sup>17</sup> clocks<br>01 2 <sup>21</sup> clocks<br>10 2 <sup>25</sup> clocks<br>11 2 <sup>29</sup> clocks                                                                                                                                     |                                                                                                                                           |
|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 2:3 | WRC | <ul> <li>Watchdog Reset Control</li> <li>00 No Watchdog reset will occur.</li> <li>01 Core reset will be forced by the<br/>Watchdog.</li> <li>10 Chip reset will be forced by the<br/>Watchdog.</li> <li>11 System reset will be forced by the<br/>Watchdog.</li> </ul> | TCR[WRC] resets to 00.<br>This field can be set by software, but<br>cannot be cleared by software, except by a<br>software-induced reset. |
| 4   | WIE | Watchdog Interrupt Enable<br>0 Disable watchdog interrupt.<br>1 Enable watchdog interrupt.                                                                                                                                                                              |                                                                                                                                           |
| 5   | PIE | PIT Interrupt Enable<br>0 Disable PIT interrupt.<br>1 Enable PIT interrupt.                                                                                                                                                                                             |                                                                                                                                           |

Figure 11-7. Timer Control Register (TCR)

| 6:7   | FP  | FIT Period<br>$00 2^9$ clocks<br>$01 2^{13}$ clocks<br>$10 2^{17}$ clocks<br>$11 2^{21}$ clocks |                    |
|-------|-----|-------------------------------------------------------------------------------------------------|--------------------|
| 8     | FIE | FIT Interrupt Enable<br>0 Disable FIT interrupt.<br>1 Enable FIT interrupt.                     |                    |
| 9     | ARE | Auto Reload Enable<br>0 Disable auto reload.<br>1 Enable auto reload.                           | Disables on reset. |
| 10:31 |     | Reserved                                                                                        |                    |

# Chapter 12. Debugging

The debug facilities of the PPC405GP include support for debug modes for debugging during hardware and software development, and debug events that allow developers to control the debug process. Debug registers control the debug modes and debug events. The debug registers are accessed through software running on the processor or through a JTAG debug port. The debug interface is the JTAG debug port. The JTAG debug port can also be used for board test.

The debug modes, events, controls, and interface provide a powerful combination of debug facilities for a wide range of hardware and software development tools.

### 12.1 Development Tool Support

The RISCWatch product from IBM is an example of a development tool that uses the external debug mode, debug events, and the JTAG debug port to implement a hardware and software development tool. The RISCTrace<sup>™</sup> feature of RISCWatch is an example of a development tool that uses the real-time instruction trace capability of the PPC405GP.

### **12.2 Debug Interfaces**

The PPC405GP provides JTAG and trace interfaces to support hardware and software test and debug. Typically, the JTAG interface connects to a debug port external to the PPC405GP; the debug port is typically connected to a JTAG connector on a processor board.

The trace interface connects to a trace port, also external to the PPC405GP, that is typically connected to a trace connector on the processor board.

# 12.3 IEEE 1149.1 Test Access Port (JTAG Debug Port)

The IEEE 1149.1 Test Access Port (TAP), commonly called the JTAG (Joint Test Action Group) debug port, is an architectural standard described in IEEE Std 1149.1–1990, *IEEE Standard Test Access Port and Boundary Scan Architecture.* The standard describes a method for accessing internal chip facilities using a four- or five-signal interface.

The JTAG debug port, originally designed to support scan-based board testing, is enhanced to support the attachment of debug tools. The enhancements, which comply with the IEEE 1149.1 specifications for vendor-specific extensions, are compatible with standard JTAG hardware for boundary-scan system testing.

| JTAG Signals               | The JTAG debug port implements the four required JTAG signals: TCK, TMS, TDI, and TDO, and the optional TRST signal.                                         |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JTAG Clock<br>Requirements | The frequency of the TCK signal can range from DC to one-half of the internal chip clock frequency.                                                          |
| JTAG Reset<br>Requirements | The JTAG debug port logic is reset at the same time as a system reset.<br>Upon receiving TRST, the JTAG debug port returns to the Test-Logic<br>Reset state. |

# 12.4 JTAG Connector

A 16-pin male 2x8 header connector is suggested as the JTAG debug port connector. This connector definition matches the requirements of the RISCWatch debugger from IBM. The connector is shown in Figure 12-1 and the signals are shown in Table 12-1. The connector should be placed as close as possible to the chip to ensure signal integrity.

Note that position 14 does not contain a pin.





| Pin | I/O | Signal              | Description                                 |
|-----|-----|---------------------|---------------------------------------------|
| 1   | 0   | TDO                 | JTAG Test Data Out                          |
| 2   |     | No connect (NC)     | Reserved                                    |
| 3   | Ι   | TDI <sup>1</sup>    | JTAG Test Data In                           |
| 4   |     | TRST                | JTAG Reset                                  |
| 5   |     | NC                  | Reserved                                    |
| 6   |     | +POWER <sup>2</sup> | Processor I/O Voltage                       |
| 7   | 1   | TCK <sup>3</sup>    | JTAG Test Clock                             |
| 8   |     | NC                  | Reserved                                    |
| 9   | 1   | TMS <sup>1</sup>    | JTAG Test Mode Select                       |
| 10  |     | NC                  | Reserved                                    |
| 11  | Ι   | HALT <sup>3</sup>   | Processor Halt                              |
| 12  |     | NC                  | Reserved                                    |
| 13  |     | NC                  | Reserved                                    |
| 14  |     | Key                 | The pin at this position should be removed. |
| 15  |     | NC                  | Reserved                                    |
| 16  |     | GND                 | Ground                                      |

| Table 12-1. JTAG Connector Signa |
|----------------------------------|
|----------------------------------|

- 1. A 10K ohm pullup resistor should be connected to this signal to reduce chip power consumption. The pullup resistor is not required.
- 2. The +POWER signal, sourced from the target development board, indicates whether the I/O voltage at which the processor is operating. This signal does not supply power to the RISCWatch hardware or to the processor. The active level on this signal can be +5V or +3.3V (note that the PPC405GP can have either +5V or +3.3V I/O, but the processor itself must be powered by +3.3V). A series resistor (1K ohm or less) should be used to provide short circuit current-limiting protection.
- 3. A 10K ohm pullup resistor must be connected to these signals to ensure proper chip operation when these inputs are not used.

### 12.4.1 JTAG Instructions

The JTAG debug port provides the standard *extest*, *idcode*, *sample/preload*, and *bypass* instructions and the optional *highz* and *clamp* instructions. Invalid instructions behave as the *bypass* instruction.

| Instruction    | Code    | Comments                   |
|----------------|---------|----------------------------|
| Extest         | 1111000 | IEEE 1149.1 standard.      |
|                | 1111001 | Reserved.                  |
| Sample/Preload | 1111010 | IEEE 1149.1 standard.      |
| IDCode         | 1111011 | IEEE 1149.1 standard.      |
| Private        | xxxx100 | Private instructions       |
| HighZ          | 1111101 | IEEE 1149.1a-1993 optional |
| Clamp          | 1111110 | IEEE 1149.1a-1993 optional |
| Bypass         | 1111111 | IEEE 1149.1 standard.      |

Table 12-2. JTAG Instructions

### 12.4.2 JTAG Boundary Scan

Boundary Scan Description Language (BSDL), IEEE 1149.1b-1994, is a supplement to IEEE 1149.1-1990 and IEEE 1149.1a-1993 *Standard Test Access Port and Boundary-Scan Architecture*. BSDL, a subset of the IEEE 1076-1993 Standard VHSIC Hardware Description Language (VHDL), allows a rigorous description of testability features in components which comply with the standard. BSDL is used by automated test pattern generation tools for package interconnect tests and by electronic design automation (EDA) tools for synthesized test logic and verification. BSDL supports robust extensions that can be used for internal test generation and to write software for hardware debug and diagnostics.

The primary components of BSDL include the logical port description, the physical pin map, the instruction set, and the boundary register description.

The logical port description assigns symbolic names to the pins of a chip. Each pin has a logical type of in, out, inout, buffer, or linkage that defines the logical direction of signal flow.

The physical pin map correlates the logical ports of the chip to the physical pins of a specific package. A BSDL description can have several physical pin maps; each map is given a unique name.

Instruction set statements describe the bit patterns that must be shifted into the Instruction Register to place the chip in the various test modes defined by the standard. Instruction set statements also support descriptions of instructions that are unique to the chip.

The boundary register description lists each cell or shift stage of the Boundary Register. Each cell has a unique number: the cell numbered 0 is the closest to the Test Data Out (TDO) pin; the cell with the highest number is closest to the Test Data In (TDI) pin. Each cell contains additional information, including: cell type, logical port associated with the cell, logical function of the cell, safe value, control cell number, disable value, and result value.

### 12.4.3 JTAG Implementation

PPC405GP JTAG interface I/Os (TDI, TDO, TMs, TCK, and TRST) are 5V tolerant and do not contain internal pull up resistors.

The optional JTAG instructions, *idcode* and *highz*, offer additional JTAG functionality. The *idcode* instruction returns the PPC405GP JTAG ID, which is unique for each chip version. The *highz* instruction disables all chip outputs regardless of whether they are included in the JTAG boundary scan chain.

The PPC405GP provides boundary scan structures on most I/O signals. However, the following signals are excluded because of speed and functional considerations:

- DrvrInh1
- Drvrlnh2
- PciClk
- Rcvrlnh
- TestEn

### 12.4.4 JTAG ID Register (CPC0\_JTAGID)

CPC0\_JTAGID is a Device Control Register that enables manufacturing, part number, and version information to be determined through the TAP. The **mfdcr** instruction is used to read this register.

Refer to *PowerPC 405GP Embedded Processor Data Sheet* for the values of the CPC0\_JTAGID fields.



| 0:11  | MANF | Manufacturer Identifier |
|-------|------|-------------------------|
| 12:23 | PART | Part Number             |
| 24:27 | LOC  | Developer Location      |
| 28:31 | VERS | Version                 |

### 12.5 Trace Port

The PPC405GP implements a trace status interface to support the tracing of code running in realtime. This interface enables the connection of an external trace tool, such as RISCWatch, and allows for user-extended trace functions. A software tool with trace capability, such as RISCWatch with RISCTrace, can use the data collected from this port to trace code running on the processor. The result is a trace of the code executed, including code executed out of the instruction cache if it was enabled. Information on trace capabilities, how trace works, and how to connect the external trace tool is available in *RISCWatch Debugger User's Guide*.

A 20-pin male 2x10 header connector is recommended for connecting to the trace status port of the PPC405GP. The connector, shown in Figure 12-3, and the signal descriptions in Table 12-3 match the requirements of RISCTrace, when used with the RISCWatch processor probe with RISCTrace option.





Table 12-3 describes the assignment of the RISCTrace signals and the processor core outputs to the header pins:

|     |             |     | •           |
|-----|-------------|-----|-------------|
| Pin | Signal Name | Pin | Signal Name |
| 1   | No connect  | 11  | No connect  |
| 2   | No connect  | 12  | TS1o (odd)  |
| 3   | TrcClk      | 13  | TS20        |
| 4   | No connect  | 14  | TS1e (even) |
| 5   | No connect  | 15  | TS2e        |
| 6   | No connect  | 16  | TS3         |
| 7   | No connect  | 17  | TS4         |
| 8   | No connect  | 18  | TS5         |
| 9   | No connect  | 19  | TS6         |

Table 12-3. RISCTrace Header Pin Description

| Pin | Signal Name | Pin | Signal Name |
|-----|-------------|-----|-------------|
| 10  | No connect  | 20  | GND         |

Table 12-3. RISCTrace Header Pin Description (continued)

# 12.6 Debug Modes

The PPC405GP supports the following debug modes, each of which supports a type of debug tool or debug task commonly used in embedded systems development:

- Internal debug mode, which supports ROM monitors
- External debug mode, which supports JTAG debuggers
- Debug wait mode, which supports processor stopping or stepping for JTAG debuggers while servicing interrupts
- · Real-time trace mode, which supports trigger events for real-time tracing

Internal and external debug modes can be enabled simultaneously. Both modes are controlled by fields in Debug Control Register 0 (DBCR0). Real-time trace mode is available only if internal, external, and debug wait modes are disabled.

# 12.6.1 Internal Debug Mode

Internal debug mode provides access to architected processor resources and supports setting hardware and software breakpoints and monitoring processor status. In this mode, debug events generate debug interrupts, which can interrupt normal program flow so that monitor software can collect processor status and alter processor resources.

Internal debug mode relies on exception handling software at a dedicated interrupt vector and an external communications path to debug software problems. This mode, used while the processor executes instructions, enables debugging of operating system or application programs.

In this mode, debugger software is accessed through a communications port, such as a serial port, external to the processor core.

To enable internal debug mode, the Debug Control Register 0 (DBCR0) field IDM is set to 1 (DBCR0[IDM] = 1). To enable debug interrupts, MSR[DE] = 1. A debug interrupt occurs on a debug event only if DBCR0[IDM] = 1 and MSR[DE] = 1.

## 12.6.2 External Debug Mode

External debug mode provides access to architected processor resources and supports stopping, starting, and stepping the processor, setting hardware and software breakpoints, and monitoring processor status. In this mode, debug events cause the processor to become architecturally frozen. While the processor is frozen, normal instruction execution stops and architected processor resources can be accessed and altered. External bus activity continues in external debug mode.

The JTAG mechanism can pass instructions to the processor for execution, allowing a JTAG debugger to display and alter processor resources, including memory.

The JTAG mechanism prevents the occurrence of a privileged exception when a privileged instruction is executed while the processor is in user mode.

Storage access control by a memory management unit (MMU) remains in effect while in external debug mode; the debugger may need to modify MSR or TLB values to access protected memory.

Because external debug mode relies only on internal processor resources, it can be used to debug system hardware and software.

In this mode, access to the processor is through the JTAG debug port.

To enable external debug mode, DBCR0[EDM] = 1. To enable debug interrupts, MSR[DE] = 1. A debug interrupt occurs on a debug event only if DBCR0[EDM] = 1 and MSR[DE] = 1.

### 12.6.3 Debug Wait Mode

In debug wait mode, debug events cause the PPC405GP to enter a state in which interrupts can be serviced while the processor appears to be stopped.

Debug wait mode provides access to architected processor resources in a manner similar to external debug mode, except that debug wait mode allows the servicing of interrupt handlers. It supports stopping, starting, and stepping the processor, setting hardware and software breakpoints, and monitoring processor status. In this mode, if a debug event caused the processor to become architecturally frozen, an interrupt causes the processor to run an interrupt handler and return to the architecturally frozen state upon returning from the interrupt handler. While the processor is frozen, normal instruction execution stops and architected processor resources can be accessed and altered. External bus activity continues in debug wait mode.

The processor enters debug wait mode when internal and external debug modes are disabled (DBCR0[IDM, EDM] = 0), debug wait mode is enabled (MSR[DWE] = 1), debug wait is enabled by the JTAG debugger, and a debug event occurs.

For example, while the PPC405GP is in debug wait mode, an external device might generate an interrupt that requires immediate service. The PPC405GP can service the interrupt (vector to an interrupt handler and execute the interrupt handler code) and return to the previous stopped state.

Debug wait mode relies only on internal processor resources, so it can be used to debug both system hardware and software problems. This mode can also be used for software development on systems without a control program, or to debug control program problems.

In this mode, access to the processor is through the JTAG debug port.

### 12.6.4 Real-time Trace Debug Mode

Real-time trace debug mode supports the generation of trigger events for tracing the instruction stream being executed out of the instruction cache in real-time. In this mode, debug events can be used to control the collection of trace information through the use of trigger event generation. The broadcast of trace information is independent of the use of debug events as trigger events. This mode does not alter the processor performance.

A trace event occurs when internal and external debug modes are disabled (DBCR0[IDM, EDM] = 0) and a debug events occurs.

When a trace event occurs, a trace device can capture trace signals that provide the instruction trace information. Most trace events generated from debug events are blocked when internal debug, external debug, or debug wait modes are enabled

# **12.7 Processor Control**

The PPC405GP provides the following debug functions for processor control. Not all facilities are available in all debug modes.

| Instruction Step  | The processor is stepped one instruction at a time, while stopped, using the JTAG debug port.                                                                                                                                                                                                                                                                                           |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction Stuff | While the processor is stopped, instructions can be stuffed into the processor and executed using the JTAG debug port.                                                                                                                                                                                                                                                                  |
| Halt              | The processor can be stopped by activating an external halt signal on an external event, such as a logic analyzer trigger. This signal freezes the processor architecturally. While frozen, normal instruction execution stops and architected processor resources can be accessed and altered using the JTAG debug port. Normal execution resumes when the halt signal is deactivated. |
| Stop              | The processor can be stopped using the JTAG debug port. Activating a stop causes the processor to become architecturally frozen. While frozen, normal instruction execution stops and the architected processor resources can be accessed and altered using the JTAG debug port.                                                                                                        |
| Reset             | An external reset signal, the JTAG debug port, or DBCR0 can request core,<br>chip, and system resets.                                                                                                                                                                                                                                                                                   |
| Debug Events      | A debug event triggers a debug operation. The operation depends on the debug mode. For more information and a list of debug events, see "Debug Events" on page 12-16.                                                                                                                                                                                                                   |
| Freeze Timers     | The JTAG debug port or DBCR0 can control timer resources. The timers can be enabled to run, freeze always, or freeze on a debug event.                                                                                                                                                                                                                                                  |
| Trap Instructions | The trap instructions <b>tw</b> and <b>twi</b> can be used, with debug events, to implement software breakpoints.                                                                                                                                                                                                                                                                       |

## 12.8 Processor Status

The processor execution status, exception status, and most recent reset can be monitored.

| Execution Status  | The JTAG debug port can monitor processor execution status to determine whether the processor is stopped, waiting, or running.                          |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Exception Status  | The JTAG debug port can monitor the status of pending synchronous exceptions.                                                                           |
| Most Recent Reset | The JTAG debug port or an <b>mfspr</b> instruction can be used to read the Debug Status Register (DBSR) to determine the type of the most recent reset. |

## 12.9 Debug Registers

Several debug registers, available to debug tools running on the processor, are not intended for use by application code. Debug tools control debug resources such as debug events. Application code that uses debug resources can cause the debug tools to fail, as well as other unexpected results, such as program hangs and processor resets.

Application code should not use the debug resources, including the debug registers.

## 12.9.1 Debug Control Registers

The debug control registers (DBCR0 and DBCR1) can enable and configure debug events, reset the processor, control timer operation during debug events, enable debug interrupts, and set the processor debug mode.

### 12.9.1.1 Debug Control Register 0 (DBCR0)



| 0   | EDM | External Debug Mode<br>0 Disabled<br>1 Enabled                             |                                                        |
|-----|-----|----------------------------------------------------------------------------|--------------------------------------------------------|
| 1   | IDM | Internal Debug Mode<br>0 Disabled<br>1 Enabled                             |                                                        |
| 2:3 | RST | Reset<br>00 No action<br>01 Core reset<br>10 Chip reset<br>11 System reset | Causes a processor reset request when set by software. |
|     |     | Attention: Writing 01, 10, or 11 to this field ca                          | auses a processor reset request.                       |
| 4   | IC  | Instruction Completion Debug Event<br>0 Disabled<br>1 Enabled              |                                                        |
| 5   | BT  | Branch Taken Debug Event<br>0 Disabled<br>1 Enabled                        |                                                        |
| 6   | EDE | Exception Debug Event<br>0 Disabled<br>1 Enabled                           |                                                        |
| 7   | TDE | Trap Debug Event<br>0 Disabled<br>1 Enabled                                |                                                        |
| 8   | IA1 | IAC 1 Debug Event<br>0 Disabled<br>1 Enabled                               |                                                        |
| 9   | IA2 | IAC 2 Debug Event<br>0 Disabled<br>1 Enabled                               |                                                        |

### Figure 12-4. Debug Control Register 0 (DBCR0)

| 10    | IA12  | Instruction Address Range Compare 1–2<br>0 Disabled<br>1 Enabled                        | Registers IAC1 and IAC2 define an<br>address range used for IAC address<br>comparisons. |
|-------|-------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 11    | IA12X | Enable Instruction Address Exclusive<br>Range Compare 1–2<br>0 Inclusive<br>1 Exclusive | Selects the range defined by IAC1 and IAC2 to be inclusive or exclusive.                |
| 12    | IA3   | IAC 3 Debug Event<br>0 Disabled<br>1 Enabled                                            |                                                                                         |
| 13    | IA4   | IAC 4 Debug Event<br>0 Disabled<br>1 Enabled                                            |                                                                                         |
| 14    | IA34  | Instruction Address Range Compare 3–4<br>0 Disabled<br>1 Enabled                        | Registers IAC3 and IAC4 define an<br>address range used for IAC address<br>comparisons. |
| 15    | IA34X | Instruction Address Exclusive Range<br>Compare 3–4<br>0 Inclusive<br>1 Exclusive        | Selects range defined by IAC3 and IAC4 to be inclusive or exclusive.                    |
| 16    | IA12T | Instruction Address Range Compare 1-2<br>Toggle<br>0 Disabled<br>1 Enable               | Toggles range 12 inclusive, exclusive DBCR[IA12X] on debug event.                       |
| 17    | IA34T | Instruction Address Range Compare 3–4<br>Toggle<br>0 Disabled<br>1 Enable               | Toggles range 34 inclusive, exclusive<br>DBCR[IA34X] on debug event.                    |
| 18:30 |       | Reserved                                                                                |                                                                                         |
| 31    | FT    | Freeze timers on debug event<br>0 Timers not frozen<br>1 Timers frozen                  |                                                                                         |

# 12.9.1.2 Debug Control Register1 (DBCR1)



| 0     | D1R   | DAC1 Read Debug Event<br>0 Disabled<br>1 Enabled                                                                        |                                                                                                                      |
|-------|-------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| 1     | D2R   | DAC 2 Read Debug Event<br>0 Disabled<br>1 Enabled                                                                       |                                                                                                                      |
| 2     | D1W   | DAC 1 Write Debug Event<br>0 Disabled<br>1 Enabled                                                                      |                                                                                                                      |
| 3     | D2W   | DAC 2 Write Debug Event<br>0 Disabled<br>1 Enabled                                                                      |                                                                                                                      |
| 4:5   | D1S   | DAC 1 Size<br>00 Compare all bits<br>01 Ignore Isb (least significant bit)<br>10 Ignore two Isbs<br>11 Ignore five Isbs | Address bits used in the compare:<br>Byte address<br>Halfword address<br>Word address<br>Cache line (8-word) address |
| 6:7   | D2S   | DAC 2 Size<br>00 Compare all bits<br>01 Ignore Isb (least significant bit)<br>10 Ignore two Isbs<br>11 Ignore five Isbs | Address bits used in the compare:<br>Byte address<br>Halfword address<br>Word address<br>Cache line (8-word) address |
| 8     | DA12  | Enable Data Address Range Compare 1:2<br>0 Disabled<br>1 Enabled                                                        | Registers DAC1 and DAC2 define an<br>address range used for DAC address<br>comparisons                               |
| 9     | DA12X | Data Address Exclusive Range Compare<br>1:2<br>0 Inclusive<br>1 Exclusive                                               | Selects range defined by DAC1 and DAC2 to be inclusive or exclusive                                                  |
| 10:11 |       | Reserved                                                                                                                |                                                                                                                      |

## Figure 12-5. Debug Control Register 1 (DBCR1)

| 12:13 | DV1M  | Data Value Compare 1 Mode<br>00 Undefined            | Type of data comparison used:                                                                                                                                                |
|-------|-------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       | 01 AND                                               | All bytes selected by DBCR1[DV1BE] must compare to the appropriate bytes of DVC1.                                                                                            |
|       |       | 10 OR                                                | One of the bytes selected by<br>DBCR1[DV1BE] must compare to the<br>appropriate bytes of DVC1.                                                                               |
|       |       | 11 AND-OR                                            | The upper halfword or lower halfword must<br>compare to the appropriate halfword in<br>DVC1. When performing halfword<br>compares set DBCR1[DV1BE] = 0011,<br>1100, or 1111. |
| 14:15 | DV2M  | Data Value Compare 2 Mode                            | Type of data comparison used                                                                                                                                                 |
|       |       | 01 AND                                               | All bytes selected by DBCR1[DV2BE] must compare to the appropriate bytes of DVC2.                                                                                            |
|       |       | 10 OR                                                | One of the bytes selected by DBCR1[DV2BE] must compare to the appropriate bytes of DVC2.                                                                                     |
|       |       | 11 AND-OR                                            | The upper halfword or lower halfword must<br>compare to the appropriate halfword in<br>DVC2. When performing halfword<br>compares set DBCR1[DV2BE] = 0011,<br>1100, or 1111. |
| 16:19 | DV1BE | Data Value Compare 1 Byte<br>0 Disabled<br>1 Enabled | Selects which data bytes to use in data value comparison                                                                                                                     |
| 20:23 | DV2BE | Data Value Compare 2 Byte<br>0 Disabled<br>1 Enabled | Selects which data bytes to use in data value comparison                                                                                                                     |
| 24:31 |       | Reserved                                             |                                                                                                                                                                              |

### 12.9.2 Debug Status Register (DBSR)

The DBSR contains status on debug events and the most recent reset; the status is obtained by reading the DBSR. The status bits are normally set by debug events or by any of the three reset types.

Clearing DBSR fields is performed by writing a word to the DBSR, using the **mtdbsr** extended mnemonic, having a 1 in all bit positions to be cleared and a 0 in the all other bit positions. The data written to the DBSR is not direct data, but a mask. A 1 clears the bit and a 0 has no effect.

Application code should not use the DBSR.



| 0  | IC  | Instruction Completion Debug Event<br>0 Event did not occur<br>1 Event occurred |
|----|-----|---------------------------------------------------------------------------------|
| 1  | BT  | Branch Taken Debug Event<br>0 Event did not occur<br>1 Event occurred           |
| 2  | EDE | Exception Debug Event<br>0 Event did not occur<br>1 Event occurred              |
| 3  | TIE | Trap Instruction Debug Event<br>0 Event did not occur<br>1 Event occurred       |
| 4  | UDE | Unconditional Debug Event<br>0 Event did not occur<br>1 Event occurred          |
| 5  | IA1 | IAC1 Debug Event<br>0 Event did not occur<br>1 Event occurred                   |
| 6  | IA2 | IAC2 Debug Event<br>0 Event did not occur<br>1 Event occurred                   |
| 7  | DR1 | DAC1 Read Debug Event<br>0 Event did not occur<br>1 Event occurred              |
| 8  | DW1 | DAC1 Write Debug Event<br>0 Event did not occur<br>1 Event occurred             |
| 9  | DR2 | DAC2 Read Debug Event<br>0 Event did not occur<br>1 Event occurred              |
| 10 | DW2 | DAC2 Write Debug Event<br>0 Event did not occur<br>1 Event occurred             |

### Figure 12-6. Debug Status Register (DBSR)

| 11    | IDE | Imprecise Debug Event<br>0 No circumstance that would cause a<br>debug event (if MSR[DE] = 1) occurred<br>1 A debug event would have occurred, but<br>debug exceptions were disabled<br>(MSR[DE] = 1) |                                                                                  |
|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 12    | IA3 | IAC3 Debug Event<br>0 Event did not occur<br>1 Event occurred                                                                                                                                         |                                                                                  |
| 13    | IA4 | IAC4 Debug Event<br>0 Event did not occur<br>1 Event occurred                                                                                                                                         |                                                                                  |
| 14:21 |     | Reserved                                                                                                                                                                                              | ·····                                                                            |
| 22:23 | MRR | Most Recent Reset<br>00 No reset has occurred since last<br>cleared by software.<br>01 Core reset<br>10 Chip reset<br>11 System reset                                                                 | This field is set to a value, indicating the type of reset, when a reset occurs. |
| 24:31 |     | Reserved                                                                                                                                                                                              |                                                                                  |

## 12.9.3 Instruction Address Compare Registers (IAC1–IAC4)

The PPC405GP can take a debug event upon an attempt to execute an instruction from an address. The address, which must be word-aligned, is defined in an IAC register. The DBCR0[IA1, IA2] fields of DBCR0 controls the instruction address compare (IAC) debug event.



| 0:29  | Instruction Address Compare word<br>address | Omit two low-order bits of complete address. |
|-------|---------------------------------------------|----------------------------------------------|
| 30:31 | Reserved                                    |                                              |

### 12.9.4 Data Address Compare Registers (DAC1–DAC2)

The PPC405GP can take a debug event upon storage or cache references to addresses specified in the DAC registers. The specified addresses in the DAC registers are EAs of operands of storage

references or cache instructions. The fields DBCR1[D1R], [D2R] and DBCR[D1W], [D2W] control the DAC-read and DAC-write debug events, respectively.

Addresses in the DAC registers specify exact byte EAs for DAC debug events. However, one may want to take a debug event on any byte within a halfword (ignore the least significant bit (LSb) of the DAC), on any byte within a word (ignore the two LSbs of DAC), or on any byte within eight words (ignore four LSbs of DAC). DBCR1[D1S, D2S] control the addressing options.

Errors related to execution of storage reference or cache instructions prevent DAC debug events.

|   | <br> |    |
|---|------|----|
| 0 |      | 31 |

Figure 12-8. Data Address Compare Registers (DAC1–DAC2)

| 0:31 | Data Address Compare (DAC) byte | DBCR0[D1S] determines which address |
|------|---------------------------------|-------------------------------------|
|      | address                         | bits are examined.                  |

#### 12.9.5 Data Value Compare Registers (DVC1–DVC2)

The PPC405GP can take a debug event upon storage or cache references to addresses specified in the DAC registers, that also require the data at that address to match the value specified in the DVC registers. The data address compare for a DVC events works the same as for a DAC event. Cache operations do not cause DVC events. If the data at the address specified matches the value in the corresponding DVC register a DVC event will occur. The fields DBCR1[DV1M, DV2M] control how the data value are compared.

Errors related to execution of storage reference or cache instructions prevent DVC debug events.

|  | <br>٦. |
|--|--------|
|  |        |
|  |        |
|  |        |

#### Figure 12-9. Data Value Compare Registers (DVC1–DVC2)

# 12.9.6 Debug Events

Debug events, enabled and configured by DBCR0 and DBCR1 and recorded in the DBSR, cause debug operations. A debug event occurs when an event listed in Table 12-4, "Debug Events," on page 12-16 is detected. The debug operation is performed after the debug event.

In internal debug mode, the processor generates a debug interrupt when a debug event occurs. In external debug mode, the processor stops when a debug event occurs. When internal and external debug mode are both enabled, the processor stops on a debug event with the debug interrupt pending. When external and internal debug mode are both disabled, and debug wait mode is enabled the processor stops, but can be restarted by an interrupt. When all debug modes are disabled, debug events are recorded in the DBSR, but no action is taken.

Table 12-4 lists the debug events and the related fields in DBCR0, DBCR1, and DBSR. DBCR0 and DBCR1 enable the debugs events, and the DBSR fields report their occurrence.

| Event                          | Enabling<br>DBCR0, DBCR1<br>Fields                                     | Reporting<br>DBSR Fields | Description                                                                                                                                                                                       |
|--------------------------------|------------------------------------------------------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction Completion         | IC                                                                     | IC                       | Occurs after completion of an instruction.                                                                                                                                                        |
| Branch Taken                   | ВТ                                                                     | ВТ                       | Occurs before execution of a branch instruction determined to be taken.                                                                                                                           |
| Exception Taken                | EDE                                                                    | EXC                      | Occurs after an exception.                                                                                                                                                                        |
| Trap Instruction               | TDE                                                                    | TIE                      | Occurs before execution of a trap<br>instruction where the conditions are such<br>that the trap will occur.                                                                                       |
| Unconditional                  | UDE                                                                    | UDE                      | Occurs immediately upon being set by the JTAG debug port.                                                                                                                                         |
| Instruction Address<br>Compare | IA1, IA2, IA3,<br>IA4, IA12,<br>IA12X, IA12T,<br>IA34, IA34X,<br>IA34T | ia1, ia2, ia3,<br>ia4    | Occurs before execution of an instruction<br>at an address that matches an address<br>defined by the Instruction Address<br>Compare Registers (IAC1–IAC4).                                        |
| Data Address<br>Compare        | D1R, D1W, D1S,<br>D2R, D2W, D2S,<br>DA12, DA12X                        | DR2,DW2                  | Occurs before execution of an instruction<br>that accesses a data address that matches<br>the contents of the specified DAC register.                                                             |
| Data Value Compare             | DV1M, DV2M,<br>DV1BE, DV2BE                                            | DR1, DW1                 | Occurs after execution of an instruction<br>that accesses a data address for which a<br>DAC occurs, and for which the value at the<br>address matches the value in the specified<br>DVC register. |
| Imprecise                      |                                                                        | IDE                      | Indicates that another debug event<br>occurred while MSR[DE] = 0                                                                                                                                  |

Table 12-4. Debug Events

# 12.9.7 Instruction Complete Debug Event

This debug event occurs after the completion of an instruction. If DBCR0[IDM] = 1, DBCR0[EDM] = 0 and MSR[DE] = 0 this debug event is disabled.

## 12.9.8 Branch Taken Debug Event

This debug event occurs before execution of a branch instruction determined to be taken. If DBCR0[IDM] = 1, DBCR0[EDM] = 0 and MSR[DE] = 0 this debug event is disabled.

### 12.9.9 Exception Taken Debug Event

This debug event occurs after an exception. Exception debug events always include the non-critical class of exceptions. When DBCR0[IDM] = 1 and DBCR0[EDM] = 0 the critical exceptions are not included.

### 12.9.10 Trap Taken Debug Event

This debug event occurs before execution of a trap instruction where the conditions are such that the trap will occur. When trap is enabled for a debug event, external debug mode is enabled, internal debug mode is enabled with MSR[DE] enabled, or debug wait mode is enabled, a trap instruction will not cause a program exception.

## 12.9.11 Unconditional Debug Event

This debug event occurs immediately upon being set by the JTAG debug port.

## 12.9.12 IAC Debug Event

This debug event occurs before execution of an instruction at an address that matches an address defined by the Instruction Address Compare Registers (IAC1–IAC4). DBCR0[IA1, IA2, IA3, IA4] enable IAC debug events IAC can be defined as an exact address comparison to one of the IAC*n* registers or on a range of addresses to compare defined by a pair of IAC*n* registers.

### 12.9.12.1 IAC Exact Address Compare

In this mode each IAC*n* register specifies an exact address to compare. These are enabled by setting DBCR0[IA*n*] = 1 and disabling IAC range compare (DBCR0[IA12X] = 0 for IAC1 and IAC2 and DBCR0[IA23X] = 0 for IAC3 and IAC4). The corresponding DBSR[IA*n*] bit displays the results of the debug event.

#### 12.9.12.2 IAC Range Address Compare

In this mode a pair of IACn registers are used to define a range of addresses to compare:

Range 1:2 corresponds to IAC1 and IAC2 Range 3:4 corresponds to IAC3 and IAC4

To enable Range 1:2, DBCR0[IA12] = 1 and DBCR0[IA1] or DBCR0[IA2] =1. An IAC event will be seen on the DBSR[IAn] field that corresponds to the enabled DBCR0[IAn] field. If DBCR0[IA1] and DBCR0[IA2] are enabled, the results of the event are reported on both DBSR fields. Setting DBCR0[IA12] =1 prohibits IAC1 and IAC2 from being used for exact address compares.

To enable Range 3:4, DBCR0[IA34] = 1 and DBCR0[IA3] or DBCR0[IA4] =1. An IAC event will be seen on the DBSR[IA*n*] field that corresponds to the enabled DBCR0[IA*n*] field. If DBCR0[IA3] and DBCR0[IA4] are enabled, the results of the event will be reported on both DBSR fields. Setting DBCR0[IA34] =1 prohibits IAC3 and IAC4 from being used for exact address compares.

Ranges can be defined as inclusive, as shown in the preceding examples, or exclusive, using DBCR0[IA12X] (corresponding to range 1:2) and DBCR0[IA34X] (corresponding to range 3:4), as follows:

Figure 12-10 shows the range selected in an inclusive IAC range address compare. Note that the address in IAC1 is considered part of the range, but the address in IAC2 is not, as shown in the preceding examples. The thick lines indicate that the indicated address is included in the compare results.



Figure 12-10. Inclusive IAC Range Address Compares

Figure 12-11 shows the range selected in an inclusive IAC range address compare. Note that the address in IAC1 is not considered part of the range, but the address in IAC2 is, along with the highest memory address, as shown in the preceding examples.



Figure 12-11. Exclusive IAC Range Address Compares

To toggle the range from inclusive to exclusive or from exclusive to inclusive on a IAC range debug event, DBCR0[IA12T] (corresponding to range 1:2) and DBCR0[IA34T] (corresponding to range 3:4) are used. If these fields are set, the DBCR0[IA12X] or DBCR0[IA34X] fields toggle on an IAC debug event, changing the defined range.

When a toggle is enabled (DBCR0[IA12T] for range 1:2 or DBCR0[IA34T] = 1 for range 3:4), and DBCR0[IDM] =1, DBCR0[EDM] = 0, and MSR[DE] = 0, IAC range comparisons for the corresponding toggle field are disabled.

### 12.9.13 DAC Debug Event

This debug event occurs before execution of an instruction that accesses a data address that matches the contents of the specified DAC register. DBCR1[D1R, D2R, D1W, D2W] enable DAC debug events for address comparisons on DAC1 and DAC2 for read instructions, DAC2 for read instructions, DAC1 for write instructions, DAC2 for write instructions respectively. Loads are reads and stores are writes. DAC can be defined(DBCR1[D1R, D2R])as an exact address comparison to one of the DACn registers or a range of addresses to compare defined by DAC1 and DAC2 registers.

### 12.9.13.1 DAC Exact Address Compare

In this mode, each DAC*n* register specifies an exact address to compare. Thes registers are enabled by setting one or more of DBCR1[D1R,D2R,D1W,D2W] = 1, and disabling DAC range compare DBCR1[DA12X] = 0. The corresponding DBSR[DR1,DR2,DW1,DW2] field displays the results of a DAC debug event.

The address for a DAC is the effective address (EA) of a storage reference instruction. EAs are always generated within a single aligned word of memory. Unaligned load and store, strings, and multiples generate multiple EAs to be used in DAC comparisons.

Data address compare (DAC) debug events can be set to react to any byte in a larger block of memory, in addition to reacting to a byte address match. The DAC Compare Size fields (DBCR1[D1S, D2S]) allow DAC debug events to react to byte, halfword, word, or 8-word line address by ignoring a number of LSBs in the EA.

| Byte address                |
|-----------------------------|
| Halfword address            |
| Word address                |
| Cache line (8-word) address |
|                             |

The user must determine how the addresses of interest are accessed, relative to byte, halfword, word, string, and unaligned storage instructions, and adjust the DAC compare size field appropriately to cover the addresses of interest.

For example, suppose that a DAC debug event should react to byte 3 of a word-aligned target. A DAC set for exact compare would not recognize a reference to that byte by load/store word or load/store halfword instructions, because the byte address is not the EA of such instructions. In such a case, the D1S field must be set for a wider capture range (for example, to ignore the two least significant bits (LSBs) if word operations to the misaligned byte are to be detected). The wider capture range may result in excess debug events (events that are within the specified capture range, but reflect byte operations in addition to the desired byte). Such excess debug events must be handled by software.

While load/store string instructions are inherently byte addressed the processor will generate EAs containing the largest portion of an aligned word address as possible. It may not be possible to DAC on a specific individual byte using load/store string instructions.

### 12.9.13.2 DAC Range Address Compare

In this mode, the pair of DAC1 and DAC2 registers are used to define a range of addresses to compare.

To enable DAC range, DBCR1[DA12] = 1 and one or more of DBCR1[D1R,D2R,D1W,D2W] =1. The DAC event is seen on the DBSR[DR1,DR2,DW1,DW2] field that corresponds to the DBCR1[D1R,D2R,D1W,D2W] field that is enabled. For example, if DBCR1[D1R] and DBCR1[D2R] are enabled, the results of a DAC debug event are reported on DBSR[DR1, DR2]. Setting DBCR1[DA12] =1 prohibits DAC1 and DAC2 from being used for exact address compares.

Ranges are defined to be inclusive or exclusive, using the DBCR1[DA12X], as follows:

 $\label{eq:decomposition} \begin{array}{l} \mathsf{DBCR1}[\mathsf{DA12}] = 1: \mbox{ Range = } \mathsf{DAC1} \leq \mbox{ range < } \mathsf{DAC2}. \\ \mbox{ DBCR1}[\mathsf{DA12X}] = 1: \mbox{ Range = } \mbox{ Range low < } \mathsf{DAC1} \mbox{ or } \mathsf{DAC2} & \mbox{ Range high}. \end{array}$ 

Figure 12-12 shows the range selected in an inclusive DAC range address compare. Note that the address in DAC1 is considered part of the range, but the address in DAC2 is not, as shown in the preceding examples. The thick lines indicate that the indicated address is included in the compare results.





Figure 12-13 shows the range selected in an exclusive DAC range address compare. Note that the address in DAC1 is not considered part of the range, but the address in DAC2 is, along with the highest memory address, as shown in the preceding examples.

| 0    | FFFF FFFF |
|------|-----------|
|      |           |
| DAC1 | DAC2      |



The DAC Compare Size fields (DBCR1[D1S, D2S]) are not used by DAC range comparisons.

#### 12.9.13.3 Data Address Compare (DAC) Applied to Cache Instructions

Some cache instructions may cause DAC debug events. There are several special cases.

Table 12-5 summarizes possible DAC debug events by cache instruction:

|             | Possible DAC Debug Event |           |  |
|-------------|--------------------------|-----------|--|
| Instruction | DAC-Read                 | DAC-Write |  |
| dcba        | No                       | Yes       |  |
| dcbf        | No                       | Yes       |  |
| dcbi        | No                       | Yes       |  |
| dcbst       | No                       | Yes       |  |
| dcbt        | Yes                      | No        |  |
| dcbz        | No                       | Yes       |  |
| dccci       | No                       | No        |  |
| dcread      | No                       | No        |  |
| dcbtst      | Yes                      | No        |  |
| icbì        | Yes                      | No        |  |

|             | Possible DAC Debug Event |           |  |
|-------------|--------------------------|-----------|--|
| Instruction | DAC-Read                 | DAC-Write |  |
| icbt        | Yes                      | No        |  |
| iccci       | No                       | No        |  |
| icread      | No                       | No        |  |

#### Table 12-5. DAC Applied to Cache Instructions (continued)

Architecturally, the **dcbi** and **dcbz** instructions are "stores." These instructions can change data, or cause the loss of data by invalidating a dirty line. Therefore, they can cause DAC-write debug events.

The **dccci** instruction can also be considered a "store" because it can change data by invalidating a dirty line. However, **dccci** is not address-specific; it affects an entire congruence class regardless of the operand address of the instruction. Because it is not address-specific, **dccci** does not cause DAC-write debug events.

Architecturally, the **dcbt**, **dcbtst**, **dcbf**, and **dcbst** instructions are "loads." These instructions do not change data. Flushing or storing a cache line from the cache is not architecturally a "store" because a store had already updated the cache; the **dcbf** or **dcbst** instruction only updates the copy in main memory.

The dcbt and dcbtst instructions can cause DAC-read debug events regardless of cachability.

Although **dcbf** and **dcbst** are architecturally "loads," these instructions can create DAC-write (but not DAC-read) debug events. In a debug environment, the fact that external memory is being written is the event of interest.

Even though **dcread** and **dccci** are not address-specific (they affect a congruence class regardless of the instruction operand address), and are considered "loads," in the PPC405GP they do not cause DAC debug events.

All ICU operations (icbi, icbt, iccci, and icread) are architecturally treated as "loads." icbi and icbt cause DAC debug events. iccci and icread do not cause DAC debug events in the PPC405GP.

#### 12.9.13.4 DAC Applied to String Instructions

An **stswx** instruction with a string length of 0 is a no-op. The **lswx** instruction with the string length equal to 0 does not alter the RT operand with undefined data, as allowed by the PowerPC Architecture. Neither **stswx** nor **lswx** with zero length causes a DAC debug event because storage is not accessed by these instructions.

#### 12.9.14 Data Value Compare Debug Event

A data value compare (DVC) debug event can occur only after execution of a load or store instruction to an address that compares with the address in one of the DAC*n* registers and has a data value that matches the corresponding DVC*n* register. Therefore, a DVC debug event requires both the data address comparison and the data value comparison to be true. A DVCn debug event when enabled in the DBCR1 supercedes a DACn debug event since the DVCn and the DACn both use the same DACn register.

DVC1 debug events are enabled by setting the appropriate DAC enable DBCR1[D1R,D1W] to cause an address comparison and by setting anybit combination in the DBCR1[DV1BE]. DVC2 debug

events are enabled by setting the appropriate DAC enable DBCR1[D2R,D2W] to cause an address comparison and by setting any bit combination in the DBCR1[DV1BE]. Each bit in DBCR1[DV1BE, DV2BE] correspondes to a byte in DVC1 and DVC2. Exact address compare and range address compare work the same for DVC as for a simple DAC.

DBSR[DR1] and DBSR[DW1] record status for DAC1 debug events. Which DBSR bit is set depends on the setting of DBCR1[D1R] and DBCR[D1W]. If DBCR1[D1R] = 1, DBSR[DR1] = 1, assuming that a DVC event occurred. Similarly, if DBCR1[D1W] = 1, DBSR[DW1] = 1, assuming that a DVC event occurred.

Similarly, DBSR[DR2] and DBSR[DW2] record status for DAC2 debug events. Which DBSR bit is set depends on the setting of DBCR1[D2R] and DBCR[D2W]. If DBCR1[D2R] = 1, DBSR[DR2] = 1, assuming that a DVC event occurred. Similarly, if DBCR1[D2W] = 1, DBSR[DW2] = 1, assuming that a DVC event occurred.

In the following example, a DVC1 event is enabled setting the DBCR1[D1R] = 1, DBCR1[D1W] = 1, DBCR1[DA12] = 0, and DBCR1[DV1BE ' 0000]. When the data address and data value match the DAC1 and DVC1 , a DVC1 event is recorded in DBSR[DR1] or DBSR[DW1], depending on whether the operation is a load (read) or a store (write). This example corresponds to the last line of Table 12-6.

In Table 12-6, *n* is 1 or 2, depending on whether the bits apply to DAC1, DAC2, DVC1, and DVC2 events. "Hold" indicates that the DBSR holds its value unless cleared by software. "RA" indicates that the operation is a read (load) and the data address compares (exact or range). "WA" indicates that the operation is a write (store) and the data address compares (exact or range). "RV" indicates that the operation is a read (load), the data address compares (exact or range), and the data value compares according to the DBCR1[DVC*n*].

|            |              |            | DBCR1 |       |        | DB    | SR    |
|------------|--------------|------------|-------|-------|--------|-------|-------|
| DACn Event | DVCn Enabled | DVCn Event | [DnR] | [DnW] | [DA12] | [DRn] | [DWn] |
| 0          |              | —          | —     | —     | —      | Hold  | Hold  |
|            |              | _          | 0     | 0     |        | Hold  | Hold  |
| 1          | 0            | _          | 0     | 1     | _      | Hold  | WA    |
| 1          | 0            | -          | 1     | 0     |        | RA    | Hold  |
| 1          | 0            | _          | 1     | 1     |        | RA    | WA    |
| 1          | 1            | 0          | —     | -     | -      | Hold  | Hold  |
| 1          | 1            | 1          | 0     | 1     |        | Hold  | WV    |
| 1          | 1            | 1          | 1     | 0     | —      | RV    | Hold  |
| 1          | 1            | 1          | 1     | 1     | _      | RV    | wv    |

Table 12-6. Setting of DBSR Bits for DAC and DVC Events

The settings of DBCR1[DV1M] and DBCR1[DV2M] are more precisely defined in Table 12-7 (*n* enables the table to apply to DBCR1[DV1M, DV2M] and DBCR1[DV1BE, DV2BE]). DV*n*BE<sub>m</sub> indicates bytes selected (or not selected) for comparison in DBCR1[DV*n*BE].

When DBCR1[DVnM] = 01, the comparison is an AND; all bytes must compare to the appropriate bytes of DVC1.

When DBCR1[DVnM] = 10, the comparison is an OR; at least one of the selected bytes must compare to the appropriate bytes of DVC1.

When DBCR1[DV*n*M] = 11, the comparison is an AND-OR (halfword) comparison. This is intended for use when DBCR1[DV*n*BE] is set to 0011, 0111, or 1111. Other values of DBCR1[DV*n*BE] can be compared, but the results are more easily understood using the AND and OR comparisons. In Table 12-7, "not" is  $\neg$ , AND is  $\land$ , and OR is  $\lor$ .

| DBCR1[DVnM] Setting | Operation | Comparison                                                                                                                                                                                                                                                                                                                                                       |
|---------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00                  | _         | Undefined                                                                                                                                                                                                                                                                                                                                                        |
| 01                  | AND       | $\begin{array}{l} (\neg DVnBE_0 \lor (DVC1[byte 0] = data[byte 0])) \land \\ (\neg DVnBE_1 \lor (DVC1[byte 1] = data[byte 1])) \land \\ (\neg DVnBE_2 \lor (DVC1[byte 2] = data[byte 2])) \land \\ (\neg DVnBE_3 \lor (DVC1[byte 3] = data[byte 3])) \end{array}$                                                                                                |
| 10                  | OR        | $\begin{array}{l} (DVnBE_0 \land (DVC1[byte \ 0] = data[byte \ 0])) \lor \\ (DVnBE_1 \land (DVC1[byte \ 1] = data[byte \ 1])) \lor \\ (DVnBE_2 \land (DVC1[byte \ 2] = data[byte \ 2])) \lor \\ (DVnBE_3 \land (DVC1[byte \ 3] = data[byte \ 3])) \end{array}$                                                                                                   |
| 11                  | AND-OR    | $\begin{array}{l} (\text{DV}n\text{BE}_0 \land (\text{DVC1[byte 0]} = \text{data[byte 0]})) \land \\ (\text{DV}n\text{BE}_1 \land (\text{DVC1[byte 1]} = \text{data[byte 1]})) \lor \\ (\text{DV}n\text{BE}_2 \land (\text{DVC1[byte 2]} = \text{data[byte 2]})) \land \\ (\text{DV}n\text{BE}_3 \land (\text{DVC1[byte 3]} = \text{data[byte 1]})) \end{array}$ |

Table 12-7. Comparisons Based on DBCR1[DVnM]

#### 12.9.15 Imprecise Debug Event

The imprecise debug event is not an independent debug event, but indicates that a debug event occurred while MSR[DE] = 0. This is useful in internal debug mode if a debug event occurs while in a critical interrupt handler. On return from interrupt, a debug interrupt occurs if MSR[DE] = 1. If DBSR[IDE] = 1, the debug event causing the interrupt occurred sometime earlier, not immediately after a debug event.

12-24 PPC405GP User's Manual

# **Chapter 13. Clock and Power Management**

The PPC405GP provides a clock and power management (CPM) controller that reduces power dissipation by stopping clocks in unused or dormant functional units. Use of the CPM controller requires careful programming and special consideration to avoid compromising system and functional unit integrity.

The CPM controller supports three different types of sleep interfaces to the functional units:

- In a CPM class 1 interface, the CPM\_Sleep\_N signal is asserted by the CPM controller when a register bit is set by software. The functional unit is unconditionally put to sleep. There is no other communication with the functional unit.
- In a CPM class 2 interface, the functional unit uses a combination of its internal state and external inputs to determine whether or not it can be put to sleep. If sleeping is permitted, the functional unit asserts the Sleep\_Req signal to the CPM controller that responds by asserting CPM\_Sleep\_N if the enable for that unit is set. The CPM\_Sleep\_N signal to a class 2 unit is deasserted when the CPM controller enable bit for that unit is reset, or when the unit deasserts its Sleep\_Req signal.
- The CPM class 3 interface has a CPM\_SleepInit signal that is asserted by the CPM controller to request that a functional unit go to sleep. If the unit can sleep, it asserts the Sleep\_Req signal to the CPM controller. The CPM\_Sleep\_N signal is then asserted by the CPM controller to shut off the class 3 clocks in the functional unit. The functional unit or the CPM controller can end the sleep state. If the CPM controller enable bit for the unit is reset, the CPM controller immediately deasserts CPM\_SleepInit and CPM\_Sleep\_N.

# 13.1 CPM Registers

Table 13-1 lists the registers used to program the CPM controller.

| Register Name | DCR Address | Access     | Reset Value (0:16)<br>(bits 17:31 reserved) |
|---------------|-------------|------------|---------------------------------------------|
| CPC0_ER       | 0x0B9       | Read/Write | 0x0000xxxx                                  |
| CPC0_FR       | 0x0BA       | Read/Write | 0x0000xxxx                                  |
| CPC0_SR       | 0x0B8       | Read Only  | 0xFFFFxxxx                                  |

Table 13-1. CPM Registers

Each functional unit has one bit in each of CPC0\_ER, CPC0\_FR, and CPC0\_SR. The bit assignment is the same in the three registers. Figure 13-1 shows the bit assignment and CPM class for each PPC405GP functional units.



| 0     | IIC        | IIC Interface                        | Class 3 |
|-------|------------|--------------------------------------|---------|
| 1     | PCI        | PCI Bridge                           | Class 3 |
| 2     | CPU        | PPC405GP Processor Core              | Class 2 |
| 3     | DMA        | DMA Controller                       | Class 2 |
| 4     | BRG        | PLB to OPB Bridge                    | Class 2 |
| 5     | DCP        | CodePack                             | Class 2 |
| 6     | EBC        | ROM/SRAM Peripheral Controller       | Class 2 |
| 7     | SDRAM      | SDRAM Memory Controller              | Class 2 |
| 8     | PLB        | PLB Bus Arbiter                      | Class 2 |
| 9     | GPIO       | General Purpose Interrupt Controller | Class 1 |
| 10    | UART0      | Serial Port 0                        | Class 1 |
| 11    | UART1      | Serial Port 1                        | Class 1 |
| 12    | UIC        | Universal Interrupt Controller       | Class 1 |
| 13    | CPU_TMRCLK | CPU Timers                           | Class 1 |
| 14    | EMAC_MM    | Ethernet MM Unit                     | Class 1 |
| 15    | EMAC_RM    | Ethernet RM Unit                     | Class 1 |
| 16    | EMAC_TM    | Ethernet TM Unit                     | Class 1 |
| 17:31 |            | Reserved                             |         |
|       |            |                                      |         |

| Figure 13-1. | CPM Registers | (CPC0 | ER. CPC0 | FR. CPC | 20 SR) |
|--------------|---------------|-------|----------|---------|--------|
|              |               |       |          |         |        |

.

### 13.1.1 CPM Enable Register (CPC0\_ER)

The CPC0\_ER bits enable the process of putting a functional unit to sleep. The class of a unit determines how its interface signals are controlled when the bit associated with the unit is set to 1.

- Class 1 When an associated CPC0\_ER bit is set to 1, the CPM\_Sleep\_N signal to the class 1 unit is asserted. When the bit is set to 0, CPM\_Sleep\_N is deasserted. There are some additional considerations to avoid generating extraneous interrupts when waking the UIC. Before enabling sleep mode (setting DPC0\_ER[UIC] to 1), save the contents of the UIC Masked Status Register (UIC\_MSR) and UIC Enable Register (UIC0\_ER), and disable all interrupts by setting UIC0\_ER to 0. After exiting sleep mode, write the ones complement of the saved contents of the UIC\_MSR to the UIC Status Register (UIC0\_SR), and restore the state of the UIC0\_ER.
- Class 2 When an associated CPC0\_ER bit is set to 1, and the Sleep\_Req signal from the class 2 unit is asserted (the unit is requesting sleep state), CPM\_Sleep\_N to the class 2 unit is asserted. When the bit is set to 0, the CPM\_Sleep\_N signal is deasserted.
- Class 3 When an associated CPC0\_ER bit is set to 1, the CPM\_SleepInit signal to the class 3 unit is asserted (the CPM controller is requesting permission to put the unit to sleep). When the class 3 unit activating the Sleep\_Req in response, (the unit is giving permission to be put to sleep), CPM\_Sleep\_N signal to the class 3 unit is asserted. When the bit is set to 0, CPM\_SleepInit and CPM\_Sleep\_N are deasserted.

# 13.1.2 CPM Force Register (CPC0\_FR)

Setting a CPC0\_FR bit forces assertion of the CPM\_Sleep\_N signal to the functional unit. For a class 1 unit, this is equivalent to setting the CPC0\_ER bit associated with the unit. For class 2 or class 3 units, CPM\_Sleep\_N is asserted regardless of the state of the Sleep\_Req signal coming from the unit.

### 13.1.3 CPM Status Register (CPC0\_SR)

The read-only CPC0\_SR shows the current state of all CPM\_Sleep\_N signals.

13-4 PPC405GP User's Manual

# **Chapter 14. Decompression Controller Operation**

The decompression controller enables PPC405GP instructions to be stored in memory in a compressed form, thus, reducing memory requirements and overall system cost. Because the processor core cannot execute compressed instructions, hardware is provided to decompress the compressed instructions. The decompression controller decompresses instructions on-the-fly, as the processor core fetches instructions from memory. The decompression unit is located in the path between memory and the processor core.

When decompressed instructions are stored in the instruction cache unit (ICU), the performance penalty is minimized. Increased latency occurs only when instruction fetches miss in the cache. Average latency is further reduced by a buffer in the decompression hardware that holds more instructions than are requested by the CPU. If a subsequent fetch occurs to a nearby memory location that is already in the buffer, data is returned from the buffer; no memory cycle is required. In such cases, initial latency is less than a normal uncompressed fetch from memory.

Code to be stored in compressed form is compressed by software after compiling and before loading. Thus, code compression can be performed once by the application developer. The compressed code is in the load image.

The decompression controller, located between the processor core and memory, is transparent to the processor core. When the processor core performs an instruction fetch, the decompression controller works with the memory controller (SDRAM or external bus controller [EBC]) to provide a decompressed instruction stream to the CPU. The memory controllers deliver the compressed stream of instructions to the decompression controller, which decompresses the instructions and delivers the resulting instruction stream to the processor core.

# 14.1 Code Compression and Decompression

While code decompression is performed in hardware when the processor core fetches instructions in a compressed code address space, code compression is performed only once, between the compile and load steps in the usual programming sequence.

### 14.1.1 Code Compression

Compression software analyzes compiled code, finds the set of most frequently used instructions, and builds decode tables from those instructions.

The compression software splits each instruction, analyzes the upper and lower halfwords of the instruction to find the most common 16-bit patterns. The most frequently used patterns are tagged for insertion in a decode table. Infrequently used instructions are tagged as not compressed. The 16-bit patterns that match those in the decode table are stored in the compressed code image, along with uncompressed instructions. The decode table is loaded into the decompression controller before attempted execution of the compressed instruction streams.

After the decode table is built, a compiled code image is compressed, using a scheme employing a tag and an index. The decompression controller generates an address into the decode table to select the original 16-bit pattern.

The compression software stores compressed and uncompressed instructions in 64-byte blocks, called compression blocks. The number of bytes used to store compressed code varies in each compression block, depending on the encoding. Because the length resulting compressed block varies, the compression software generates an index table that translates addresses of uncompressed 64-byte blocks, called target instruction addresses (TIAs), to addresses of the compressed variable length blocks. The index table also contains information indicating, for each block, whether the compression block was compressed or left uncompressed. The index table is loaded into system memory with the compressed blocks of program code. The decompression controller accesses the index table when a fetch is made to compressed program space.

### 14.1.2 Code Decompression

The decompression controller is located between the processor core and the SDRAM and EBC memory controllers, isolating the memory controllers from the processor local bus (PLB). The decompression controller is transparent to the processor core and the memory controllers. The processor core side of the decompression controller is a PLB slave to the PLB bus, and the memory controller side is a PLB master to the memory controllers. Instruction-side requests for external memory go though the decompression controller, and are either intercepted for decompression or allowed to pass through unaltered.

The decompression controller must distinguish between compressed and uncompressed code space. To accomplish this, the processor core provides a signal with each instruction memory reference, indicating whether the reference is in compressed or uncompressed memory space. The CPU's U0 storage attribute is used to implement this signal. When address translation is enabled (the IR field of the Machine State Register (MSR) is 1), a corresponding U0 bit is implemented in translation lookaside buffer (TLB) entries in the memory management unit (MMU). When address translation is disabled (MSR[IR] = 0, the Storage User-defined 0 Register (SU0R) implements the U0 storage attribute for memory regions. The U0 storage attribute indicates whether a page is marked as compressed.

#### 14.1.3 Instruction Fetches to Compressed Pages

The decompression controller intercepts instruction fetches to code in uncompressed pages, locates the compressed code in memory, and decompresses the instruction stream before forwarding it to the processor core. These steps are detailed in the following procedure:

- 1. Locate compressed code
  - a. Calculate offset into index table.
  - b. Retrieve index from index table.
  - c. Calculate address of compression block using the index table entry.
  - d. Retrieve compression block.
- 2. Decode instructions into the output buffer, if required.
- 3. Return instructions to the processor core.

The decompression controller contains a 64B output buffer that stores instruction words as they are decompressed. Because code is compressed and decompressed in 64B blocks and the CPU requests smaller line fills (32 bytes), some accesses to compressed instructions may already be available in the decompression controller output buffer, decompressed and ready for execution. In this case, line fill requests are serviced from the output buffer, without having to address external memory.

Step 2, above, indicates that compressed code is decoded "if required." Some compression blocks do not contain compressed code, even though they reside in compressed code space. The compression algorithm can infrequently result in blocks that are larger than the original code. In such cases, the compression software does not compress the instruction block and marks it as uncompressed. The decoder will not attempt to decompress such blocks.

### 14.1.4 Instruction Fetches to Uncompressed Pages

The decompression controller does not intercept instruction fetches to code in uncompressed memory space. These fetches are passed, unaltered, to the appropriate memory controller. The decompression controller also provides unaltered data, from the appropriate memory controller, back to the CPU in the case of a read. This transaction does not incur any additional latency.

#### 14.1.5 Performance

The decompression controller is designed so that read/write requests to uncompressed memory spaces incur no additional latency over a system without a decompression controller.

The decompression controller adds additional latency to some read accesses to compressed memory space. The decompression controller requires additional cycles to locate compressed code, fetch it, decode the instructions, and place them in the output buffer. However, because instructions are encoded in 64-byte compression blocks, the decompression controller continues to decompress instructions until its 64-byte output buffer is full. In such cases, the decompression controller acts as a prefetch buffer, and subsequent fetches to instructions in the same 64-byte block actually incur less latency than if the decompression controller were not present.

More significant latencies occur when the processor core executes a branch out of the current 64byte block. If the branch is to a TIA that is not at the beginning of a 64-byte block, the decompression controller must fetch and decode the block containing the TIA, byte by byte, until it reaches the desired instruction. The worst latencies occur when the TIA is outside of the 128-byte group, since the decompression core must then go through its entire decode process, including a refetch of the index table entry.

# 14.2 Decompression Controller Registers

The registers that control operation of the decompression controller, listed in Table 14-1, are indirectly accessed using the Decompression Controller Address Register (DCP0\_CFGADDR) and Decompression Controller Data Register (DCP0\_CFGDATA) listed in Table 14-2. The DCP0\_CFGADDR and DCP0\_CFGDATA are accessed using the **mfdcr** and **mtdcr** instructions.

Descriptions of the registers follow Table 14-2.

The DCP0\_CFGADDR stores the address of the target register, while the DCP0\_CFGDATA register is used to write or read the target register contents.

The following procedure accesses the decompression controller registers.

- 1. Write the offset from Table 14-2 to the Decompression Controller Address Register (DCP0\_CFGADDR).
- 2. Read data from or write data to the Decompression Controller Data Register (DCP0\_CFGDATA).

| Table 14-1. | DCRs Used to | Access the | Decompression | Controller Registers |
|-------------|--------------|------------|---------------|----------------------|
|             |              |            |               |                      |

| Register     | DCR<br>Address | Access | Description                               |
|--------------|----------------|--------|-------------------------------------------|
| DCP0_CFGADDR | 0x014          | R/W    | Decompression Controller Address Register |
| DCP0_CFGDATA | 0x015          | R/W    | Decompression Controller Data Register    |

#### Table 14-2. Offsets for Decompression Controller Registers

| Register                  | Offset      | R/W     | Description                                     |
|---------------------------|-------------|---------|-------------------------------------------------|
| DCP0_ITOR0                | 0x00        | R/W     | Index Table Origin Register 0                   |
| DCP0_ITOR1                | 0x01        | R/W     | Index Table Origin Register 1                   |
| DCP0_ITOR2                | 0x02        | R/W     | Index Table Origin Register 2                   |
| DCP0_ITOR3                | 0x03        | R/W     | Index Table Origin Register 3                   |
| DCP0_ADDR0                | 0x04        | R/W     | Address Decode Definition Register 0            |
| DCP0_ADDR1                | 0x05        | R/W     | Address Decode Definition Register 1            |
| DCP0_CFG                  | 0x40        | R/W     | Decompression Controller Configuration Register |
| DCP0_ID                   | 0x41        | R       | Decompression Controller ID Register            |
| DCP0_VER                  | 0x42        | R       | Decompression Controller Version Register       |
| DCP0_PLBBEAR              | 0x50        | R       | Bus Error Address Register (PLB)                |
| DCP0_MEMBEAR              | 0x51        | R       | Bus Error Address Register (EBC/SDRAM)          |
| DCP0_ESR                  | 0x52        | R/Clear | Bus Error Status Register 0 (Masters 0-3)       |
| DCP0_RAM0-<br>DCP0_RAM3FF | 0x400-0x7FF | R/W     | SRAM/ROM Read/Write                             |

### 14.2.1 Index Table Origin Registers (DCP0\_ITOR0-DCP0\_ITOR3)

DCP0\_ITOR0-DCP0\_ITOR3 each contain the high-order address bits of the index table for a compression region.



#### Figure 14-1. Decompression Index Table Origin Registers (DCP0\_ITOR0-DCP0\_ITOR3)

| 0:20  |     | Reserved           |                                     |
|-------|-----|--------------------|-------------------------------------|
| 21:31 | ΙΤΟ | Index Table Origin | High-order index table address bits |

## 14.2.2 Decompression Address Decode Definition Registers (DCP0\_ADDR0-DCP0\_ADDR1)

DCP0\_ADDR0-DCP0\_ADDR1 each define an address space used by the decompression controller for compressed instructions, and for uncompressed accesses that are passed to a memory controller.



Figure 14-2. Decompression Address Decode Definition Registers (DCP0\_ADDR0-DCP0\_ADDR1)

| 0:9   | DRBA | Decode Region Base Address                                                                                                                                                            | High-order decode region address bits |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 10:11 |      | Reserved                                                                                                                                                                              |                                       |
| 12:15 | DRS  | Decode Region Size<br>0000–0100 Reserved<br>0101 4MB<br>0110 8MB<br>0111 16MB<br>1000 32MB<br>1001 64MB<br>1010 128MB<br>1011 256MB<br>1100 512MB<br>1101 1GB<br>1110 2GB<br>1111 4GB |                                       |
| 16:30 |      | Reserved                                                                                                                                                                              |                                       |
| 31    | DREN | Enable Decode Region<br>0 Decoding is disabled for region<br>1 Decoding is enabled for region.                                                                                        |                                       |

#### 14.2.3 Decompression Configuration Register (DCP0\_CFG)

DCP0\_CFG is used to configure the operation of the decompression controller.

DCP0\_CFG[IKB] must be set to 0 to enable decompression. The value of this field determines whether the U0 storage attribute is recognized; the storage attribute must be recognized for decompression to occur.



Figure 14-3. Decompression Controller Configuration Register (DCP0\_CFG)

| 0:17  |      | Reserved                                                                                                                                                                                        |                                       |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 18:27 | SLDY | Sleep Delay                                                                                                                                                                                     | Sleep delay                           |
| 28    | SLEN | Sleep Enable<br>0 Disable sleep<br>1 Enable sleep                                                                                                                                               | •                                     |
| 29    | CDB  | Clear Decompression Buffer<br>0 Normal operation<br>1 Clear decompression buffer                                                                                                                | Self-clearing; always reads 0         |
| 30    |      | Reserved                                                                                                                                                                                        | · · · · · · · · · · · · · · · · · · · |
| 31    | КВ   | <ul> <li>Enable Decrompression</li> <li>0 Decompression is enabled; U0 storage<br/>attribute is recognized</li> <li>1 Decompression is disabled; U0 storage<br/>attribute is ignored</li> </ul> |                                       |

# 14.2.4 Decompression Controller ID Register (DCP0\_ID)

DCP0\_ID contains the decompression controller ID.

| - |   | <br> |      |      |
|---|---|------|------|------|
|   | 0 |      |      | 31   |
|   |   | <br> | <br> | <br> |

#### Figure 14-4. Decompression Controller ID Register (DCP0\_ID)

| 0:31 | Decompression Controller ID | Read-only, value is 0000504D |
|------|-----------------------------|------------------------------|
|      |                             |                              |

## 14.2.5 Decompression Controller Version Register (DCP0\_VER)

DCP0\_VER contains the decompression controller version.

| Figure 14-5. | Decompression Controller | r Version Register (DCP | 0_VER) |
|--------------|--------------------------|-------------------------|--------|

| 0:31 | Decompression Controller Version | Read-only, value is 00000200 |
|------|----------------------------------|------------------------------|

#### 14.2.6 Decompression Controller PLB Error Address Register (DCP0\_PLBBEAR)

On an error, DCP0\_PLBBEAR contains the address on the PLB that caused the decompression controller to generate cycles to the SDRAM and EBC memory controllers.

#### Figure 14-6. Decompression Controller PLB Error Address Register (DCP0\_PLBBEAR)

| 0:31 | Address of PLB Error |
|------|----------------------|
| 0.0. |                      |
|      |                      |

#### 14.2.7 Decompression Controller Bus Error Address Register (DCP0\_MEMBEAR)

On an error, DCP0\_MEMBEAR contains the address, presented to the memory controllers, that caused an error in the decompression controller. The address was presented to the memory controllers for either an ITE fetch or a block burst request.

|   |  | 04       |
|---|--|----------|
|   |  | 311      |
| • |  | <b>.</b> |
|   |  |          |

#### Figure 14-7. Decompression Controller Bus Error Address Register (DCP0\_MEMBEAR)

|  | 0:31 Address of SDRAM or EBC Error |
|--|------------------------------------|
|--|------------------------------------|

#### 14.2.8 Decompression Controller Error Status Register 0 (DCP0\_ESR)

DCP0\_ESR reports error status.

0

31

Status information includes error type and master read/write status. DCP0\_ESR0 field and DCP0\_PLBBEAR or DCP0\_MEMBEAR lock status is also reported.



| Figure 14-8. | Decompression | Controller E | Error Status | <b>Register 0</b> | (DCP0 | ESR) |
|--------------|---------------|--------------|--------------|-------------------|-------|------|
|              |               |              |              | J                 | ·     |      |

| 0:2 | DETO | Decompression Error Type for Master 0<br>000 Time-out during ITE fetch<br>001 Time-out during block fetch<br>010 Memory controller error during ITE<br>fetch<br>011 Memory controller error during block<br>fetch<br>100–111 Reserved | Master 0 is the processor core instruction cache unit (ICU).                                                                                              |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RW0  | Read/Write Status for Master 0<br>0 Error operation was a write<br>1 Error operation was a read                                                                                                                                       | This implementation only reports errors for<br>compressed reads.                                                                                          |
| 4   | FLO  | DCP0_ESR Field Lock for Master 0<br>0 DCP0_ESR fields are unlocked<br>1 DCP0_ESR fields are locked                                                                                                                                    | DCP0_ESR register fields are locked when<br>the PLB_lockErr signal was active in the<br>cycle in which the error occurred.                                |
| 5   | ALO  | DCP0_MEMBEAR/DCP0_PLBBEAR<br>Address Lock for Master 0<br>0 Master has not locked<br>DCP0_MEMBEAR and<br>DCP0_PLBBEAR<br>1 Master has locked DCP0_MEMBEAR<br>and DCP0_PLBBEAR                                                         | DCP0_MEMBEAR and DCP0_PLBBEAR<br>are locked to this master address when the<br>PLB_lockErr signal was active in the cycle<br>in which the error occurred. |
| 6:8 | DET1 | Decompression Error Type for Master 1                                                                                                                                                                                                 | See description for DCP0_ESR[DET0].<br>Master1 is the processor core data cache<br>unit (DCU).                                                            |
| 9   | RW1  | Read/Write Status for Master 1<br>0 Error operation was a write<br>1 Error operation was a read                                                                                                                                       | This implementation only reports errors for<br>compressed reads.                                                                                          |
| 10  | FL1  | DCP0_ESR Field Lock for Master 1<br>0 DCP0_ESR fields are unlocked<br>1 DCP0_ESR fields are locked                                                                                                                                    | DCP0_ESR register fields are locked when<br>the PLB_lockErr signal was active in the<br>cycle in which the error occurred.                                |
| 11  | AL1  | DCP0_MEMBEAR/DCP0_PLBBEAR<br>Address Lock for Master 1<br>0 Master has not locked<br>DCP0_MEMBEAR and<br>DCP0_PLBBEAR<br>1 Master has locked DCP0_MEMBEAR<br>and DCP0_PLBBEAR                                                         | DCP0_MEMBEAR and DCP0_PLBBEAR<br>are locked to this master address when the<br>PLB_lockErr signal was active in the cycle<br>in which the error occurred. |

| 12:14 | DET2                                                                                                      | Decompression Error Type for Master 2                                                                                                                                         | See description for DCP0_ESR[DET0].<br>Master 2 is the external master.                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | RW2                                                                                                       | Read/Write Status for Master 2<br>0 Error operation was a write<br>1 Error operation was a read                                                                               | This implementation only reports errors for compressed reads.                                                                                             |
| 16    | 16 FL2 DCP0_ESR Field Lock for Master 2<br>0 DCP0_ESR fields are unlocked<br>1 DCP0_ESR fields are locked |                                                                                                                                                                               | DCP0_ESR register fields are locked when<br>the PLB_lockErr signal was active in the<br>cycle in which the error occurred.                                |
| 17    | AL2                                                                                                       | DCP0_MEMBEAR/DCP0_PLBBEAR<br>Address Lock for Master 2<br>0 Master has not locked<br>DCP0_MEMBEAR and<br>DCP0_PLBBEAR<br>1 Master has locked DCP0_MEMBEAR<br>and DCP0_PLBBEAR | DCP0_MEMBEAR and DCP0_PLBBEAR<br>are locked to this master address when the<br>PLB_lockErr signal was active in the cycle<br>in which the error occurred. |
| 18:20 | DET3                                                                                                      | Decompression Error Type for Master 3                                                                                                                                         | See description for DCP0_ESR[DET0].<br>Master 3 is PCI.                                                                                                   |
| 21    | RW3 Read/Write Status for Master 3<br>0 Error operation was a write<br>1 Error operation was a read       |                                                                                                                                                                               | This implementation only report errors for compressed reads.                                                                                              |
| 22    | FL3                                                                                                       | DCP0_ESR Field Lock for Master 3<br>0 DCP0_ESR fields are unlocked<br>1 DCP0_ESR fields are locked                                                                            | DCP0_ESR register fields are locked when<br>the PLB_lockErr signal was active in the<br>cycle in which the error occurred.                                |
| 23    | AL3                                                                                                       | DCP0_MEMBEAR/DCP0_PLBBEAR<br>Address Lock for Master 3<br>0 Master has not locked<br>DCP0_MEMBEAR and<br>DCP0_PLBBEAR<br>1 Master has locked DCP0_MEMBEAR<br>and DCP0_PLBBEAR | DCP0_MEMBEAR and DCP0_PLBBEAR<br>are locked to this master address when the<br>PLB_lockErr signal was active in the cycle<br>in which the error occurred. |
| 24:31 |                                                                                                           | Reserved                                                                                                                                                                      |                                                                                                                                                           |

For more information, refer to CodePack<sup>™</sup> PowerPC Code Compression Utility User's Manual, Version 3.0.

14-10 PPC405GP User's Manual

Part IV. PPC405GP External Interfaces

IV-2 PPC405GP User's Manual

# **Chapter 15. SDRAM Controller**

The SDRAM controller provides a 32-bit interface to SDRAM memory with optional Error Checking and Correction (ECC). The memory controller provides flexible, fully programmable timings for interfacing to a wide variety of SDRAM devices. It supports four physical banks of dual- or quad-bank SDRAMs, where each physical bank is from 4 MB to 256 MB in size. In addition, the SDRAM controller supports the use of registered SDRAMs.

The controller supports page mode operation with bank interleaving and maintains up to four open pages. To improve performance, the controller features separate 32-byte read and 128-byte write buffers. For applications where data integrity must be guaranteed, optional ECC provides standard single error correction and double error detection. Designers also have the opportunity to reduce system power by placing the SDRAM controller in sleep and/or self-refresh mode.

# 15.1 Interface Signals

In many systems the memory controller can directly interface to SDRAM, relieving designers from the need to buffer signals or add circuitry to phase adjust the SDRAM clock. However, since each application is different, a detailed timing analysis should always be performed. Please note that all of the signals on the SDRAM interface utilize industry standard bit and byte lane numbering. That is, MemData0 is the least significant bit and DQM0 is the enable for the MemData7:0.

Figure 15-1 illustrates the SDRAM signal I/Os.





The usage and signal state after a PPC405GP reset for each of these signals is shown in Table 15-1 on page 15-2.

| Signal                                                      | Reset State           | Usage                                                                                                                                                                                          |  |
|-------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MemClkOut1:0                                                | Toggling <sup>1</sup> | Two copies of the SDRAM clock.                                                                                                                                                                 |  |
| ClkEn1:0                                                    | 1                     | SDRAM clock enable.                                                                                                                                                                            |  |
| BA1:0                                                       | 2'b0                  | Bank address. Used to select an internal SDRAM bank in dual- and quad-bank SDRAM devices.                                                                                                      |  |
| MemAddr12:0                                                 | 13b'0                 | Memory address. See Table 15.3.5, "Logical Address to Memory<br>Address Mapping," on page 15-8 for additional details.                                                                         |  |
| BankSel3:0                                                  | 4b'1                  | Bank Selects. Used to select between different physical banks of SDRAM memory.                                                                                                                 |  |
| RAS         1         Row Address Strobe.                   |                       | Row Address Strobe.                                                                                                                                                                            |  |
| CAS         1         Column Address Strobe.                |                       | Column Address Strobe.                                                                                                                                                                         |  |
| WE 1 Write Enable.                                          |                       | Write Enable.                                                                                                                                                                                  |  |
| MemData31:0 High-Z Data input/output. MemData31 is the most |                       | Data input/output. MemData31 is the most significant bit.                                                                                                                                      |  |
| during read operations. DQM3 applies to MemData31:2         |                       | Data Mask, an input mask for write accesses and an output enable<br>during read operations. DQM3 applies to MemData31:24, DQM2 to<br>MemData23:16, DQM1 to MemData15:8 and DQM0 to MemData7:0. |  |
| ECC7:0                                                      | High-Z                | ECC check bits.                                                                                                                                                                                |  |
| DQMCB                                                       | 1                     | Data Mask for ECC check bits.                                                                                                                                                                  |  |

Table 15-1. SDRAM Signal Usage and State During/Following Reset

Note 1: During power-up, MemClkOut1:0 tracks SysClk until the internal PLL begins to lock. At that time MemClkOut1:0 transitions to the clock rate configured via the strapping resistors.

# 15.2 Accessing SDRAM Registers

After a system reset, software is required to configure and then enable the SDRAM controller. When this is complete, the SDRAM memory is ready for access by the processor, or any other master in the PPC405GP. Once the controller is operating, it is usually not necessarily for software to access the SDRAM configuration registers. The status registers, however, are useful for determining the state of the memory controller or querying information regarding any corrected or uncorrectable ECC errors that may have occurred.

All SDRAM configuration and status registers are accessed using the **mtdcr** and **mfdcr** PowerPC instructions. Access to these registers is performed using an indirect addressing method through the SDRAM0\_CFGADDR and SDRAM0\_CFGDATA registers.

| Register       | DCR Address | Access | Description                       |
|----------------|-------------|--------|-----------------------------------|
| SDRAM0_CFGADDR | 0x010       | R/W    | SDRAM Controller Address Register |
| SDRAM0_CFGDATA | 0x011       | R/W    | SDRAM Controller Data Register    |

Table 15-2. SDRAM Controller DCR Addresses

Table 15-3 lists the indirectly accessed SDRAM configuration and status registers.

| Mnemonic      | Address Offset Acce |         | Description                          | Page  |
|---------------|---------------------|---------|--------------------------------------|-------|
| SDRAM0_BESR0  | 0x00                | R/Clear | Bus Error Syndrome Register 0        | 15-17 |
| SDRAM0_BESR1  | 0x08                | R/Clear | Bus Error Syndrome Register 1        | 15-18 |
| SDRAM0_BEAR   | 0x10                | R/W     | Bus Error Address Register           | 15-17 |
| SDRAM0_CFG    | 0x20                | R/W     | SDRAM Configuration                  | 15-3  |
| SDRAM0_STATUS | 0x24                | R       | SDRAM Controller Status              | 15-5  |
| SDRAM0_RTR    | 0x30                | R/W     | Refresh Timer Register               | 15-13 |
| SDRAM0_PMIT   | 0x34                | R/W     | Power Management Idle Timer          | 15-20 |
| SDRAM0_B0CR   | 0x40                | R/W     | Memory Bank 0 Configuration Register | 15-6  |
| SDRAM0_B1CR   | 0x44                | R/W     | Memory Bank 1 Configuration Register | 15-6  |
| SDRAM0_B2CR   | 0x48                | R/W     | Memory Bank 2 Configuration Register | 15-6  |
| SDRAM0_B3CR   | 0x4C                | R/W     | Memory Bank 3 Configuration Register | 15-6  |
| SDRAM0_TR     | 0x80                | R/W     | SDRAM Timing Register                | 15-9  |
| SDRAM0_ECCCFG | 0x94                | R/W     | ECC Configuration                    | 15-14 |
| SDRAM0_ECCESR | 0x98                | R       | ECC Error Status                     | 15-16 |

 Table 15-3.
 SDRAM Controller Configuration and Status Registers

To read or write one of these SDRAM controller registers, software must first write the register's address offset into the SDRAM0\_CFGADDR register. The target register can then be read or written through the SDRAM0\_CFGDATA DCR address. The following PowerPC code illustrates this procedure by reading the SDRAM0\_CFG register.

| li    | r3,SDRAM0_CFG     | ! address offset of SDRAM0_CFG |
|-------|-------------------|--------------------------------|
| mtdcr | SDRAM0_CFGADDR,r3 | ! set offset address           |
| mfdcr | r4,SDRAM0_CFGDATA | ! read value of SDRAM0_CFG     |

**Programming Note:** Reserved fields in SDRAM controller configuration registers must not change when the register is written. To modify bit fields within a register, read the register, use a mask to clear the target bits, OR in the new field value, and then write the result back.

# 15.3 SDRAM Controller Configuration and Status

Software must program a number of SDRAM control registers before the SDRAM controller can be started and memory accessed. At a minimum, this involves writing to the SDRAM Configuration Register (SDRAM0\_CFG), SDRAM Timing Register (SDRAM0\_TR) and one or more Memory Bank Configuration Registers (SDRAM0\_BnCR).

# 15.3.1 Memory Controller Configuration Register (SDRAM0\_CFG)

After a system reset the SDRAM controller is disabled and must be configured before memory transactions can occur. The Memory Controller Configuration Register (SDRAM0\_CFG) serves to both enable the controller and select from various memory controller features. These features include enabling power management, ECC error checking, and registered SDRAM support. Each of these settings is global and applies to the entire SDRAM subsystem.

Prior to enabling the SDRAM controller by setting SDRAM0\_CFG[DCE], the SDRAM0\_TR, SDRAM0\_PMIT, and SDRAM0\_BnCR registers must be configured. This is because

once SDRAM0\_CFG[DCE]=1 writing any of the listed SDRAM registers does not actually update the target register. Write access to SDRAM0\_CFG is independent of SDRAM0\_CFG[DCE]. However, software must ensure that the SDRAM controller is idle when updating SDRAM0\_CFG[3:10]. This guarantees that the register update does not affect any in-progress SDRAM operations.

Before software enables the SDRAM controller by setting SDRAM0\_CFG[DCE] it must ensure that the SDRAM power-on delay has been satisfied. For example, the IBM 16MB SDRAM requires a 100µs pause; the 64MB SDRAM requires a 200µs pause. Once enabled, the SDRAM controller automatically performs the following initialization procedure:

- 1. Issues the precharge command to all banks.
- 2. Waits SDRAM0\_TR[PTA] cycles.
- 3. Performs eight CAS before RAS refresh cycles, each separated by SDRAM0\_TR[RFTA] clock cycles)
- 4. Issues the mode register write command to each bank.
- 5. Perform eight CAS before RAS refresh cycles (each separated by SDRAM0\_TR[RFTA] clock cycles).
- 6. Waits SDRAM0\_TR[RFTA] clock cycles.

The SDRAM is then available for read and write access.



| 0 | DCE    | SDRAM Controller Enable<br>0 Disable<br>1 Enable    | All SDRAM controller configuration<br>registers must be initialized and valid prior to<br>setting DCE. |
|---|--------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| 1 | SRE    | Self-Refresh Enable<br>0 Disable<br>1 Enable        | See "Self-Refresh" on page 15-19.                                                                      |
| 2 | PME    | Power Management Enable<br>0 Disable<br>1 Enabled   | See "Power Management" on page 15-20.                                                                  |
| 3 | МЕМСНК | Memory Data Error Checking<br>0 None<br>1 ECC       | See "Error Checking and Correction (ECC)" on page 15-14.                                               |
| 4 | REGEN  | Registered Memory Enable<br>0 Disabled<br>1 Enabled |                                                                                                        |

Figure 15-2. Memory Controller Configuration (SDRAM0\_CFG)

| 5:6   | DRW    | SDRAM Width<br>00 32-bit<br>01 Reserved<br>10 Reserved<br>11 Reserved                                                                                                           | Must be set to 2'b00.                                                                                                                                                                      |
|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:8   | BRPF   | Burst Read Prefetch Granularity<br>00 Reserved<br>01 16 bytes<br>10 32 bytes<br>11 Reserved                                                                                     | Most applications should set with field to 2'b01.                                                                                                                                          |
| 9     | ECCDD  | ECC Driver Disable<br>0 Check bit data output on ECC7:0.<br>1 ECC7:0 are placed in high-Z state.                                                                                | Regardless of whether ECC checking is<br>enabled, SDRAM writes cause the<br>PPC405GP to output check bit data on<br>ECC7:0. If ECC is not used, setting<br>ECCDD=1 disables these drivers. |
| 10    | EMDULR | Enable Memory Data Unless Read<br>0 MemData0:31 are high-Z unless a<br>memory write is being performed.<br>1 MemData0:31 are driven unless a<br>memory read is being performed. | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                      |
| 11:31 |        | Reserved                                                                                                                                                                        |                                                                                                                                                                                            |

# 15.3.2 Memory Controller Status (SDRAM0\_STATUS)

The Memory Controller Status Register (SDRAM0\_STATUS) allows software to determine the current state of the SDRAM controller. If SDRAM0\_STATUS[MRSCMP]=0 the SDRAM is not accessible for either read or write operations. Similarly, the SDRAM is also inaccessible when the SDRAM is in self-refresh mode, SDRAM0\_STATUS[SRSTATUS]=1.



| 0    | MRSCMP   | Mode Register Set Complete<br>0 MRS not complete<br>1 MRS completed     | Set to 1 when the SDRAM controller completes<br>the Mode Register Set Command, which results<br>from setting SDRAM0_CFG[DCE].<br>Clearing SDRAM0_CFG[DCE] causes this bit to<br>clear in the following MemClkOut1:0 cycle. |
|------|----------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | SRSTATUS | Self-Refresh State<br>0 Not in Self-Refresh Mode<br>1 Self-Refresh Mode | See "Self-Refresh" on page 15-19.                                                                                                                                                                                          |
| 2:31 |          | Reserved                                                                |                                                                                                                                                                                                                            |

| Figure 15-3. | Memory Controller Status (SDR | AMO STATUS) |
|--------------|-------------------------------|-------------|
|              |                               |             |

#### 15.3.3 Memory Bank 0–3 Configuration (SDRAM0\_B0CR–SDRAM0\_B3CR)

These registers are used to configure and enable memory in each respective bank. Only SDRAM banks with SDRAM0\_BnCR[BE]=1 are initialized when SDRAM0\_CFG[DCE] is set to 1 and subsequently available for access. Since the SDRAM0\_BnCR registers cannot be modified when SDRAM0\_CFG[DCE]=1, adding or removing memory banks requires that the SDRAM controller be disabled and then reinitialized.



Figure 15-4. Memory Bank 0–3 Configuration Registers (SDRAM0\_B0CR–SDRAM0\_B3CR)

| 0:9   | BA | Base Address                                                                                                                         | The base address must be aligned on<br>a boundary that matches the size of<br>the region as defined by the SZ field.<br>For example, a 4MB region must begin<br>on an address that is divisible by 4MB. |
|-------|----|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:11 |    | Reserved                                                                                                                             |                                                                                                                                                                                                         |
| 12:14 | SZ | Size<br>000 4M byte<br>001 8M byte<br>010 16M byte<br>011 32M byte<br>100 64M byte<br>101 128M byte<br>110 256M byte<br>111 Reserved |                                                                                                                                                                                                         |
| 15    |    | Reserved                                                                                                                             |                                                                                                                                                                                                         |
| 16:18 | АМ | Addressing Mode<br>000 Mode 1<br>001 Mode 2<br>010 Mode 3<br>011 Mode 4<br>100 Mode 5<br>101 Mode 6<br>110 Mode 7<br>111 Reserved    | See "SDRAM Addressing Modes" on page 15-7.                                                                                                                                                              |
| 19:30 |    | Reserved                                                                                                                             | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                   |
| 31    | BE | Memory Bank Enable<br>0 Bank is disabled<br>1 Bank is enabled                                                                        |                                                                                                                                                                                                         |

| Addressing<br>Mode | SDRAM<br>Memory Organization                            |
|--------------------|---------------------------------------------------------|
| 1                  | 11 x 9 - 2 Bank<br>11 x 10 - 2 Bank                     |
| 2                  | 12 x 9 - 4 Bank<br>12 x 10 - 4 Bank                     |
| 3                  | 13 x 9 - 4 Bank<br>13 x 10 - 4 Bank<br>13 x 11 - 4 Bank |
| 4                  | 12 x 8 - 2 Bank<br>12 x 8 - 4 Bank<br>13 x 8 - 2 Bank   |
| 5                  | 11 x 8 - 2 Bank<br>11 x 8 - 4 Bank                      |
| 6                  | 13 x 8 - 2 Bank<br>13 x 8 - 4 Bank                      |
| 7                  | 13 x 9 - 2 Bank<br>13 x 10 - 2 Bank                     |

Table 15-4. SDRAM Addressing Modes

#### 15.3.4 Page Management

The SDRAM controller supports page mode operation with bank interleaving and maintains up to four open pages in the memory subsystem. The SDRAM controller page management unit (PMU) tracks memory accesses (activate, read/write, precharge, and refresh) and maintains a directory of up to four open pages. All PMU entries are allocated and deallocated based on current and pending accesses. Allocated entries are checked against the address of the pending access, and a page hit occurs when a match exists. All PMU directory entries are deallocated when a CAS before RAS refresh occurs.

Open pages can be spread across the system memory array on different bank selects (BankSeln) or be contained in a single bank select, depending on the memory access sequences and the memory subsystem implementation. For a single bank memory subsystem, the number of open pages is limited to the number of internal banks associated with the SDRAM devices in that bank. For example, a single bank implementation consisting of SDRAMs with two internal banks can have two open pages. In this case, the maximum of two open pages is a limitation of the memory subsystem implementation, not the SDRAM controller.

The SDRAM page size for page hits varies, depending on the address mode programmed in SDRAM0\_BnCR[AM]. Table 15-5, "SDRAM Page Size," on page 15-7 details the relationship of the address mode to the page size.

| Address Mode | Page Size |
|--------------|-----------|
| 1,2,3,7      | 2 KB      |
| 4,5,6        | 1 KB      |

## 15.3.5 Logical Address to Memory Address Mapping

SDRAM memory requires that addresses be divided into row and column portions. The relationship between a logical address and the SDRAM row and column address is determined by the address mode programmed in SDRAM0\_BnCR[AM] and is shown in Table 15-6.

|      | Bank Size                 | Address | В | A  | MemAddr |                |    |    |    |    |    |    |    |    |    |    |    |
|------|---------------------------|---------|---|----|---------|----------------|----|----|----|----|----|----|----|----|----|----|----|
| Mode | Organization <sup>1</sup> | Phase   | 1 | 0  | 12      | 11             | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 1    | 8 MB                      | Row     | 7 | 9  | 7       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 11 x 9 x 2                | Column  | 7 | 9  | 7       | 9              | AP | 8  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
|      | 16 MB                     | Row     | 7 | 9  | 7       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 11 x 10 x 2               | Column  | 7 | 9  | 7       | 9              | AP | 8  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 2    | 32 MB                     | Row     | 7 | 8  | 7       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 12 x 9 x 4                | Column  | 7 | 8  | 7       | 4              | AP | 6  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
|      | 64 MB                     | Row     | 7 | 8  | 7       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 12 x 10 x 4               | Column  | 7 | 8  | 7       | 4              | AP | 6  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 3    | 64 MB                     | Row     | 6 | 7  | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 9 x 4                | Column  | 6 | 7  | 7       | 4              | AP | 5  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
|      | 128 MB                    | Row     | 6 | 7  | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 10 x 4               | Column  | 6 | 7  | 7       | 4              | AP | 5  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
|      | 256 MB                    | Row     | 6 | 7  | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 11 x 4               | Column  | 6 | 7  | 7       | 4 <sup>2</sup> | AP | 5  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 4    | 8/16 MB                   | Row     | 8 | 21 | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 12 x 8 x 2/4              | Column  | 8 | 21 | 8       | 4              | AP | 6  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 5    | 4/8 MB                    | Row     | 9 | 21 | 9       | 21             | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 11 x 8 x 2/4              | Column  | 9 | 21 | 9       | 21             | AP | 8  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 6    | 16/32 MB                  | Row     | 7 | 21 | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 8 x 2/4              | Column  | 7 | 21 | 8.      | 9              | AP | 8  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 7    | 32 MB                     | Row     | 7 | 7  | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 9 x 2                | Column  | 7 | 7  | 7       | 4              | AP | 6  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
|      | 64 MB                     | Row     | 7 | 7  | 8       | 9              | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
|      | 13 x 10 x 2               | Column  | 7 | 7  | 7       | 4              | AP | 6  | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |

Table 15-6. Logical Address Bit on BA1:0 and MemAddr12:0 Versus Addressing Mode.

Note 1: Memory organization is the number of rows x columns x internal banks.

Note 2: Column address bit 10 sent out on MemAddr11 for 13 x 11 x 4 parts.

Note 3: All read operations transfer 64-bits from SDRAM memory to the controller. Therefore, MemAddr0 is first driven with 0 and then 1. For data items narrower than 64-bits, the requested byte(s) are fulfilled from the 64-bit doubleword.

### 15.3.6 SDRAM Timing Register (SDRAM0\_TR)

The SDRAM Timing Register sets the timing parameters for all SDRAM memory banks. This register must be written prior to setting SDRAM0\_CFG[DCE]. If SDRAM0\_CFG[DCE]=1, writes to this register appear to complete, but do not affect the contents of SDRAM0\_TR.

If the SDRAM interface is operated in registered mode, (SDRAM0\_CFG[REGE]=1) a programmed CAS latency of 2 clocks (SDRAM0\_TR[CASL] = 2'b01) corresponds to a registered CAS latency of 3 clocks, and a programmed latency of 3 clocks (SDRAM0\_TR[CASL] = 2'b10) corresponds to a registered CAS latency of 4 clocks. Programming the CAS latency to 4 clocks (SDRAM0\_TR[CASL] = 2'b11), corresponding to a registered CAS latency of 5 clocks, is not supported.

See "Selected Timing Diagrams" on page 15-10 for timing diagrams illustrating how the fields in SDRAM0\_TR affect the signalling on the SDRAM memory interface.



| 0:6   |      | Reserved                                                                                                                                                        |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:8   | CASL | SDRAM CAS latency.<br>00 Reserved<br>01 2 MemClkOut1:0 cycles<br>10 3 MemClkOut1:0 cycles<br>11 4 MemClkOut1:0 cycles                                           |
| 9:11  |      | Reserved                                                                                                                                                        |
| 12:13 | ΡΤΑ  | SDRAM Precharge Command to next<br>Activate Command minimum.<br>00 Reserved<br>01 2 MemClkOut1:0 cycles<br>10 3 MemClkOut1:0 cycles<br>11 4 MemClkOut1:0 cycles |
| 14:15 | CTP  | SDRAM Read / Write Command to<br>Precharge Command minimum.<br>00 Reserved<br>01 2 MemClkOut1:0 cycles<br>10 3 MemClkOut1:0 cycles<br>11 4 MemClkOut1:0 cycles  |
| 16:17 | LDF  | SDRAM Command Leadoff.<br>00 Reserved<br>01 2 MemClkOut1:0 cycles<br>10 3 MemClkOut1:0 cycles<br>11 4 MemClkOut1:0 cycles                                       |
| 18:26 |      | Reserved                                                                                                                                                        |

| Figure 15-5.  | SDRAM  | Timina | Register  | (SDRAMO | TR)       |
|---------------|--------|--------|-----------|---------|-----------|
| 1 19410 10 0. | ODIMAN |        | riegioter |         | _ • • • • |

| 27:29 | RFTA | SDRAM CAS before RAS Refresh<br>Command to next Activate Command<br>minimum.<br>000 4 MemClkOut1:0 cycles<br>001 5 MemClkOut1:0 cycles<br>010 6 MemClkOut1:0 cycles<br>011 7 MemClkOut1:0 cycles<br>100 8 MemClkOut1:0 cycles<br>101 9 MemClkOut1:0 cycles<br>110 10 MemClkOut1:0 cycles<br>111 Reserved |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:31 | RCD  | SDRAM RAS to CAS Delay<br>00 Reserved<br>01 2 MemClkOut1:0 cycles<br>10 3 MemClkOut1:0 cycles<br>11 4 MemClkOut1:0 cycles                                                                                                                                                                                |

## 15.3.7 Selected Timing Diagrams

The SDRAM controller is capable of performing many different types of read and write operations. For example, while the CPU generally issues four doubleword line fills and line writes, the EBC external master interface can issue various types of burst transactions. Since the SDRAM controller is often servicing read and write requests from several masters, the exact sequence of operations on the external SDRAM interface cannot be predicted. Therefore, the timing diagrams in this section should be considered as examples of the signalling that can be observed on the SDRAM interface, and not the only types of transactions that occur.

The timing diagrams in this section are intended to illustrate cycle-based SDRAM programmable timing parameters only. As such, AC specific timing information should not be inferred from the timing diagrams. Instead, please refer to the PPC405GP data sheet for AC specifications.

Table 15-7 summarizes the SDRAM memory timing parameters used to annotate the waveforms. These parameters are set in the SDRAM Timing Register (SDRAM0\_TR).

| Name | Function                          | Description                                                                                                                          |
|------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| RCD  | Activate to Read/Write<br>Command | Minimum number of clock cycles from an activate command to a read or write command. Corresponds to SDRAM RAS to CAS assertion delay. |
| RFTA | Refresh to Activate               | Minimum number of clock cycles from a $\overline{CAS}$ before $\overline{RAS}$ refresh command to the next activate command.         |
| СТР  | Command to<br>Precharge           | Minimum number of clock cycles from a read or write command to a precharge command.                                                  |
| PTA  | Precharge to Active               | Minimum number of clock cycles required to wait following a<br>Precharge Command to issuing the next activate command.               |
| CASL | CAS Latency                       | CAS access latency.                                                                                                                  |
| LDF  | Command Leadoff<br>Delay          | Number of clock cycles from address/command assertion to bank select (BankSeln) assertion.                                           |

Table 15-7. SDRAM Memory Timing Parameters















Figure 15-10. Self-Refresh Entry and Exit

# 15.3.8 Auto (CAS Before RAS) Refresh

Refresh of odd memory banks is staggered from the refresh of even memory banks. Only enabled SDRAM banks (SDRAM0\_BnCR[BE]=1) are initialized when the controller is enabled (SDRAM0\_CFG[DCE] set to 1) and refreshed during normal operation. Once the memory controller is enabled and the initialization sequence has completed, the refresh mechanism starts automatically with refreshing of the memory continuing independent of SDRAM0\_CFG[DCE].

Refresh requests are generated internally when the refresh timer expires. The refresh interval is programmable via the Refresh Timer Register (SDRAM0\_RTR). During refresh, all SDRAM accesses are delayed until the refresh cycle completes.

# 15.3.9 Refresh Timer Register (SDRAM0\_RTR)

The Refresh Timer Register determines the memory refresh rate for the SDRAM. The internal counter runs at the controller clock frequency, thus if MemClkOut1:0 is 100MHz, a value of 0x05F0 produces a refresh interval of 15.20 s ( $1520 \times 10 \text{ ns} = 15.20 \text{ s}$ ). This register is programmable to accommodate other SDRAM clock frequencies.



Figure 15-11. Refresh Timing Register (SDRAM0\_RTR)

| 0:1   |    | Always 0b00                                                                                                                      |                                                                              |
|-------|----|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 2:12  | IV | Interval<br>Programmable between 0b00000000000<br>and 0b1111111111 (that is, 0x0000 to<br>0x3FF8 for the complete 16-bit field). | Reset value is 0b00010111110 (that is, 0x05F0 for the complete 16-bit field) |
| 13:15 |    | Always 0b000                                                                                                                     |                                                                              |
| 16:31 |    | Reserved                                                                                                                         |                                                                              |

# **15.4 Error Checking and Correction (ECC)**

Error Checking and Correction (ECC) corrects all single bit errors and detects all double bit errors when reading from SDRAM memory. In addition, ECC detects any and all errors which may exist in an aligned 4-bit nibble. As detailed in Table 15-8, "Additional Latency when using ECC," on page 15-14, the ECC function is transparent in terms of latency, except for partial write operations. On partial writes, a read-modify-write sequence, including bus turn-around, is required to generate the write check bits and store the resultant data.

Table 15-8. Additional Latency when using ECC

| PLB Transaction                 | Added Latency              |  |
|---------------------------------|----------------------------|--|
| Read                            | None                       |  |
| Burst or full single beat write | None                       |  |
| Partial write                   | SDRAM0_TR[CASL] + 4 clocks |  |

ECC is enabled for all SDRAM banks by setting SDRAM0\_CFG[MEMCHK]=1 during the SDRAM initialization procedure. Software is then required to write each word of SDRAM to set the check bits to a valid state. When this is complete, ECC checking and correction is enabled on a per-bank basis through the SDRAM0\_ECCCFG register.

# 15.4.1 ECC Configuration Register (SDRAM0\_ECCCFG)

Write access to SDRAM0\_ECCCFG is independent of SDRAM0\_CFG[DCE]. Software must ensure that the SDRAM controller is idle when updating SDRAM0\_ECCCFG. This guarantees that the register update does not affect any in-progress SDRAM operations.



Figure 15-12. ECC Configuration Register (SDRAM0\_ECCCFG)

| 0:7   |     | Reserved                                                     |                                                                                                                                                                         |
|-------|-----|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:11  | CEn | ECC Correction Enable for bank n.<br>0 Disabled<br>1 Enabled | When CEn is set, ECC correction is<br>enabled for bank n (BankSeln). When<br>cleared, the ECC logic ignores the check<br>bits and passes read data along<br>unmodified. |
| 12:31 |     | Reserved                                                     |                                                                                                                                                                         |

#### 15.4.2 Correctable ECC Errors

During SDRAM memory read operations the ECC logic automatically detects and corrects any single bit error that occurs within each 32-bit word of SDRAM memory. This includes errors detected during the read portion of the read-modify-sequence sequence required for partial (less than 64-bit) SDRAM writes.

If a correctable ECC error occurs during a memory read the corrected data is returned to the requesting master. When a correctable error is detected during the read portion of a partial write the corrected data is combined with the write data and written back to memory with new ECC check bits. In both cases, the memory bank (BankSeln) that caused the error is logged in SDRAM0\_ECCESR[BKnE] and the byte lane that experienced the correctable error is identified in SDRAM0\_ECCESR[BLnCE]. Furthermore, the correctable error bit (SDRAM0\_ECCESR[CE]) is set causing an ECC Correctable Error interrupt to the Universal Interrupt Controller. The interrupt remains active until software clears SDRAM0\_ECCESR[CE].

#### 15.4.3 Uncorrectable ECC Errors

Uncorrectable ECC errors may occur during SDRAM read and SDRAM partial write operations. An uncorrectable error detected during a memory read results in the data from system memory (unchanged) being returned to the requesting master. An uncorrectable error detected on the read portion of a read-modify-write sequence for an SDRAM partial write results in the data from system memory (unchanged) being combined with the write data and written back to memory with new ECC check bits.

Whenever an uncorrectable ECC error occurs the errant memory address is captured in SDRAM0\_BEAR. The error status for the master that initiated the memory operation is logged in either SDRAM0\_BESR0 or SDRAM0\_BESR1. The memory bank (BanknSel) that experienced the error is recorded in SDRAM0\_ECCESR[BKnE] and an uncorrectable error is flagged via SDRAM0\_ECCESR[UE].

Since an uncorrectable error also results in an error signal to the master that initiated the transfer, other side effects may occur. For example, an instruction fetch with an uncorrectable error causes a machine check. In the case of a DMA transfer, the DMA channel stops and an error is logged.

#### 15.4.4 Error Locking

The PCI Bridge and Media Access Layer (MAL) controllers may qualify their PLB transactions to the SDRAM Controller such that the information describing any errors that occur during these transfers becomes locked. When an error is locked, subsequent errors are not permitted to overwrite the information detailing the first error.

When a master requests error locking an error locks not only the SDRAM0\_BESRn field for the master, but also SDRAM0\_BEAR. These remain locked until software clears them. The SDRAM Controller has a SDRAM0\_BESRn field for each PLB master containing two bits associated with error locking. One is the field lock bit and the other is the address lock bit. When an error is detected with locking enabled the field lock bit is set to a value of one. Setting the field lock bit prevents subsequent errors for this master from being logged and overwriting the contents of the field. In addition, the address lock bit is set if no other master has previously locked the SDRAM0\_BEAR. Once the SDRAM0\_BEAR is locked, no future errors from this or any master can update the SDRAM0\_BEAR until software clears the lock bits. When software processes an error it should clear the error status and both lock bits at the same time.

## 15.4.5 ECC Error Status Register (SDRAM0\_ECCESR)

The ECC Error Status Register (SDRAM0\_ECCESR) tracks ECC related errors encountered during SDRAM memory accesses. Bits in SDRAM0\_ECCESR are cleared by writing a 32-bit value to SDRAM0\_ECCESR with a 1 in any bit position that is to be cleared and 0 in all other bit positions.



#### Figure 15-13. ECC Error Status Register (SDRAM0\_ECCESR)

| 0:3   | BLnCE | Byte Lane n Corrected Error<br>0 No error<br>1 Error occurred in byte lane n                                                                       |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:7   |       | Reserved                                                                                                                                           |
| 8:9   | CBE   | Error Detected in Check bits<br>00 No error<br>01 Error in lower check bits<br>10 Error in upper check bits<br>11 Error in both sets of check bits |
| 10    | CE    | Correctable Error                                                                                                                                  |
| 11    | UE    | Uncorrectable Error                                                                                                                                |
| 12:15 |       | Reserved                                                                                                                                           |

| 16:19 | BKnE | Bank n Error<br>0 No error<br>1 Error occurred in bank n |
|-------|------|----------------------------------------------------------|
| 20:31 |      | Reserved                                                 |

# 15.4.6 Bus Error Address Register (SDRAM0\_BEAR)

The SDRAM Bus Error Address Register (SDRAM0\_BEAR) is a 32-bit register containing the address of the access where a correctable or uncorrectable ECC error occurred. If the master that initiated the transfer requested error locking, and the SDRAM0\_BEAR is not already locked, the contents of SDRAM0\_BEAR are locked until the lock bit in one of the Peripheral Bus Error Status Registers (SDRAM0\_BESR0 or SDRAM0\_BESR1) is cleared. The contents of the SDRAM0\_BEAR are accessed indirectly through the SDRAM\_CFGADDR and SDRAM0\_CFGDATA registers using the mfdcr and mtdcr instructions.



Figure 15-14. Bus Error Address Register (SDRAM0\_BEAR)

| 0:31 SDRAM0_BEAR Address of ECC Error. | 0:31 | SDRAM0_BEAR | Address of ECC Error. |
|----------------------------------------|------|-------------|-----------------------|
|----------------------------------------|------|-------------|-----------------------|

# 15.4.7 Bus Error Syndrome Register 0 (SDRAM0\_BESR0)

This register tracks errors encountered during CPU, external bus master and PCI accesses to SDRAM memory. Bits in SDRAM0\_BESR0 are cleared by writing a 32-bit value to SDRAM0\_BESR0 with a 1 in any bit position that is to be cleared and 0 in all other bit positions.



| Figure 15-15. B | us Error S | yndrome R | legister 0 ( | SDRAM0_ | BESR0) |
|-----------------|------------|-----------|--------------|---------|--------|
|-----------------|------------|-----------|--------------|---------|--------|

| 0:2 | EETO | Error type for master 0<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 0 is the processor instruction fetcher. |
|-----|------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| 3   | RWS0 | Read/write status for master 0<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                                |

| 4:5   |      | Reserved                                                                                                            |                                       |
|-------|------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 6:8   | EET1 | Error type for master 1<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 1 is the processor data side.  |
| 9     | RWS1 | Read/write status for master 1<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                       |
| 10:11 |      | Reserved                                                                                                            |                                       |
| 12:14 | EET2 | Error type for master 2<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 2 is the external bus master.  |
| 15    | RWS2 | Read/write status for master 2<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                       |
| 16:17 |      | Reserved                                                                                                            |                                       |
| 18:20 | EET3 | Error type for master 3<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 3 is the PCI bridge.           |
| 21    | RWS3 | Read/write status for master 3<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                       |
| 22    | FL3  | Field lock for master 3<br>0 EET3 and RWS3 fields are unlocked<br>1 EET3 and RWS3 fields are locked                 | · · · · · · · · · · · · · · · · · · · |
| 23    | AL3  | SDRAM0_BEAR address lock for master 3<br>0 SDRAM0_BEAR address unlocked<br>1 SDRAM0_BEAR address locked             |                                       |
| 24:31 |      | Reserved                                                                                                            |                                       |

# 15.4.8 Bus Error Syndrome Register 1 (SDRAM0\_BESR1)

This register tracks errors encountered during MAL and DMA accesses to SDRAM memory. Bits in SDRAM0\_BESR1 are cleared by writing a 32-bit value to SDRAM0\_BESR1 with a 1 in any bit position that is to be cleared and 0 in all other bit positions.



| 0:2   | EET4 | Error type for master 4<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 4 is the MAL.            |
|-------|------|---------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 3     | RWS4 | Read/write status for master 4<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                 |
| 4     | FL4  | Field lock for master 4<br>0 EET4 and RWS4 fields are unlocked<br>1 EET4 and RWS4 fields are locked                 |                                 |
| 5     | AL4  | SDRAM0_BEAR address lock for master 4<br>0 SDRAM0_BEAR address unlocked<br>1 SDRAM0_BEAR address locked             |                                 |
| 6:8   | EET5 | Error type for master 5<br>000 No error<br>001 Reserved<br>01X ECC uncorrectable error<br>1XX Reserved              | Master 5 is the DMA controller. |
| 9     | RWS5 | Read/write status for master 5<br>0 Error operation was a write operation<br>1 Error operation was a read operation |                                 |
| 10:31 |      | Reserved                                                                                                            |                                 |

## 15.5 Self-Refresh

The SDRAM controller supports self-refresh operation for applications desiring lower power. When the SDRAM memory is placed in self-refresh mode it is no longer accessible for read or write accesses. Prior to placing the SDRAM controller in self-refresh mode all pending and previously queued requests targeting the SDRAM controller must be allowed to complete. Self-refresh entry is then initiated by setting SDRAM0\_CFG[SRE]. When set, the SDRAM controller:

- 1. Completes the current SDRAM operation.
- 2. Issues precharge all commands to close all open pages.
- 3. Performs an auto-refresh cycle.
- 4. Enters self-refresh mode and sets SDRAM0\_STATUS[SRSTATUS].

The SDRAM controller maintains the SDRAM in self-refresh mode, independent of any pending memory access requests, until SDRAM0\_CFG[SRE] is cleared. Any attempt to read or write SDRAM memory during this time will stall the PLB.

Once SDRAM0\_CFG[SRE] is cleared, the SDRAM controller performs the following:

- 1. Exits self-refresh mode.
- 2. Performs an auto-refresh cycle.

3. Clears SDRAM0\_STATUS[SRSTATUS].

The SDRAM controller is then ready to service any memory request.

# 15.6 Power Management

The SDRAM controller provides a sleep mode where all SDRAM controller clocking is disabled with the exception of the SDRAM refresh logic and the power management wake-up logic. When the SDRAM controller is in sleep mode SDRAM refresh continues to preserve the contents of the memory and maintain the refresh interval.

## 15.6.1 Sleep Mode Entry

Sleep mode is enabled by setting SDRAM0\_CFG[PME] and CPM0\_ER[SDRAM]. Once sleep mode is enabled and the SDRAM controller has been idle for the number of cycles programmed in SDRAM0\_PMIT, the SDRAM controller goes to sleep.

## 15.6.2 Power Management Idle Timer (SDRAM0\_PMIT)

The SDRAM0\_PMIT register determines the number for SDRAM clock (MemClkOut1:0) cycles that the controller must be idle before it asserts a sleep request when power management is enabled (SDRAM0\_CFG[PME]=1). At system reset, SDRAM0\_PMIT[CNT] is set to zero. This corresponds to a sleep request after 32 idle cycles.



| Figure 15-17. | Power | Management I | alh  | Timor |         | DMIT) |
|---------------|-------|--------------|------|-------|---------|-------|
| Figure 15-17. | rower | managementi  | lule | 1 mer | SDRAWU_ |       |

| 0:4   | CNT | Count<br>0-31  |  |
|-------|-----|----------------|--|
| 5:9   |     | Always 0b11111 |  |
| 10:31 |     | Reserved       |  |

#### 15.6.3 Sleep Mode Exit

The power management wake-up logic monitors the PLB for SDRAM reads or writes from other masters. In addition, the wakeup logic also monitor the DCR bus for accesses to SDRAM configuration and status registers. If either a PLB or DCR operation targeting the SDRAM controller is detected the SDRAM controller wakes up. The wakeup process results in a two cycle additional latency to the pending operation.

15-22 PPC405GP User's Manual

# **Chapter 16. External Bus Controller**

The PPC405GP External Bus controller (EBC) provides direct attachment for most SRAM/Flash type memory and peripheral devices. The interface minimizes the amount of external glue logic needed to communicate with memory and peripheral devices. This reduces the embedded system device count, circuit board area, and cost.

To eliminate off-chip address decoding, the EBC provides eight programmable chip selects that enable system designers to locate memory and peripherals within the PPC405GP memory map. Chip select, data bus, and associated control signal timings are programmable for both single and burst transfers. For peripherals with variable timing requirements the EBC supports device-paced transfers with optional bus-timeout. System design is further simplified through dynamic bus sizing which supports seamlessly attaching 8-, 16-, and 32-bit wide memories and peripherals. Whenever a size mismatch exists between a read or write operation and the externally attached device, the EBC automatically packs or unpacks data as appropriate.

In addition to the peripheral and memory interface, the EBC includes an external bus master (EBM) interface. Using the EBM, external masters arbitrate and gain access to the peripheral interface. Once an external master owns the peripheral interface it can read and write all PLB- and OPB-addressable memory, with the exception of devices controlled by the EBC. Typical destinations for EBM transactions are PCI address space and SDRAM memory. For EBC-attached peripherals and memory, the external master is required to directly control the target.

## 16.1 Interface Signals

Figure 16-1 on page 16-2 illustrates the signal I/O between the EBC and the external peripheral bus.



Figure 16-1. External Bus Controller Signals

The usage along with the state of these signals during and after a reset is as follows: . .

| Table 16-1. EBC Signal Usage and State During/Following a Chip or System Reset |
|--------------------------------------------------------------------------------|
|--------------------------------------------------------------------------------|

| Signal      | ExtReset=0 | ExtReset=1      | Usage                                                                                                                                                     |
|-------------|------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| PerClk      | See Note 1 | Toggling        | Peripheral bus clock. During an EBC transfer all EBC signal transitions and data sampling occurs synchronous to PerClk.                                   |
| ExtReset    | 0          | 1               | Peripheral reset for use by slaves and external bus masters.                                                                                              |
| PerAddr0:31 | High-Z     | Last<br>Address | Peripheral address bus. PerAddr0 is the most significant bit.                                                                                             |
| PerData0:31 | High-Z     | High-Z          | Peripheral data bus. PerData0 is the most significant bit.                                                                                                |
| PerPar0:3   | High-Z     | High-Z          | Peripheral parity bus. The EBC implements odd parity.                                                                                                     |
| PerCS0:7    | High-Z     | 1               | Chip selects. PerCS1:7 are multiplexed with GPIO10:16 and power up as actively driven chip selects. See "Pin Sharing" on page 9-3 for additional details. |
| PerR/W      | High-Z     | 1               | Read not write.                                                                                                                                           |

| Signal    | ExtReset=0 | ExtReset=1 | Usage                                                                                                                                                                                                                                                                                                                            |
|-----------|------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PerWBE0:3 | High-Z     | 1          | Write byte enables or read/write byte enables.                                                                                                                                                                                                                                                                                   |
| PerOE     | High-Z     | 1          | Output enable.                                                                                                                                                                                                                                                                                                                   |
| PerWE     | High-Z     | High-Z     | Write enable. $\overrightarrow{PerWE}$ is low whenever any bit in $\overrightarrow{PerWBE0:3}$ is low<br>and $\overrightarrow{PerRW} = 0$ . This signal is multiplexed with and defaults to<br>$\overrightarrow{PCIINT}$ after a reset. $\overrightarrow{PerWE}$ is selected by setting<br>$\overrightarrow{CPC0\_CR1[PCIPW]}$ . |
| PerBLast  | High-Z     | 1          | Burst Last. Active during non-burst operations and the last transfer of a burst access.                                                                                                                                                                                                                                          |
| PerReady  | Input      | Input      | An input to allow external peripherals to perform device-paced transfers.                                                                                                                                                                                                                                                        |
| PerErr    | Input      | Input      | Peripheral data error input.                                                                                                                                                                                                                                                                                                     |
| HoldReq   | Input      | Input      | Hold request, used by an external master to request ownership of the peripheral bus.                                                                                                                                                                                                                                             |
| HoldPri   | Input      | Input      | Hold priority, used by an external master to indicate the priority in effect for an external master bus tenure.                                                                                                                                                                                                                  |
| HoldAck   | High-Z     | 0          | Hold acknowledge, informs the external master that it has been granted ownership of the peripheral bus.                                                                                                                                                                                                                          |
| BusReq    | 0          | 0          | Bus request, active when the EBC needs to regain control of the peripheral interface from an external master.                                                                                                                                                                                                                    |
| ExtReq    | Input      | Input      | External request, used by an external master to indicate that it is prepared to transfer data.                                                                                                                                                                                                                                   |
| ExtAck    | High-Z     | 1          | External acknowledge, used by the PPC405GP to indicate that an external master data transfer occurred.                                                                                                                                                                                                                           |

Note 1: During a chip or system reset PerClk begins clocking 64 SysClk cycles prior to the time when the ExtReset output switches from 0 to 1.

## 16.1.1 Interfacing to Byte, Halfword and Word Devices

Figure 16-2 on page 16-4 illustrates how to interface byte, halfword, and word devices to the peripheral data bus. When devices are connected in this way the EBC supports burst transfers and automatically converts read and write operations to the data width of the external device. As shown in Figure 16-2, halfword devices should not connect to PerAddr31. Similarly, a 32-bit device does not require either PerAddr30 or PerAddr31. Instead, the active byte lanes should be inferred from PerWBE0:3, the read/write byte enables.

When a large number of byte and halfword devices are attached to the peripheral data bus, the capacitive loading on byte lane 0 (and byte lane 1, if many halfword devices are used) will be much larger than the loading on byte 3, possibly resulting in unacceptable timing performance on byte 0 or byte 1.

If a bank register is configured as word-wide, then byte-wide devices may be attached to the bus in any byte lane (and accessed using byte loads and stores). Similarly, if a bank register is configured as word-wide, then halfword-wide devices may be attached to the bus in the byte 0/byte 1 lane, or in the

byte 2/byte 3 lane, and accessed using halfword loads and stores. External logic may be required to develop additional control signals if the data bus is utilized in this manner.



Figure 16-2. Attachment of Devices of Various Widths to the Peripheral Data Bus

#### 16.1.2 Multiplexed I/Os

Seven of the chip select outputs, PerCS1:7, are multiplexed with GPIOs, while PerWE is multiplexed with PCIINT. The multiplexing of these I/Os occurs outside of the EBC logic, see "Pin Sharing" on page 9-3 for additional details. As a result, software can still configure and attempt to use a peripheral memory bank whose output is set up as a GPIO. Doing so causes an EBC transaction without an active chip select and the results are therefore undefined.

In the remainder of this chapter PerCS0:7 and PerWE are assumed to be configured as EBC outputs.

#### 16.1.3 Driver Enables

As shown in Table 16-2, "Effect of Driver Enable Programming on EBC Signal States," on page 16-5, the output enables for the peripheral address, data and most of the EBC control signals are configurable. For systems that do not use an external master or where the external master does not directly control devices on the peripheral bus, setting EBC0\_CFG[CSTC]=1 eliminates the need for pull-up resistors on PerCS0:7. Pullups are also unnecessary on the remainder of the EBC control signals when EBC0\_CFG[EBTC]=1.

Both chip and system resets set EBC0\_CFG[EBTC]=1 and EBC0\_CFG[CSTC]=1. In most applications, clearing EBC0\_CFG[CSTC] is not recommended. If EBC0\_CFG[EBTC]=0, EBC control

signals can transition from the active state to high-Z without first being driven inactive. To prevent this, all peripheral banks must be configured with at least one hold cycle, EBC0\_BnAP[TH] > 0.

| EBC<br>Operation | ExtReset<br>PerClk<br>PerWE<br>HoldAck<br>BusReq<br>ExtAck | PerCS0:7       | PerAddr0:31<br>PerR/W<br>PerWBE0:3<br>PerOE<br>PerBLast | PerData0:31<br>PerPar0:3 |
|------------------|------------------------------------------------------------|----------------|---------------------------------------------------------|--------------------------|
| Reset            | High-Z                                                     | High-Z         | High-Z                                                  | High-Z                   |
| Idle             | Driven                                                     | EBC0_CFG[CSTC] | EBC0_CFG[EBTC]                                          | EBC0_CFG[EBTC]           |
| Read             | Driven                                                     | Driven         | Driven                                                  | High-Z                   |
| Write            | Driven                                                     | Driven         | Driven                                                  | Driven                   |
| External Master  | Driven                                                     | EBC0_CFG[CSTC] | High-Z                                                  | High-Z                   |

Table 16-2. Effect of Driver Enable Programming on EBC Signal States

Note 1: If the EBC0\_CFG bit is set, the signal is driven to the appropriate state during the indicated EBC operation. Otherwise, the I/O is High-Z.

## 16.2 Non-Burst Peripheral Bus Transactions

The timing of the PerCSn, PerOE, and PerWBE0:3 signals is programmable via the Peripheral Bank Access Parameter (EBC0\_BnAP) registers. For non-burst transfers, the access parameter registers control the peripheral bus timing as follows:

- PerCSn becomes active 0-3 PerClk cycles (EBC0\_BnAP[CSN]) after the address is driven.
- PerOE is driven low 0-3 PerClk cycles (EBC0\_BnAP[OEN]) after PerCSn is active.
- PerBLast is active throughout the entire transfer and is driven high during the programmed hold time (EBC0\_BnAP[TH]).
- PerWBE0:3 can be either write byte enables or read and write enables.

If EBC0\_BnAP[BEM]=0, PerWBE0:3 are write byte enables and:

- PerWBE0:3 goes active 0-3 (EBC0\_BnAP[WBN]) PerClk cycles after PerCSn becomes active.
- PerWBE0:3 becomes inactive 0-3 (EBC0\_BnAP[WBF]) PerClk cycles before PerCSn becomes inactive.

If EBC0\_BnAP[BEM]=1, PerWBE0:3 are read/write byte enables and have timing identical to the peripheral address bus. In this case the EBC0\_BnAP[WBN] and EBC0\_BnAP[WBF] parameters are ignored.

- 1-256 PerClk cycles (EBC0\_BnAP[TWT] + 1) after the address became valid:
  - If EBC0\_CFG[CSTC]=1 or EBC0\_BnAP[TH]>0, PerCSn is driven high.
  - If EBC0\_CFG[CSTC]=0 and EBC0\_BnAP[TH]=0, PerCSn transitions directly from logic 0 to the high-impedance state.
- The parameters TWT, CSN, OEN, WBN, and WBF in EBC0\_BnAP are not independent. For nonburst configured banks it is required that TWT ≥ CSN + MAX(OEN,WBN) + WBF.

- The hold time, EBC0\_BnAP[TH], is programmable from 0 to 7 PerClk cycles. During the hold time
  the peripheral address bus remains driven with the last address and all control signals are actively
  driven high. If the operation was a write, the peripheral data bus continues driving the last data
  value.
- There is no guarantee of dead cycles between transfers on the peripheral interface. If there are back-to-back transfers to the same memory bank and the number of hold cycles is programmed to zero (EBC0\_BnAP[TH]=0) and EBC0\_BnAP[CSN]=0, then:
  - PerCSn may not go inactive between the back-to-back transfers.
  - If EBC0\_BnAP[OEN]=0, PerOE may not become inactive between the two transfers.
  - If EBC0\_BnAP[WBN]=0 and EBC0\_BnAP[WBF]=0, PerWBE0:3 may not go inactive between the back-to-back transfers.

#### 16.2.1 Single Read Transfer

Figure 16-3 shows the peripheral interface timing for a single read transfer from a non-burst enabled (EBC0\_BnAP[BME]=0) bank. The transaction begins with the address being driven. Since this is a single transfer, PerBLast is also driven active along with the address. If byte enable mode is enabled for the bank (EBC0\_BnAP[BEM]=1) the byte enables are also output concurrently on PerWBE0:3. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address, while PerOE goes low EBC0\_BnAP[OEN] cycles after PerCSn. The EBC then waits until EBC0\_BnAP[TWT]+1 cycles have elapsed since the start of the transaction and then reads the data bus and the peripheral error input, PerErr. If parity checking is enabled (EBC0\_BnAP[PAR]=1) the parity is also read at this time. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles.



Figure 16-3. Single Read Transfer

#### 16.2.2 Single Write Transfer

Figure 16-4 shows the peripheral interface timing for a single write transfer to a non-burst enabled (EBC0\_BnAP[BME]=0) bank. The transaction begins with the address being driven. Since this is a single transfer, PerBLast is also driven active along with the address. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address. At this point the signalling sequence depends on whether or not byte enable mode is enabled for the bank.

- If EBC0\_BnAP[BEM]=0, byte enable mode is disabled and the PerWBE0:3 are write byte enables. The appropriate write byte enables go low EBC0\_BnAP[WBN] cycles after PerCSn. The EBC then waits until (EBC0\_BnAP[TWT] - EBC0\_BnAP[WBF] + 1) cycles have elapsed since the start of the transaction, then drives all the PerWBE0:3 inactive.
- If EBC0\_BnAP[BEM]=1, the PerWBE0:3 lines are byte enables and have the same timing as the peripheral address bus.

After EBC0\_BnAP[TWT+1] cycles elapse from the start of transfer, PerCSn and PerBLast are driven high. The EBC then waits EBC0\_BnAP[TH] cycles before allowing any pending transfers to occur.



Figure 16-4. Single Write Transfer

# 16.3 Burst Transactions

Bursting is controlled on a per-bank basis by the Burst Mode Enable bit in the EBC0\_BnAP registers. When enabled (EBC0\_BnAP[BME]=1) this mode activates bursting for all cache line fills and flushes, PLB burst transfers to the EBC, and all packing and unpacking operations. When bursting is enabled:

- PerCSn becomes active 0-3 (EBC0\_BnAP[CSN]) PerClk cycles after the address becomes valid.
- PerCSn is no longer actively driven:
  - 1-32 (EBC0\_BnAP[FWT]+1) PerClk cycles after the address becomes valid when a single transfer occurs to a burst-enabled bank.
  - 1-8 (EBC0\_BnAP[BWT]+1) PerClk cycles after the last address becomes valid during a burst:
    - If EBC0\_CFG[CSTC]=1 or EBC0\_BnAP[TH]>0, PerCSn is driven high.
    - If EBC0\_CFG[CSTC]=0 and EBC0\_BnAP[TH]=0, PerCSn transitions directly from logic 0 to the high-impedance state.
- During read operations PerOE is driven low 0-3 (EBC0\_BnAP[OEN]) PerClk cycles after PerCSn is active. PerOE goes inactive when PerCSn goes inactive.
- For bursts, the EBC drives a new address (EBC0\_BnAP[FWT]+1) + N\*(EBC0\_BnAP[BWT]+1) cycles after the start of the transaction, where N = 0, 1, 2, ...
- · Addresses during a burst may "wrap." For example, cache line fills are processed critical word first.
- During write operations, the write data is driven concurrent with each address.
- PerWBE0:3 can be either write byte enables or read and write enables.

If EBC0\_BnAP[BEM]=0, PerWBE0:3 are write byte enables and:

- For the first transfer of a burst, or a single transfer to a burst enabled bank, the appropriate write byte enables go low 0-3 (EBC0\_BnAP[WBN]) cycles after PerCSn becomes active. The EBC then waits until EBC0\_BnAP[FWT] - EBC0\_BnAP[WBF] + 1 cycles have elapsed since the start of the transaction and drives PerWBE0:3 inactive.
- The remaining transfers of the burst are similar, except that PerWBE0:3 becomes active EBC0\_BnAP[WBN] cycles after each new address is driven on the interface. The PerWBE0:3 remain low for (EBC0\_BnAP[BWT] + 1) - EBC0\_BnAP[WBN] - EBC0\_BnAP[WBF] cycles.

If EBC0\_BnAP[BEM]=1, PerWBE0:3 are byte enables that have timing identical to the peripheral address bus. In this case the EBC0\_BnAP[WBN] and EBC0\_BnAP[WBF] parameters are ignored.

- PerBLast is active throughout the entire last (or only) transfer of a burst operation and is deactivated during the programmed hold time (EBC0\_BnAP[TH]).
- Access bank parameters CSN and OEN apply to the first (or only) transfer of a burst, while WBN and WBF apply to all transfers. It is required that FWT ≥ CSN + MAX(OEN,WBN) + WBF and BWT ≥ WBN+WBF.
- Hold time (EBC0\_BnAP[TH]) is programmable from 0 to 7 cycles. During the hold time, the peripheral address bus remains driven and all control signals are driven inactive. If the operation was a write, the peripheral data bus continues driving the write data.
- There is no guarantee of dead cycles between transfers on the peripheral interface. If there are back-to-back transfers to the same memory bank and the number of hold cycles is programmed to zero (EBC0\_BnAP[TH]=0) and EBC0\_BnAP[CSN]=0, then:

- PerCSn may not go inactive between the back-to-back transfers.
- If EBC0\_BnAP[OEN]=0, PerOE may not become inactive between the two transfers.
- If EBC0\_BnAP[WBN]=0 and EBC0\_BnAP[WBF]=0, PerWBE0:3 may not go inactive between the back-to-back transfers.

#### 16.3.1 Burst Read Transfer

Figure 16-5 shows the peripheral interface timing for a burst read transfer from a burst enabled (EBC0\_BnAP[BME]=1) bank. The transaction begins with the address being driven. If byte enable mode is enabled for the bank (EBC0\_BnAP[BEM]=1) the byte enables are also output concurrently on PerWBE0:3. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address, while PerOE goes low EBC0\_BnAP[OEN] cycles after PerCSn. The EBC then waits until EBC0\_BnAP[FWT]+1 cycles have elapsed since the start of the transaction and then reads the data bus and the peripheral error input, PerErr. If parity checking is enabled (EBC0\_BnAP[PEN]=1) the parity is also read at this same time.

The next address of the burst is then driven and after EBC0\_BnAP[BWT]+1 cycles the EBC performs the next read. The remaining items in the burst are read in the same manner, except that PerBLast is active during the last data element. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles before allowing any pending transfers to occur.





## 16.3.2 Burst Write Transfer

Figure 16-6 shows the peripheral interface timing for a burst write transfer to burst enabled (EBC0\_BnAP[BME]=1) bank. The transaction begins with the address being driven. At this point the signalling sequence depends on whether byte enable mode is enabled for the bank.

- If EBC0\_BnAP[BEM]=0, byte enable mode is disabled and PerWBE0:3 are write byte enables. In this case, the appropriate write byte enables go low EBC0\_BnAP[WBN] cycles after PerCSn. The EBC then waits until (EBC0\_BnAP[FWT] +1) EBC0\_BnAP[WBF] cycles have elapsed since the start of the transaction and drives PerWBE0:3 inactive. EBC0\_BnAP[WBF] cycles are then allowed to elapse after which the address and data are output for the second element in the burst. As shown in Figure 16-6, the EBC transfers the subsequent data items in a similar manner.
- If EBC0\_BnAP[BEM]=1, the PerWBE0:3 lines are byte enables and have the same timing as the
  peripheral address bus. In this configuration external logic may be necessary to latch write data at
  the appropriate times.

PerBLast goes low at the beginning of the last transfer to indicate that the burst is ending. The EBC then drives PerCSn and PerBLast high and waits EBC0\_BnAP[TH] cycles before allowing any pending transfers to occur.





# 16.4 Device-Paced Transfers

For device-paced transfers, the EBC provides two distinct modes: Sample On Ready enabled and Sample On Ready disabled. The selection of these modes is controlled on a per-bank basis by EBC0\_BnAP[SOR]. When Sample On Ready is enabled (EBC0\_BnAP[SOR] = 1) data is transferred on the PerClk rising edge where PerReady is sampled active. When Sampling On Ready is disabled (EBC0\_BnAP[SOR] = 0), PerReady sampled active causes the data transfer to occur in the next cycle, which results in an additional cycle of wait time.

The ready signal (PerReady) is an input which allows the insertion of externally generated (devicepaced) wait states. PerReady is monitored only when EBC0\_BnAP[RE]=1.

- For burst disabled banks (EBC0\_BnAP[BME] = 0) sampling of the PerReady input starts EBC0\_BnAP[TWT] cycles after the beginning of the transfer. Wait states are inserted and sampling continues once per cycle until either PerReady is high when sampled or a timeout occurs.
- For burst enabled banks (EBC0\_BnAP[BME] = 1) sampling of the PerReady input starts EBC0\_BnAP[FWT] PerClk cycles after the beginning of the first transfer of a burst, and EBC0\_BnAP[BWT] cycles after the beginning of subsequent transfers of the burst. Sampling continues once per cycle until either PerReady is sampled high or a timeout occurs.
- When EBC0\_BnAP[SOR] = 1 data transfer occurs in the same cycle where PerReady is sampled active. In contrast, if EBC0\_BnAP[SOR]=0 the data transfer occurs in the next cycle.
- When EBC0\_BnAP[SOR] = 1, if the hold time is set to zero, EBC0\_BnAP[TH] = 0, the programmed hold time is ignored and the EBC performs the transaction with one hold cycle.
- When EBC0\_BnAP[RE] = 1, the Write Byte Enable Off parameter must be programmed to zero, EBC0\_BnAP[WBF] = 0.

The EBC may be programmed to wait only a limited time for PerReady to become active, or it may be programmed for unlimited wait. If EBC0\_CFG[PTD] = 1, timeouts are disabled and the EBC waits indefinitely for an active PerReady.

If EBC0\_CFG[PTD] = 0, device-paced timeouts are enabled and the EBC only waits for the number of PerClk cycles programmed in EBC0\_CFG[RTC]. The timeout counter is reset whenever the peripheral address changes. In this manner each data element within a device-paced burst transaction is treated separately for the purposes of determining whether a timeout error occurs. If PerReady does not become active before the timeout counter reaches the value programmed into EBC0\_CFG[RTC], the transfer is aborted and an error is signalled. See "Error Reporting" on page 16-29 for details on how timeout errors are logged.

## 16.4.1 Device-Paced Single Read Transfer

Figure 16-7 shows the peripheral interface timing for a device-paced single read transfer from a burst disabled (EBC0\_BnAP[BME]=0) bank. The transaction begins with the address being driven. Since this is a single transfer, PerBLast is also driven active along with the address. If byte enable mode is enabled for the bank (EBC0\_BnAP[BEM]=1) the byte enables are also output concurrently on PerWBE0:3. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address, while PerOE goes low EBC0\_BnAP[OEN] cycles after PerCSn.

The EBC then waits until EBC0\_BnAP[TWT]+1 cycles have elapsed since the start of the transaction and then begins sampling PerReady. If device-paced timeouts are disabled (EBC0\_CFG[PTD]=0) the EBC waits indefinitely for PerReady to become active. Otherwise, the EBC waits only EBC0\_CFG[RTC] cycles from the start of the transaction until logging a timeout error.

Once PerReady is sampled active if Sample On Ready is disabled (EBC0\_BnAP[SOR]=0) the EBC waits one more cycle. The EBC then samples the data bus and the peripheral error input, PerErr. If parity checking is enabled (EBC0\_BnAP[PEN]=1) the parity is also read at this time. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles before allowing any pending EBC transfers to occur.





## 16.4.2 Device-Paced Single Write Transfer

Figure 16-8 shows the peripheral interface timing for a device-paced single write transfer from a burst enabled (EBC0\_BnAP[BME]=1) bank. The transaction begins with the address being driven. Since this is a single transfer, PerBLast is also driven active along with the address. At this point the signalling sequence depends on whether byte enable mode is enabled for the particular bank.

- If EBC0\_BnAP[BEM]=0, byte enable mode is disabled and the PerWBE0:3 are write byte enables. The appropriate write byte enables go low EBC0\_BnAP[WBN] cycles after PerCSn went low. PerWBE0:3 return high on the same PerClk edge that the write data is transferred (see below).
- If EBC0\_BnAP[BEM]=1, the PerWBE0:3 lines are byte enables and have the same timing as the peripheral address bus.

The EBC then waits until EBC0\_BnAP[TWT]+1 cycles have elapsed since the start of the transaction and then begins sample PerReady. If device-paced timeouts are disabled (EBC0\_CFG[PTD]=0) the EBC waits indefinitely for PerReady to become active. Otherwise, the EBC waits only EBC0\_CFG[RTC] cycles from the start of the transaction until logging a timeout error.

If PerReady is sampled active and Sample On Ready is disabled (EBC0\_BnAP[SOR]=0) the EBC waits one more cycle. At this point, the write transfer occurs and the EBC reads the peripheral error input, PerErr. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles.



Figure 16-8. Device-Paced Single Write Transfer

## 16.4.3 Device-Paced Burst Read Transfer

Figure 16-9 shows the peripheral interface timing for a device-paced burst read transfer from a burst enabled (EBC0\_BnAP[BME]=1) bank. The transaction begins with the address being driven. If byte enable mode is enabled for the bank (EBC0\_BnAP[BEM]=1) the byte enables are also output concurrently on PerWBE0:3. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address, while PerOE goes low EBC0\_BnAP[OEN] cycles after PerCSn. The EBC then waits until EBC0\_BnAP[FWT]+1 cycles have elapsed since the start of the transaction and begins sampling PerReady.

If device-paced timeouts are disabled (EBC0\_CFG[PTD]=0) the EBC waits indefinitely for PerReady to become active. Otherwise, the EBC waits only EBC0\_CFG[RTC] cycles from the start of the transaction until logging a timeout error.

If PerReady is sampled active and Sample On Ready is disabled (EBC0\_BnAP[SOR]=0) the EBC waits one more cycle before sampling read data. The EBC then reads the data bus and the peripheral error input, PerErr. If parity checking is enabled (EBC0\_BnAP[PEN]=1) the parity is also read.

The next address of the burst is then driven and after EBC0\_BnAP[BWT]+1 cycles the EBC waits for PerReady as described above. The remaining items in the burst are read in this same manner, except that PerBLast is active during the last data element. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles before allowing any pending transfers to occur.





#### 16.4.4 Device-Paced Burst Write Transfer

Figure 16-10 shows the peripheral interface timing for a device-paced burst write transfer to a burst enabled (EBC0\_BnAP[BME]=1) bank. The transaction begins with the address being driven. PerCSn then becomes active EBC0\_BnAP[CSN] cycles after the address. At this point the signalling sequence depends on whether or not byte enable mode is enabled for the bank.

- If byte enable mode is disabled (EBC0\_BnAP[BEM]=0) PerWBE0:3 are write byte enables. In this case the appropriate write byte enables go low EBC0\_BnAP[WBN] cycles after PerCSn becomes active for the first element in a burst and EBC0\_BnAP[WBN] cycles after each new address for the remainder of the burst. If EBC0\_BnAP[WBN]
   PerWBE0:3 is driven inactive on the same PerClk edge that write data is transferred (see below). Otherwise, PerWBE0:3 remains low for all data elements in the burst.
- If EBC0\_BnAP[BEM]=1, PerWBE0:3 are byte enables and have the same timing as PerAddr0:31.

The EBC then waits until EBC0\_BnAP[FWT]+1 cycles have elapsed since the start of the transaction and begins sampling PerReady. If device-paced timeouts are disabled (EBC0\_CFG[PTD]=0) the EBC waits indefinitely for PerReady. Otherwise, the EBC waits only EBC0\_CFG[RTC] cycles from the start of the transaction until logging a timeout error.

If PerReady is sampled active and Sample On Ready is disabled (EBC0\_BnAP[SOR]=0) the EBC waits one more cycle. At this point the write transfer occurs and the EBC reads the peripheral error input, PerErr.

The next address of the burst is then driven and after EBC0\_BnAP[BWT]+1 cycles the EBC waits for PerReady as described above. The remaining items in the burst are transferred in this same manner, except that PerBLast is active for the last data element. The EBC then drives PerCSn, PerOE and PerBLast high and waits EBC0\_BnAP[TH] cycles before allowing any pending transfers to occur.



Figure 16-10. Device-Paced Burst Write Transfer

## 16.5 External Bus Master Interface

The EBC includes an External Bus Master (EBM) interface supporting a shared bus protocol which allows an EBM to gain control of the peripheral bus. Once an external master has been granted access to the peripheral interface it can read and write all PLB- and OPB-addressable memory, with the exception of devices controlled by the EBC. Typical destinations for EBM transactions are PCI address space and SDRAM memory. For EBC-attached peripherals and memory, the external master is required to directly control the target.

Figure 16-11 shows a sample interconnection of the EBC, one SRAM bank, and one external bus master. While only one SRAM bank is shown, the bus master could access all eight of the SRAM banks. Also, with the appropriate arbitration logic, multiple bus masters may be used in a system.



Figure 16-11. Sample External Bus Master System

The EBM interface includes both arbitration and data transfer functions. The arbiter grants the peripheral bus to either the EBC or an external master, while the datapath logic implements an external master to PLB bridge function. This bridge function translates the EBM interface protocol to that required by the on-chip PLB bus.

#### 16.5.1 Arbitration

To gain control of the peripheral bus, the external bus master places an active level on the HoldReq input and drives the HoldPri signal to the desired value (see Figure 16-12 on page 16-20 for an illustrative waveform). The HoldPri input selects the priority of the external master's transactions

relative to other EBC operations. Internal to the PPC405GP all reads and writes that target the EBC are assigned the priority 0b10.

If HoldPri=0 the external master priority is set to EBC0\_CFG[EMPL], whereas HoldPri=1 sets the priority to EBC0\_CFG[EMPH]. Table 16-3 details the only unique ways of programming the external master priority fields in EBC0\_CFG, along with the arbiter's response.

| EMPL | ЕМРН | HoldPri | When HoldReq=1<br>HoldAck Becomes Active                         | When HoldAck=1<br>BusReq Goes Active |
|------|------|---------|------------------------------------------------------------------|--------------------------------------|
| 0b11 | 0b11 | Х       | After any active EBC operation completes.                        | Never.                               |
| 0b00 | 0b11 | 0       | If no EBC transfers are active or pending. If an EBC transfer is |                                      |
|      |      | 1       | After any active EBC operation completes.                        | Never.                               |
| 0b00 | 0b00 | Х       | If no EBC transfers are active or pending.                       | If an EBC transfer is pending.       |

Table 16-3. External Master Arbitration.

When an external bus master requests the bus by driving HoldAck=1, the EBC finishes any transfer in progress (except for bursts) before arbitrating between any pending PLB request and the external master request. If the external master presents a higher priority request during a PLB burst, the burst is terminated. Note that processor cache reads and writes are PLB line operations, not PLB bursts, and are never interrupted.

As detailed in Table 16-3, the arbitration logic drives HoldAck active either when the current EBC transaction completes or when there are no EBC transfers pending. Once the external master has been granted the bus, it may either directly control devices on the peripheral bus or read and write PLB- and OPB-addressable memory. If the EBC detects a pending PLB request when the external master owns the peripheral bus (HoldAck=1), BusReq may be asserted to signal the external master that the PPC405GP wants to regain ownership of the peripheral bus. Table 16-3 lists the cases where a PLB request causes BusReq to go active. To ensure fairness and optimize bus utilization, an external master that receives an active BusReq should complete its current transaction and then relinquish ownership of the peripheral bus by driving HoldReq inactive. This is important since the EBC cannot reclaim ownership of the external bus until the external master negates HoldReq.

Table 16-4, "Signal States During Hold Acknowledge (HoldAck=1)," on page 16-18 details the usage of the EBC I/Os when an external master has been granted ownership of the peripheral bus. The usage statements in this table for signals other than HoldPri, HoldReq, HoldAck and BusReq do not apply if an external master directly controls a device on the peripheral bus.

| Signal Name | State       | Usage                                                                                           |
|-------------|-------------|-------------------------------------------------------------------------------------------------|
| HoldPri     | Input       | Requested priority for external master tenure. HoldPri must not<br>change state when HoldReq=1. |
| HoldReq     | Input (=1)  | External master must maintain its request when it owns the bus.                                 |
| HoldAck     | Output (=1) | External master is receiving an active bus grant.                                               |
| BusReq      | Output      | See Table 16-3 on Page 16-18.                                                                   |
| ExtReq      | Input       | Indicates the external master is ready to transfer data.                                        |
| ExtAck      | Output      | Indicates to the external master that a data transfer occurred.                                 |

Table 16-4. Signal States During Hold Acknowledge (HoldAck=1)

| Signal Name | State  | Usage                                                            |
|-------------|--------|------------------------------------------------------------------|
| PerAddr0:31 | Input  | Requested address from external master.                          |
| PerWBE0:3   | Input  | Selects the requested byte(s) for reads and writes.              |
| PerR/W      | Input  | Determines if the operation is a read or write.                  |
| PerBLast    | Input  | Active during single transfers and the last transfer of a burst. |
| PerData0:31 | I/O    | Read and write data.                                             |
| PerOE       | High-Z | Unused.                                                          |
| PerWE       | 1      | Unused.                                                          |
| PerErr      | High-Z | Unused.                                                          |
| PerPar0:3   | High-Z | Unused.                                                          |

Table 16-4. Signal States During Hold Acknowledge (HoldAck=1)

#### 16.5.2 Transaction Overview

The EBM interface supports direct attachment of 8-, 16-, and 32-bit masters. By programming the width of the external master into EBC0\_CFG[EMS] the interface accepts write data and provides read data at the appropriate width for the master. The EBM interface includes a 32-byte data buffer, used for both read and write operations between the EBM and PLB- and OPB-mapped memory locations. While write operations only use the buffer during bursts, all reads prefetch one doubleword and burst reads prefetch EBC0\_CFG[BPR] doublewords from the source memory into the buffer. This prefetched data remains in the buffer until either a write operation is performed or a read is requested to a different 32-byte block of memory.

To provide the best possible performance, the EBM interface supports both single and burst transactions. Single read transfers result in the EBM reading and buffering a 64-bit doubleword from the requested memory address. The requested read data is then serviced from within this doubleword. If the next operation on the EBM interface is a read and targets this same doubleword, it is serviced directly from the buffer. Burst reads are similar, except that the EBM prefetches four doublewords beginning with the requested word.

Single write transfers result in a separate PLB transaction for each data item. To improve performance, burst writes are gathered in the 32-byte buffer and forwarded in a single PLB transaction to the target memory.

# 16.5.3 Single Read and Single Write Transfers

Figure 16-12 illustrates external master bus arbitration along with a single read and signal write transfer. An external master requests ownership of the peripheral bus by driving HoldReq active along with the desired priority on HoldPri. Observe that HoldPri must be held at constant value throughout the entire external master tenure. After two or more PerClk cycles the arbiter will grant the peripheral bus to the external master. The delay from when the external master asserts HoldReq to when HoldAck becomes active is variable and depends on any EBC transaction that may be in progress or pending, the level on HoldPri, and the programming in EBC0\_CFG[EMPL] and EBC0\_CFG[EMPH].

Once the external master is granted the peripheral bus (HoldAck=1), it may either directly control a device on the EBC or issue read and write transactions to the external master interface. This waveform and the ones that follow apply only to the later case. Additionally, cycles shown with breaks in the clock may not be present or may extend for multiple cycles.

To perform a single read operation the external master must:

- Place the desired address on PerAddr0:31.
- Indicate the requested data byte(s) on PerWBE0:3.
- Drive PerR/W high.
- Assert PerBLast to mark this as a single transfer.
- Request the transfer by driving and holding ExtReq low.



Figure 16-12. External Master Arbitration, Single Read and Single Write

The EBM interface then converts this read request into a PLB transaction and reads the target memory location. ExtAck then goes low when read data is available on PerData. Note that the external master must not remove ExtReq until the cycle after ExtAck becomes active. In addition, ExtReq must be high for at least one cycle between all external master transactions.

Write transfers are similar to reads except that the write data must be provided along with the address and  $PerR/\overline{W}$  is low to indicate a write. As with reads,  $\overline{ExtReq}$  must be held until the cycle after  $\overline{ExtAck}$  is received.

#### 16.5.4 Burst Read Transfer

Burst reads are preferred when accessing sequential addresses as they provide much better performance. Figure 16-13 illustrates an external master burst read transaction. A burst read differs from a single read in that PerBLast is held inactive for all but the last transfer of the burst. In addition, the EBM only requires the address of the first burst element. Following each ExtAck the EBM uses

the size of the master configured in EBC0\_CFG[EMS] to increment its internal address counter as appropriate.



Figure 16-13. External Master Burst Read

#### 16.5.5 Burst Write Transfer

Burst writes are preferred when accessing sequential addresses as they provide much better performance. Figure 16-14 illustrates an external master burst write transaction. A burst write differs from a single write in that PerBLast is held inactive for all but the last transfer of the burst. In addition,

the EBM only requires the address of the first burst element. Following each ExtAck the EBM uses the size of the master in EBC0\_CFG[EMS] to increment its internal address counter as appropriate.



Figure 16-14. External Master Burst Write

#### 16.5.6 External Master Error Interrupts

The EBM can generate an interrupt if a PLB error is encountered while read or writing data. As example, an SDRAM uncorrectable ECC error will cause and EBM interrupt. Please refer to the UIC Chapter for additional information regarding interrupts.

# 16.6 EBC Registers

All EBC configuration and status registers are accessed using the PowerPC **mtdcr** and **mfdcr** instructions. Access to these registers is performed using an indirect addressing method through the EBC0\_CFGADDR and EBC0\_CFGDATA registers.

| Register     | DCR Address | Access | Description                              |
|--------------|-------------|--------|------------------------------------------|
| EBC0_CFGADDR | 0x012       | R/W    | External Bus Controller Address Register |
| EBC0_CFGDATA | 0x013       | R/W    | External Bus Controller Data Register    |

Table 16-5. EBC DCR Addresses

Table 16-6 lists the indirectly accessed EBC configuration and status registers.

| Table 16-6. External Bus Configuration and Status Regis | ters |
|---------------------------------------------------------|------|
|---------------------------------------------------------|------|

| Mnemonic            | Address Offset | Access | Description                             | Page  |
|---------------------|----------------|--------|-----------------------------------------|-------|
| EBC0_B0CR-EBC0_B7CR | 0x00-0x07      | R/W    | Peripheral Bank Configuration Registers | 16-25 |
| EBC0_B0AP-EBC0_B7AP | 0x10-0x17      | R/W    | Peripheral Bank Access Parameters       | 16-26 |
| EBC0_BEAR           | 0x20           | R      | Peripheral Bus Error Address Register   | 16-29 |
| EBC0_BESR0          | 0x21           | R/W    | Peripheral Bus Error Status Register 0  | 16-30 |
| EBC0_BESR1          | 0x22           | R/W    | Peripheral Bus Error Status Register 1  | 16-32 |
| EBC0_CFG            | 0x23           | R/W    | EBC Configuration Register              | 16-23 |

To access one of these registers, software must first write the address offset into the EBC0\_CFGADDR register. The target register can then be read or written through the EBC0\_CFGDATA DCR address. The following PowerPC code illustrates this procedure by writing the EBC0\_B0CR register and then reading back the written value.

| li    | r3,EBC0_B0CR                      | ! address offset                      |
|-------|-----------------------------------|---------------------------------------|
| lis   | r4, <config upper=""></config>    | ! upper 16-bits of configuration data |
| ori   | r4,r4, <config lower=""></config> | ! lower 16-bits of configuration data |
| mtdcr | EBC0_CFGADDR,r3                   | ! set offset addr                     |
| mtdcr | EBC0_CFGDATA,r4                   | ! write config data                   |
| mfdcr | r5,EBC0_CFGDATA                   | ! read back config data               |

## 16.6.1 EBC Configuration Register (EBC0\_CFG)

The contents of EBC0\_CFG are accessed indirectly through the EBC0\_CFGADDR and EBC0\_CFGDATA registers using the **mfdcr** and **mtdcr** instructions.



### Figure 16-15. EBC Configuration Register (EBC0\_CFG)

| 0     | EBTC | External Bus Three-State Control                                                                                                                                                                                           | Default after reset is EBTC=1. See "Effect of                                                                                           |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
|       |      | <ul> <li>Address, data and control signals are<br/>high-Z between EBC transfers.</li> <li>Between EBC transfers the peripheral data<br/>bus, address bus and control signals are<br/>driven.</li> </ul>                    | Default after reset is EBTC=1. See Effect of<br>Driver Enable Programming on EBC Signal<br>States" on page 16-5.                        |
| 1     | PTD  | Device-Paced Time-out Disable<br>0 Enabled time-outs<br>1 Disable time-outs                                                                                                                                                | If PTD=1, the EBC waits indefinitely for<br>assertion of PerReady during device-paced<br>accesses.                                      |
| 2:4   | RTC  | Ready Timeout Count<br>000 16 PerClk cycles<br>001 32 PerClk cycles<br>010 64 PerClk cycles<br>011 128 PerClk cycles<br>100 256 PerClk cycles<br>101 512 PerClk cycles<br>110 1024 PerClk cycles<br>111 2048 PerClk cycles | When PTD=0, the number of cycles from<br>PerAddr0:31 changing until a time-out error<br>occurs.                                         |
| 5:6   | EMPL | External Master Priority Low<br>00 Low<br>01 Medium low<br>10 Medium high<br>11 High                                                                                                                                       | The PLB priority for external master initiated transfers when the external master hold priority input is low (HoldPri=0).               |
| 7:8   | EMPH | External Master Priority High<br>00 Low<br>01 Medium low<br>10 Medium high<br>11 High                                                                                                                                      | The PLB priority for external master initiated transfers when the external master hold priority input is high (HoldPri=1).              |
| 9     | CSTC | Chip Select Three-state Control<br>0 PerCS0:7 are high-Z between EBC<br>transfers and when an external master is<br>active (HoldAck=1)<br>1 PerCS0:7 are always driven.                                                    | Default after reset is CSTC=1. See "Effect of<br>Driver Enable Programming on EBC Signal<br>States" on page 16-5.                       |
| 10:11 | BPF  | Burst Prefetch<br>00 Prefetch 1 doubleword<br>01 Prefetch 2 doublewords<br>10 Prefetch 4 doublewords<br>11 Reserved                                                                                                        | Controls the amount of data prefetching<br>when the EBC is servicing a PLB burst read.<br>For most applications set this field to 0b00. |

| 12:13 | EMS | External Master Size<br>00 8-bit<br>01 16-bit<br>10 32-bit<br>11 No external master attached | Width of the attached external master.                                                                                                       |
|-------|-----|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 14    | PME | Power Management Enable<br>0 Disabled<br>1 Enabled                                           |                                                                                                                                              |
| 15:19 | РМТ | Power Management Timer<br>0-31                                                               | The EBC makes a sleep request to the Clock<br>and Power Management unit when PME=1<br>and the EBC has been idle for 32*PMT<br>PerClk cycles. |
| 20:31 |     | Reserved                                                                                     |                                                                                                                                              |

## 16.6.2 Peripheral Bank Configuration Registers (EBC0\_BnCR)

These registers must be configured to enable memory in each respective bank. Boot ROM must be attached to bank 0 if installed.

If a boot ROM is present, the bank 0 starting address register is loaded with a value of 0xFFE, and the bank 0 size register is loaded with a value of 0b001 (2MB) immediately following SysReset inactive.



| Figure 16-16. | Peripheral | <b>Bank Confid</b> | uration Re | aisters ( | EBC0 | BnCR) |
|---------------|------------|--------------------|------------|-----------|------|-------|
|               |            |                    |            |           |      |       |

| 0:11  | BAS | Base Address Select                                                                                                                                    | Specifies the bank starting address, which must be a multiple of the bank size.                                                                                    |
|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:14 | BS  | Bank Size<br>000 1 MB bank<br>001 2 MB bank<br>010 4 MB bank<br>011 8 MB bank<br>100 16 MB bank<br>101 32 MB bank<br>110 64 MB bank<br>111 128 MB bank |                                                                                                                                                                    |
| 15:16 | BU  | Bank Usage<br>00 Disabled<br>01 Read-only<br>10 Write-only<br>11 Read/Write                                                                            | Specifies the type of accesses allowed for<br>the bank. A protect error occurs if a write is<br>attempted to a read-only bank or a read<br>from a write-only bank. |

| 17:18 | BW | Bus Width<br>00 8-bit bus<br>01 16-bit bus<br>10 32-bit bus<br>11 Reserved |
|-------|----|----------------------------------------------------------------------------|
| 19:31 |    | Reserved                                                                   |

• BAS (Base Address Select, bits 0:11) – Sets the base address for a peripheral device. The bank starting address must be a multiple of the bank size programmed in the BS field. The BAS field is compared to bits 0:11 of the address. If the address is within the range of a BAS field, the associated bank is enabled for the transaction.

Multiple bank registers may be inadvertently programmed with the same base address or as overlapping banks. An attempt to use such overlapping banks is recorded in EBC0\_BESR0 or EBC0\_BESR1 as a configuration error and no external access occurs. This error may result in a machine check exception if the requesting master is the CPU. If the error occurred during a DMA access, the DMA may signal an interrupt to the PPC405GP through the UIC.

- BS (Bank Size, bits 12:14) Sets the number of bytes which the bank may access, beginning with the base address set in the BAS field.
- BU (Bank Usage, bits 15:16) Protects banks of physical devices from read or write accesses.

When a write access is attempted to an address within the range of the BAS field, and the bank is designated as read-only, a protection error occurs. Also, when a read access is attempted to an address within the range of the BAS field, and the bank is designated as write-only, a protection error occurs. The address of the attempted access is logged in EBC0\_BEAR and type of error is logged in either EBC0\_BESR0 or EBC0\_BESR1.

• BW (Bus Width, bits 17:18) – Controls the width of region accesses. If the BW field is 0b00, the region is configured for an 8-bit data bus; 0b01 indicates a 16-bit data bus and 0b10 indicates a 32-bit data bus. If devices are attached to the data bus as shown in Figure 16.1.1 on page 16-3, the EBC automatically packs read data and unpacks write data when a data transfer size mismatch exists.

### 16.6.3 Peripheral Bank Access Parameters (EBC0\_BnAP)



| Figure 16-17. Peripheral Bank Access Parameters (EBC0_BnAP) | Figure 16-17. | Peripheral E | <b>Bank Access</b> | Parameters | (EBC0 BnAP) |
|-------------------------------------------------------------|---------------|--------------|--------------------|------------|-------------|
|-------------------------------------------------------------|---------------|--------------|--------------------|------------|-------------|

| 0   | BME | Burst Mode Enable<br>0 Bursting is disabled<br>1 Bursting is enabled |                                          |
|-----|-----|----------------------------------------------------------------------|------------------------------------------|
| 1:8 | TWT | Transfer Wait<br>0-255 PerClk cycles                                 | Wait states on all transfers when BME=0. |

| 1:5   | FWT | First Wait<br>0-31 PerClk cycles                                                                                                                                                  | If BME=1, number of wait states on the first transfer of a burst.                                                |
|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 6:8   | BWT | Burst Wait<br>0-7 PerClk cycles                                                                                                                                                   | If BME=1, number of wait states on non-first transfers of a burst.                                               |
| 9:11  |     | Reserved                                                                                                                                                                          |                                                                                                                  |
| 12:13 | CSN | Chip Select On Timing<br>0-3 PerClk cycles                                                                                                                                        | Number of cycles from peripheral address driven to PerCSn low.                                                   |
| 14:15 | OEN | Output Enable On Timing<br>0-3 PerClk cycles                                                                                                                                      | Number of cycles from PerCSn low to PerOE low.                                                                   |
| 16:17 | WBN | Write Byte Enable On Timing<br>0-3 PerClk cycles                                                                                                                                  | If BEM=0, number of cycles from PerCSn<br>low to PerWBE0:3 active.                                               |
| 18:19 | WBF | Write Byte Enable Off Timing<br>0-3 PerClk cycles                                                                                                                                 | If BEM=0 and RE=0, number of cycles<br>PerWBEn becomes inactive prior to PerCSn<br>inactive.                     |
| 20:22 | ТН  | Transfer Hold<br>0-7 PerClk cycles                                                                                                                                                | Contains the number of hold cycles inserted at the end of a transfer.                                            |
| 23    | RE  | Ready Enable<br>0 PerReady is disabled<br>1 PerReady is enabled                                                                                                                   |                                                                                                                  |
| 24    | SOR | Sample on Ready<br>0 Data transfer occurs one PerClk cycle after<br>PerReady is sampled active<br>1 Data transfer occurs in the same PerClk<br>cycle that PerReady becomes active |                                                                                                                  |
| 25    | BEM | Byte Enable Mode<br>0 PerWBE0:3 are only active for write cycles<br>1 PerWBE0:3 are active for read and write<br>cycles                                                           | If BEM=0, PerWBE0:3 timing is controlled by WBN and WBF. If BEM=1, PerWBE0:3 has the same timing as PerAddr0:31. |
| 26    | PEN | Parity Enable<br>0 Disable parity checking<br>1 Enable parity checking                                                                                                            | The EBC implements odd parity.                                                                                   |
| 27:31 |     | Reserved                                                                                                                                                                          |                                                                                                                  |

- BME (Burst Mode Enable, bit 0) Controls bursting for cache line fills and flushes, PLB burst transfers and all packing and unpacking operations. If BME=1, bursting is enabled. When bursting is enabled the parameters Chip Select On (CSN), Output Enable On (OEN), and First Wait (FWT) apply only to the first transfer, while Burst Wait (BWT) and Write Byte Enable On (WBN) apply during all remaining transfers of the burst.
- TWT (Transfer Wait, bits 1:8) Specifies the number of wait states taken by each transfer to the bank. The number of cycles from address valid to the deassertion of PerCSn is (1 + TWT), where 0 ≤ TWT ≤ 255. This field is used for non-burst transfers (field BME = 0).
- FWT (First Wait, bits 1:5) Specifies the number of wait states to be taken by the first access to the bank during a burst transfer (field BME = 1). During a burst the number of cycles from the first address valid to the second address is (1 + FWT), where 0 ≤ FWT ≤ 31.

- BWT (Burst Wait, bits 6:8) Specifies the number of wait states to be taken by accesses beyond the first during a burst transfer (field BME = 1). On burst accesses except for the last, the number of cycles from address valid to the next valid address on each burst access is (1 + BWT), where 0 ≤ BWT ≤ 7. On the last burst access, the number of cycles from address valid to the deassertion of PerCSn is (1 + BWT), where 0 ≤ BWT ≤ 7.
- CSN (Chip Select On Timing, bits 12:13) Specifies the chip select turn on delay relative to the
  address. PerCSn may turn on coincident with the address or be delayed by 1, 2, or 3 PerClk cycles.
- OEN (Output Enable On Timing, bits 14:15) Specifies when the output enable signal, PerOE, is
  asserted for read operations relative to the chip select signal. If 0, PerOE is asserted coincident
  with the chip select. If 1, 2 or 3, PerOE is delayed by 1, 2, or 3 PerClk cycles.
- WBN (Write Byte Enable On Timing, bits 16:17) Specifies when the write byte enables, PerWBE0:3, are asserted relative to the chip select signal. If 0, then PerWBE0:3 turns on coincident with the chip select. If 1, 2, or 3, then PerWBE0:3 is delayed 1, 2, or 3 PerClk cycles from the chip select.
- WBF (Write Byte Enable Off Timing, bits 18:19) Specifies when the write byte enables are deasserted, relative to the deassertion of the chip select signal. If WBF=0, PerWBE0:3 goes high coincident with the chip select signal. If WBF is 1, 2, or 3, then PerWBE0:3 turns off 1, 2, or 3 PerClk cycles before the turn-off of the chip select signal.

**Programming Note:** It is an error to set WBF > BWT. Moreover, for device-paced transfers (EBC0\_BnAP[RE]=1) WBF must be set to zero.

- TH (Transfer Hold, bits 20:22) Specifies the number of PerClk cycles (0 through 7) that the
  peripheral bus is held idle after the deassertion of PerCSn. During these cycles, the address bus
  and data bus are active and PerR/W is valid. During the hold time, chip select, output enable, and
  write byte enables are inactive. If Ready Mode is used (RE=1) along with Sample on Ready
  (SOR=1) TH must be set to at least 1.
- RE (Ready Enable, bit 23) Controls the use of the PerReady input signal. If RE=0, the PerReady input is ignored and no additional wait states are inserted into bus transactions. If RE=1, the PerReady input is examined after the wait period expires; additional wait states are inserted if the PerReady input is 0. The maximum number of wait states in each transaction is determined by the settings in the Device-Paced Timeout Disable (PTD) and Ready Timeout Counter (RTC) fields in EBC0\_CFG. If EBC0\_CFG[PTD]=0, the ready timeout function is disabled and the PPC405GP waits indefinitely until PerReady=1. If EBC0\_CFG[PTD]=1, the PPC405GP waits the number of cycle indicated by EBC0\_CFG[RTC] cycles for PerReady to become active. If PerReady does not become active in the allotted time, the address of the error is logged in EBC0\_BEAR and the type of error is captured in either EBC0\_BESR0 or EBC0\_BESR1.
- SOR (Sample Ready, bit 24) Controls the location of the data transfer cycle with respect to the PerReady input. If SOR=1 the data transfer occurs on the same PerClk edge that PerReady is sampled active, whereas if SOR=0 the data transfer occurs one cycle later.
- BEM (Byte Enable Mode, bit 25) Controls whether PerWBE0:3 is active during writes or for both reads and writes.
- PEN (Parity Enable Mode, bit 26) Enables parity generation and checking.

## 16.7 Error Reporting

The EBC monitors four kinds of errors when performing read and write transfers. Of these four, bank protect and external bus errors are always checked, while timeout and read parity error checking must be enabled via DCR-mapped configuration registers.

- **Protect Error** Requested read or write operation violates the bank usage programmed in EBC0\_BnCR[BU]. For example, write attempt to read-only bank. In all cases, no external bus activity occurs.
- External Bus Error The PerErr input was sampled active during the data transfer cycle of a read or write operation. The associated data is read or written as usual.
- Timeout Error This error is possible during memory operations when both PerReady sampling is enabled, EBC0\_BnAP[RE]=1, and device paced timeouts are enabled, EBC0\_CFG[PTD]=0.
   Whenever the peripheral address bus changes the EBC begins counting PerClk cycles. If the count reaches the value represented by EBC0\_CFG[RTC] a timeout error occurs. Note that timeout errors are not possible during the peripheral portion of DMA transfers.
- **Parity Error** Indicates that the parity calculated for the read data did not match the parity read. Parity generation and checking is enabled for memory operations by setting EBC0\_BnAP[PEN]=1 and for DMA peripheral transfers by programming DMA0\_CRn[PCE]=1.

When the EBC slave detects one of the above errors it reports the error condition to the PLB master that initiated the transfer. The EBC also logs the type of error into EBC0\_BESR0 or EBC0\_BESR1 and the address of the error in EBC0\_BEAR.

### 16.7.1 Error Locking

The PCI Bridge and Media Access Layer (MAL) controllers may qualify their PLB transactions to the EBC such that the information describing any errors that occur during these transfers becomes locked. When an error is locked, subsequent errors are not permitted to overwrite the information detailing the first error.

When a master requests error locking an error locks not only the EBC0\_BESRn field for the master, but also the EBC0\_BEAR. These remain locked until software clears them. For each PLB master that supports error locking the EBC has a EBC0\_BESRn field containing two bits associated with error locking. One is the field lock bit and the other is the address lock bit. When an error is detected with locking enabled the field lock bit is set to a value of one. Setting the field lock bit prevents subsequent errors for this master from being logged and overwriting the contents of the field. In addition, the address lock bit is set if no other master has previously locked the EBC0\_BEAR. Once the EBC0\_BEAR is locked, no future errors from this or any master can update the EBC0\_BEAR until software clears the lock bits. When software processes an error it should clear the error status and both lock bits at the same time.

### 16.7.2 Peripheral Bus Error Address Register (EBC0\_BEAR)

The Peripheral Bus Error Address Register (EBC0\_BEAR) is a 32-bit register containing the address of the access where a data bus error occurred. If the master that initiated the transfer requested error locking, and the EBC0\_BEAR is not already locked, the contents of EBC0\_BEAR are locked until the lock bit in one of the Peripheral Bus Error Status Registers (EBC0\_BESR0 or EBC0\_BESR1) is cleared. The contents of the EBC0\_BEAR are accessed indirectly through the EBC0\_CFGADDR and EBC0\_CFGDATA registers using the **mfdcr** and **mtdcr** instructions.

Precise address capture in the EBC0\_BEAR when a parity error occurs only applies to devices with at least one cycle of hold time: EBC0\_BNAP[TH] > 0. This is because parity errors are not calculated until the cycle after the data was valid on the external bus, and the EBC0\_BEAR is loaded with the address on the bus during that cycle. If the device timings do not include at least one hold cycle, the address may transition to the next address in a burst or the address of a new transaction before the EBC0\_BEAR latches the value.



#### Figure 16-18. Peripheral Bus Error Address Register (EBC0\_BEAR)

| 0:31 | Address of Bus Error (asynchronous) |
|------|-------------------------------------|

#### 16.7.3 Peripheral Bus Error Status Register 0 (EBC0\_BESR0)

The Peripheral Bus Error Status Register 0 (EBC0\_BESR0) records the occurrence and type of errors for transactions attempted on behalf of the CPU, EBC External Bus Master and PCI Bridge. The contents of EBC0\_BESR0 are accessed indirectly through the EBC0\_CFGADDR and EBC0\_CFGDATA registers using the **mfdcr** and **mtdcr** instructions.

It is possible to have both a parity error and a bus error during the same data transfer. If this occurs, the bus error is detected first and EBC0\_BESR0 and EBC0\_BEAR are updated. In the next cycle the parity error is detected and, if error locking is not enabled, logged in EBC0\_BESR0.





| 0:2 | EETO | Error type for master 0<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 0 is the processor instruction fetcher. |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| 3   | RWS0 | Read/write status for master 0<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                                |

| 4:5   |      | Reserved                                                                                                                                                                                              |                                      |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| 6:8   | EET1 | Error type for master 1<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 1 is the processor data side. |
| 9     | RWS1 | Read/write status for master 1<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                      |
| 10:11 |      | Reserved                                                                                                                                                                                              |                                      |
| 12:14 | EET2 | Error type for master 2<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 2 is the external bus master. |
| 15    | RWS2 | Read/write status for master 2<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                      |
| 16:17 |      | Reserved                                                                                                                                                                                              |                                      |
| 18:20 | EET3 | Error type for master 3<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 3 is the PCI bridge.          |
| 21    | RWS3 | Read/write status for master 3<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                      |
| 22    | FL3  | Field lock for master 3<br>0 EET3 and RWS3 fields are unlocked<br>1 EET3 and RWS3 fields are locked                                                                                                   |                                      |
| 23    | AL3  | EBC0_BEAR address lock for master 3<br>0 EBC0_BEAR address unlocked<br>1 EBC0_BEAR address locked                                                                                                     |                                      |
| 24:31 |      | Reserved                                                                                                                                                                                              |                                      |

### 16.7.4 Peripheral Bus Error Status Register 1 (EBC0\_BESR1)

The Peripheral Bus Error Status Register 1 (EBC0\_BESR1) records the occurrence and type of errors for transactions attempted on behalf of the MAL and DMA controllers. The contents of EBC0\_BESR1 are accessed indirectly through the EBC0\_CFGADDR and EBC0\_CFGDATA registers using the **mfdcr** and **mtdcr** instructions.

It is possible to have both a parity error and a bus error during the same data transfer. If this occurs the bus error is detected first and EBC0\_BESR1 and EBC0\_BEAR are updated. In the next cycle the parity error is detected and, if error locking is not enabled, logged in EBC0\_BESR1.



| Figure 16-20. Peripheral Bus Error Status Register 1 (EBC0_BESR1 | Figure 16-20. | Peripheral Bus | <b>Error Status</b> | <b>Register 1</b> | (EBC0 | _BESR1) |
|------------------------------------------------------------------|---------------|----------------|---------------------|-------------------|-------|---------|
|------------------------------------------------------------------|---------------|----------------|---------------------|-------------------|-------|---------|

| 0:2 | EET4 | Error type for master 4<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 4 is the MAL.            |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 3   | RWS4 | Read/write status for master 4<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                 |
| 4   | FL4  | Field lock for master 4<br>0 EET4 and RWS4 fields are unlocked<br>1 EET4 and RWS4 fields are locked                                                                                                   |                                 |
| 5   | AL4  | EBC0_BEAR address lock for master 4<br>0 EBC0_BEAR address unlocked<br>1 EBC0_BEAR address locked                                                                                                     |                                 |
| 6:8 | EET5 | Error type for master 5<br>000 No error<br>001 Parity error<br>010 Reserved<br>011 Reserved<br>100 Protection error<br>101 Reserved<br>110 External bus input error<br>111 External bus timeout error | Master 5 is the DMA controller. |
| 9   | RWS5 | Read/write status for master 5<br>0 Error operation was a write operation<br>1 Error operation was a read operation                                                                                   |                                 |

| 10    | FL5 | Field lock for master 5<br>0 EET5 and RWS5 fields are unlocked<br>1 EET5 and RWS5 fields are locked |
|-------|-----|-----------------------------------------------------------------------------------------------------|
| 11    | AL5 | EBC0_BEAR address lock for master 5<br>0 EBC0_BEAR address unlocked<br>1 EBC0_BEAR address locked   |
| 12:31 |     | Reserved                                                                                            |

16-34 PPC405GP User's Manual

# **Chapter 17. PCI Interface**

## 17.1 PCI Overview

The peripheral component interconnect (PCI) interface and bridge (referred to as PCI bridge in this chapter) provides a means for connecting PCI-compliant devices to the on-chip bus architecture of the PPC405GP chip. The PCI bridge complies with *PCI Specification*, Version 2.2. The PCI bridge is bidirectional in that it allows PPC405GP PLB masters to access PCI targets off-chip. It also allows PCI masters to access PLB slave devices such as the SDRAM controller. The PCI bridge contains an arbiter which can optionally be used for host applications.

The PCI bridge is configurable by an external PCI agent, allowing it to be used in target adapter applications. The PCI bridge contains address mapping register sets to provide address mapping for both transaction directions. See Figure 17-3 on page 17-5 for a graphic overview of the PCI bridge.

Agents on the PLB are referred to as masters or slaves. Agents on the PCI are referred to as targets or slaves.

### 17.1.1 PCI Bridge Features

- PLB bus frequency up to 100 MHz
- PCI bus frequency up to 66 MHz (asynchronous) or 33 MHz (synchronous)
- Asynchronous clocking between PLB and PCI buses (optional)
- Supports 1:1, 2:1, 3:1, and 4:1 clock ratios from PLB to PCI
- 32-bit PCI Address/Data Bus
- Power Management
- Buffering:
  - PCI target 64-byte write post buffer
  - PCI target 96-byte read prefetch buffer
  - PLB slave 32-byte write post buffer
  - PLB slave 64-byte read prefetch buffer
- Error tracking/status
- PCI arbitration function (optional)
- Supports PCI target-side configuration
- · Supports processor access to all PCI address spaces:
  - Single-beat PCI I/O reads and writes
  - PCI memory single-beat and prefetch-burst reads and single-beat writes
  - Single-beat PCI configuration reads and writes (type 0 and type 1)
  - PCI interrupt acknowledge

### 17.1.2 PCI Bridge Block Diagram

Figure 17-1 shows the PCI bridge block diagram.



Figure 17-1. PCI Bridge Block Diagram

### 17.1.3 Byte Ordering

The PCI bridge configuration register address space must be treated as little endian, as required by *PCI Specification*, Version 2.2. In most cases data memory areas in PCI address space will be configured and used in little endian format. To provide for this, PCI configuration space and memory map regions should be defined as little endian memory space by means of the corresponding entry in the PPC405GP CPU's MMU or by means of the appropriate memory region bit in the Storage Little-Endian Register (SLER) if the MMU is not being used. Because the endianness attribute in the SLER can only be applied to 128MB memory regions, this method of defining little endian memory space for PCI must be carefully considered in defining a system memory map.

Byte ordering and management of little endian memory space from a PowerPC CPU point of view is described in detail in "Byte Ordering" on page 3-28. PowerPC architecture and CoreConnect bus architecture both use a bit naming convention in which the most significant bit (msb) name incorporates the numeral 0 and the least significant bit (Isb name for a 32-bit vector incorporates the numeral 31. Table 17-1 shows the correspondence of address bit-naming conventions for PowerPC, CoreConnect PLB, and PCI interface.

| Functional Unit/Interface       | Word Address | Byte Address  |
|---------------------------------|--------------|---------------|
| PPC405GP Processor Core Address | A0:29        | A30:31        |
| CoreConnect — PLB Address Bus   | PLB_ABus0:29 | PLB_ABus30:31 |
| PCI Address Bus                 | AD31:2       | AD1:0         |

Table 17-2 shows the correspondence of data bus bit naming conventions and data lane connections for PowerPC, CoreConnect PLB, and PCI interface. Note that within a data lane (column), the data signal naming indicates that, for example, AD31is connected to PLB Write Data24.

| Table 17-2. PowerPC, CoreConnect PLB, and PCI Data Bus Bit-Na | aming Conventions |
|---------------------------------------------------------------|-------------------|
|---------------------------------------------------------------|-------------------|

| Functional Unit/ Interface                                                                                                 | Most Significant<br>Byte (MSB) | $\leftrightarrow$      | $\leftrightarrow$     | LeastSignificant<br>Byte (LSB) |
|----------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------|-----------------------|--------------------------------|
| Data Byte Value (0xnn)                                                                                                     | 11                             | 22                     | 33                    | 44                             |
| Little Endian Byte Address (0bnn)                                                                                          | 11                             | 10                     | 01                    | 00                             |
| PPC405GP Processor Core<br>(Write) Data Bus                                                                                | Data24:31                      | Data16:23              | Data8:15              | Data0:7                        |
| CoreConnect — PLB Write Data<br>Bus — Byte Group                                                                           | PLB Write<br>Data24:31         | PLB Write<br>Data16:23 | PLB Write<br>Data8:15 | PLB Write<br>Data0:7           |
| PLB Byte Enable                                                                                                            | PLB_BE3                        | PLB_BE2                | PLB_BE1               | PLB_BE0                        |
| PCI Byte Enable                                                                                                            | C/BE3                          | C/BE2                  | C/BE1                 | C/BE0                          |
| PCI Data Bus Byte Group                                                                                                    | AD31:24                        | AD23:16                | AD15:8                | AD7:0                          |
| Note 1: Logical data work (32-bit word) == 0x11223344                                                                      |                                |                        |                       |                                |
| Note 2: 405 CPU performing either:                                                                                         |                                |                        |                       |                                |
| <ul> <li>Store word to little endian memory space</li> <li>Store word—byte reversed—to big endian address space</li> </ul> |                                |                        |                       |                                |

## 17.1.4 Reference Information

.

| Subject          | Pointer                        |
|------------------|--------------------------------|
| PLB Overview     | Chapter 2, "On-Chip Bus"       |
| Register Summary | Chapter 25, "Register Summary" |
| Clocking         | Chapter 7, "Clocking"          |
| PCI              | PCI Specification, Version 2.2 |

## 17.2 PCI Bridge Functional Blocks

The following sections describe the PCI bridges and the associated arbiter.

### 17.2.1 PLB-to-PCI Half-Bridge

As shown in Figure 17-2, the 64-bit PLB slave interface and PCI master interface function together as a PLB-to-PCI half-bridge to enablePLB master devices to access PCI target devices. The half-bridge configuration contains a 32-byte write post buffer and a 64-byte read prefetch buffer.



Figure 17-2. PLB-to-PCI Half-Bridge Block Diagram

### 17.2.2 PCI-to-PLB Half-Bridge

As shown in Figure 17-3, the PCI target interface and 64-bit PLB master interface function together as a PCI-to-PLB half-bridge to enable PCI master devices to access PLB slave devices. The half-bridge configuration contains a 63-byte write post buffer and a 96-byte read prefetch buffer.



Figure 17-3. PCI-to-PLB Half-Bridge Block Diagram

#### 17.2.3 PCI Arbiter

The internal arbiter can be used with up to six external PCI masters (six Req/Gnt pairs) or can be disabled. When the internal arbiter is disabled, there is one Req/Gnt pair that must be attached to an external arbiter. A strapping pin determines whether the internal arbiter is enabled or not. Priority is round-robin (rotating). Priority switches when a master begins a transfer by asserting Frame. Each block keeps a priority bit that only switches if its highest priority requestor receives a grant. Assuming that all priority bits are initially cleared and all requests are active, an example rotation would be PPC405GP 3, 1, 5, 0, 4, 2. *PCI Specification*, Version 2.2 requires that all PCI devices three-state their pins during reset. The PPC405GP PCI arbiter supports bus parking during normal operation.

Figure 17-4 shows the logical arbitration structure.



Figure 17-4. Arbitration Structure

## 17.3 PCI Bridge Address Mapping

The following sections describe the address maps supported by the PCI bridge.

### 17.3.1 PLB-to-PCI Address Mapping

The PCI bridge responds as a slave on the PLB bus in several address ranges. These ranges enable a PLB master to configure the PCI bridge, and to cause the PCI bridge to generate memory, I/O, configuration, interrupt acknowledge, and special cycles to the PCI bus. Table 17-3 shows the address map from the view of the PLB, that is, as decoded by the PCI bridge as a PLB slave.

| PLB Address<br>Range      | Description                                                                                                                                                                                                          | PCI Address<br>Range      |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 0xE8000000<br>0xE800FFFF  | PCI I/O<br>Accesses to this range are translated to an I/O access on PCI<br>in the range 0 to $64KB - 1$ .                                                                                                           | 0x00000000-<br>0x0000FFFF |
| 0E8010000-<br>0E87FFFFF   | Reserved<br>PCI bridge does not respond.<br>(Other bridges use this space for non-contiguous I/O.)                                                                                                                   |                           |
| 0xE8800000-<br>0xEBFFFFFF | PCI I/O<br>Accesses to this range are translated to an I/O access on PCI<br>in the range 8MB to 64MB – 1.                                                                                                            | 0x00800000<br>0x03FFFFFF  |
| 0xEC000000-<br>0xEEBFFFFF | Reserved<br>PCI bridge does not respond                                                                                                                                                                              |                           |
| 0xEEC00000-<br>0xEECFFFFF | PCIC0_CFGADDR and PCIC0_CFGDATA<br>0xEEC00000: PCIC0_CFGADDR<br>0xEEC00004: PCIC0_CFGDATA<br>0xEEC00008-0xEECFFFF: Reserved (can mirror<br>PCIC0_CFGADDR and PCIC0_CFGDATA).                                         |                           |
| 0xEED00000-<br>0xEEDFFFFF | PCI Interrupt Acknowledge and Special Cycle<br>0xEED00000 read: Interrupt Acknowledge<br>0xEED00000 write: Special Cycle<br>0xEED00004–0xEEDFFFFF: Reserved (can mirror Interrupt<br>Acknowledge and Special Cycle). |                           |
| 0xEEE00000-<br>0xEF3FFFFF | Reserved<br>PCI bridge does not respond.                                                                                                                                                                             |                           |

Table 17-3. PLB Address Map

| PLB Address<br>Range                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PCI Address<br>Range                        |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| 0xEF400000-<br>0xEF4FFFF                 | PCI Bridge Local Configuration Registers<br>0xEF400000: PCIL0_PMM0LA<br>0xEF400008: PCIL0_PMM0PCILA<br>0xEF400008: PCIL0_PMM0PCILA<br>0xEF400010: PCIL0_PMM0PCIHA<br>0xEF400010: PCIL0_PMM1LA<br>0xEF400018: PCIL0_PMM1PCILA<br>0xEF400010: PCIL0_PMM1PCIHA<br>0xEF400020: PCIL0_PMM2LA<br>0xEF400024: PCIL0_PMM2PCILA<br>0xEF400028: PCIL0_PMM2PCILA<br>0xEF400028: PCIL0_PMM2PCIHA<br>0xEF400030: PCIL0_PTM1PCIHA<br>0xEF400030: PCIL0_PTM1LA<br>0xEF400030: PCIL0_PTM1LA<br>0xEF400030: PCIL0_PTM1LA<br>0xEF400030: PCIL0_PTM2PCIHA<br>0xEF400030: PCIL0_PTM2PCIHA<br>PCI_0XEF40<br>PCI_0XEF40<br>PCI_0XEF40<br>PCI_0XEF40<br>PC |                                             |
| 0x00000000-<br>0xFFFFFFFF <sup>/1*</sup> | PCI Memory—Range 0<br>PMM 0 registers map a region in PLB space to a region in PCI<br>memory space. The address ranges are fully programmable.<br>The PCI address is 64 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x000000000000000000-<br>0xFFFFFFFFFFFFFFFF |
| 0x00000000-<br>0xFFFFFFFF*               | PCI Memory—Range 1<br>PMM 1 registers map a region in PLB space to a region in PCI<br>memory space. The address ranges are fully programmable.<br>The PCI address is 64 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x000000000000000000<br>0xFFFFFFFFFFFFFFFF  |
| 0x00000000-<br>0xFFFFFFFF*               | PCI Memory—Range 2<br>PMM 2 registers map a region in PLB space to a region in PCI<br>memory space. The address ranges are fully programmable.<br>The PCI address is 64 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x00000000000000000-<br>0xFFFFFFFFFFFFFFFFF |

Table 17-3. PLB Address Map (continued)

\* Memory map ranges are fully programmable. The ranges must not overlap with each other or conflict with any other memory mappings.

Three PCI bridge address ranges, associated with PLB masters in PLB space, are mapped to PCI memory space: PCI master map (PMM) 0, PMM1, and PMM2.

Each PMM is configured using the following registers (n is 0, 1, or 2, corresponding with PMM0, PMM1, and PMM2, respectively):

- PMMnLocal Address (PCIL0\_PMMnLA)
- PMMnMask/Attribute (PCIL0\_PMMnMA)
- PMMnPCI Low Address (PCIL0\_PMMnPCILA)
- PMMnPCI High Address (PCIL0\_PMMnPCIHA)

The location of each PMM in PLB space is programmable, using the PCIL0\_PMMnLA registers. The PLB address range assigned to each PMM should not overlap any other PLB address space range that is used or reserved. Overlapping results in undefined behavior.

The range of PCI memory address space associated with each PMM is also programmable, and is a 64-bit address space to enable address translation between the PCI bus and the PLB. The PCIL0\_PMMnPCILA registers contain the low-order word of a PCI address; the PCIL0\_PMMnPCIHA registers contain the high-order word of a PCI address. If the high-order word of a PCI address is greater than 0, the PCI bridge generates dual address cycles to the PCI.

The size of each PMM is programmable, using the mask portion of the PCIL0\_PMMnMA registers. The size is a power of 2, ranging from 4KB–4GB. The PLB and PCI address spaces for each PMM are aligned to the size contained in the associated PCIL0\_PMMnMA registers.

The attribute portion of the PCIL0\_PMMnMA registers specify whether the associated PMM is enabled or disabled, and marked as prefetchable or not prefetchable.

Address ranges and attributes should be initialized before a PMM is enabled.

Figure 17-5 shows the detail of the PMM register sets used to map PLB memory regions to PCI address space.



Figure 17-5. PMM Register Sets Map PLB Address Space to PCI Address Space

### 17.3.2 PCI-to-PLB Address Mapping

The PCI bridge responds as a PCI target for memory accesses and configuration Type 0 accesses. Table 17-4 shows the PCI memory address map from the view of PCI, that is, as decoded by the PCI bridge as a PCI target.

| Table 17-4. P | CI Memory | Address Map |
|---------------|-----------|-------------|
|---------------|-----------|-------------|

| PCI Memory<br>Address     | Description                                                                                                                                                                                                                               | PLB Address               |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 0x00000000-<br>0xFFFFFFFF | System Memory or ROM—Range 0<br>PTM 1 maps a region of PCI memory space to PLB space, which can<br>map to system memory or ROM. Size and location is programmable.<br>The space supports address translation between the PCI and the PLB. | 0x00000000-<br>0xFFFFFFFF |
| 0x00000000-<br>0xFFFFFFFF | System Memory or ROM—Range 1<br>PTM 2 maps a region of PCI memory space to PLB space, which can<br>map to system memory or ROM. Size and location is programmable.<br>The space supports address translation between the PCI and the PLB. | 0x00000000-<br>0xFFFFFFFF |

### 17.3.3 PCI Target Map Configuration

Two PCI bridge address ranges in PCI memory space are mapped to PLB space: PCI target map (PTM1) and PTM2 (PTM0 is reserved).

Each PTM is configured using the following registers (n is 1 or 2, corresponding with PTM1 and PTM2, respectively).

- PTMnMemory Size (PCIL0\_PTMnMS)
- PTMnLocal Address (PCIL0\_PTMnLA)
- PTMnBAR (PCIL0\_PTMnBAR)

The size of each PTM is programmable, using the PCIL0\_PTMnMS registers. The size is a power of 2, and ranges from 4KB–4GB. The PLB and PCI address spaces for each PTM are aligned to this size.

The address range of PLB space accessed through each PTM is also programmable, enabling address translation between the PCI bus and the PLB. The PLB address range is defined in the PCIL0\_PTMnLA registers.

The location of each PTM in PCI memory space is programmable, using the PCIPCIL0\_PTMnBAR registers.

The PTMs are enabled and disabled using PCIC0\_CMD[MA]. PTM address ranges and sizes should be initialized before being enabled. If the PCI bridge is not the host bridge, the local processor must initialize the PTM size before enabling host configuration setting the Host Configuration Enable (HCE) field of the Bridge Options 2 register (PCIC0\_BRDGOPT2). This ensures that the host experiences proper behavior from the PCIL0\_PTMnBAR registers. Note that PTM1 is always enabled. The PTM1 registers must always be initialized.

Figure 17-6 shows the detail of the PMM/BAR register sets used to map PCI memory regions to PLB address space.



Figure 17-6. PTM Register Sets Map PCI Address Space to PLB Address Space

## 17.4 PCI Bridge Transaction Handling

The following sections discuss PCI bridge transactions and completion ordering.

### 17.4.1 PLB-to-PCI Transaction Handling

This section describes how the PCI bridge responds to read and write requests from a PLB master. The PCI bridge decodes and accepts PLB transactions to different address ranges resulting in the generation of memory, I/O, configuration, interrupt acknowledge and special cycles on the PCI bus.

| PLB Transaction<br>PLB Master → Bridge<br>(PLB Slave Interface) | Bridge Mapping and<br>Qualifications                              | PCI Transaction<br>Bridge (PCI Master Interface) → PCI<br>Target |
|-----------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------|
| Single-beat 1 $\rightarrow$ 8-byte Read                         | 64KB or 56MB PCI I/O<br>address range                             | I/O Read                                                         |
| Single-beat 1 $\rightarrow$ 8-byte Write                        | 64KB or 56MB PCI I/O<br>address range                             | I/O Write                                                        |
| Single-Beat 1 $\rightarrow$ 8-byte Read                         | Access to PCIC0_CFGDATA register                                  | Configuration Read (Type 0, 1)                                   |
| Single-Beat 1 $\rightarrow$ 8-byte Write                        | Access to PCIC0_CFGDATA register                                  | Configuration Write (Type 0, 1)                                  |
| Single-Beat 1 $\rightarrow$ 8-byte Read                         | PLB address decodes to<br>PMM0, PMM1, or PMM2,<br>nonprefetchable | Memory Read                                                      |
| Burst Read                                                      | PLB address decodes to<br>PMM0, PMM1, or PMM2,<br>nonprefetchable | Memory Read                                                      |
| PLB 4-word and 8-word Line Reads                                | PLB address decodes to<br>PMM0, PMM1, or PMM2                     | Memory Read Line                                                 |
| Single-Beat 1 $\rightarrow$ 4-byte Read                         | PLB address decodes to<br>PMM0, PMM1, or PMM2,<br>nonprefetchable | Memory Read Multiple                                             |
| Burst Read                                                      | PLB address decodes to<br>PMM0, PMM1, or PMM2,<br>nonprefetchable | Memory Read Multiple                                             |
| Single-Beat 1 $\rightarrow$ 4-byte Write                        | PLB address decodes to PMM0, PMM1, or PMM2                        | Memory Write                                                     |
| Burst Write                                                     | PLB address decodes to PMM0, PMM1, or PMM2                        | Memory Write                                                     |
| Single-Beat 1 $\rightarrow$ 4-byte Read                         | Address 0xFED00000                                                | Interrupt Acknowledge                                            |
| Single-Beat 1 $\rightarrow$ 4-byte Write                        | Address 0xFED00000                                                | Special Cycle                                                    |
|                                                                 | Not supported                                                     | Memory Write and Invalidate                                      |
|                                                                 | Not supported                                                     | Memory Write Line                                                |

Table 17-5. Transaction Mapping: PLB -> PCI

### 17.4.1.1 PCI Master Commands

The type of cycle generated to the PCI bus depends on the PLB address, the type of PLB transfer, and the data size. The following sections describe the transaction types supported and outlines the translation of commands from one bus to the other.

The terms "single beat" or "1–8-byte," in reference to PLB transfers, refer to the M\_size=0000 transaction type.

PCI bridge initiates the following commands as a PCI master:

I/O Read and I/O Write

This command is generated in response to PLB 1–8-byte read or write requests that decode to one of the two PCI I/O spaces.

• Configuration Read and Configuration Write (type 0 and type 1)

This command is generated in response to PLB 1–8-byte read or write requests that decode to the PCIC0\_CFGDATA register.

Memory Read

This command is generated in response to PLB 1–8-byte reads or byte and halfword burst reads that decode to one of the three PMMs when the PMM is marked as nonprefetchable.

Memory Read Line

This command is generated in response to PLB 4- and 8-word line reads or word and doubleword reads of 32 bytes or less that decode to one of the three PMMs.

• Memory Read Multiple

This command is generated in response to PLB 1–8-byte reads or byte and halfword burst reads that decode to one of the three PMMs when the PMM is marked as prefetchable. This command is also generated in response to word and doubleword burst reads of greater than 32 bytes that decode to one of the three PMMs. For prefetches, the PCI bridge bursts up to a 64 bytes from the PCI.

Memory Write

This command is generated in response to PLB 1–8-byte writes or burst writes to one of the three PMMs.

Interrupt Acknowledge

This command is generated in response to a PLB 1–8-byte read from address 0xEED00000.

• Special Cycle

This command is generated in response to a PLB 1–8-byte write to address 0xEED00000.

The Memory Write and Invalidate command is not generated. All PCI memory writes are performed with Memory Write.

The PLB slave responds as a 64-bit device to word and doubleword bursts. All other commands receive a 32-bit response.

The PCI bridge supports PLB size 1–8-byte encodings. Burst reads of all sizes are also supported. Read line sizes greater than eight words are not supported, and no line writes are supported. The PCI bridge posts all writes which are decoded to PCI memory and PCI I/O space. Posted data is kept in internal write buffers until it can be transferred to the PCI bus. All other writes and all reads are connected, that is, they complete on the PCI bus before completing on the PLB.

### 17.4.1.2 PLB Slave Read Handling

PLB master read requests are decoded into four types: PCI Memory, I/O, Configuration, and Interrupt Acknowledge. If the request falls within any of these ranges, and is a supported command type, the bridge claims the cycle initially by asserting a PLB wait signal (as opposed to a PLB address acknowledge signal). The bridge must first gain access to the PCI bus before acknowledging a PLB read request. The specific timing of the address acknowledge is dependent upon the type of transfer. All posted writes must be flushed before a read is allowed to complete.

For PLB line reads, the PCI bridge must wait for all read data to be received before acknowledging the PLB request. This is because PCI targets are allowed to disconnect in the middle of a transfer, and the PLB requires line transfers to be atomic. If the system can guarantee that PCI targets do not disconnect these reads, PCIC0\_BRDGOPT1[APLRM] can be set to 1. In this mode, line read performance is improved by having the bridge PLB slave assert an address acknowledge signal and begin its data tenure as soon as the first word is received on the PCI bus. If the above guarantee cannot be made, the setting of this bit could hang the bridge.

If the PCI cycle Master Aborts, all beats of read data are returned as 0xFFFFFFF.

PLB master reads to the PCI bridge configuration registers are allowed to execute regardless of whether any write data is posted in the bridge. The configuration registers are described in "PCI Bridge Configuration Registers" on page 17-19.

#### 17.4.1.3 Prefetching

When the PCI bridge receives a PLB 1–8-byte or byte or halfword burst read request that decodes to a PMM marked as nonprefetchable. The PCI bridge runs a single beat read to the PCI. If the PCI cycle is retried, the PLB cycle is rearbitrated.

When the PCI bridge receives a PLB 1–8-byte or byte or halfword burst read request that decodes to a PMM marked as prefetchable, the PCI bridge burst reads up to a 64 bytes from the PCI and saves the data in the PLB slave read prefetch buffer. Less than 64 bytes can be read if the PCI target disconnects, or if the PCI bridge PCI master disconnects due to a master latency time out. Note that PCI bridge prefetching is not affected by memory management page boundaries (PLB\_Guarded is ignored). If a subsequent PLB 1–8-byte or byte or halfword burst read is contained in the prefetch buffer, the data is returned to the PLB directly from the prefetch buffer, and no cycle is generated on the PCI.

If a PLB read to the PCI bridge occurs while the PCI bridge is prefetching and does not hit in the prefetch buffer, then the PLB read is rearbitrated. After prefetching completes, any PLB read (of any type or address range) to the PCI bridge that does not hit in the prefetch buffer causes the prefetch buffer to be emptied, and a new PCI read to begin. PLB writes, including configuration writes, will invalidate the prefetch buffer.

#### 17.4.1.4 PLB Slave Write Handling

PLB master write requests are decoded into four types: PCI Memory (one of three PMM ranges), PCI I/O, PCI Configuration, or Special Cycles. If the request falls within any of these ranges, and is a supported command type, the bridge claims the cycle by asserting a PLB wait signal. If the write is connected, or translates to a PCI Configuration or Special Cycle, the bridge must gain access to the PCI bus and successfully transfer the data before it may assert a PLB address acknowledge signal. If the address is to PCI I/O or memory, the bridge immediately asserts a PLB address acknowledge signal and posts the write if there is sufficient buffer space.

Internal configuration writes are not allowed to execute if posted write data exists in either the PCI slave write buffer or the PLB slave write buffer. The internal configuration mechanism is described in "PCI Bridge Configuration Registers" on page 17-19.

#### PLB Slave Write Post Buffer

The PCI bridge has a 32-byte write post buffer that may contain four separate single-beat PLB write transactions or one burst. New PLB write requests are rearbitrated if there is not enough room in the write post buffer.

The buffers are not snooped, and are always completed on the PCI bus in the same order as they are received on the PLB bus.

Each write buffer entry preserves the master ID and drives the appropriate PLB bus busy signal until the write is deallocated (it completes on the PCI bus). It is recommended that PLB masters do not use PLB bus busy signal. Instead, PLB masters generating cycles to the PCI should use the standard PCI mechanisms for data coherency.

#### 17.4.1.5 Aborted PLB Requests

The PCI bridge aborts PLB reads only.

A PLB master accessing the PCI bridge can abort PLB write cycles only under the following conditions:

- The PCI bridge rearbitrates the cycle.
- The PCI bridge does not see the cycle because the PLB bus is granted to some other master. A CPU/System Memory interface is expected to do this when a CPU cycle is pending to PCI bridge, but a PLB Master requests system memory access requiring snooping.
  - **Note:** If a PLB master aborts the write cycle at any other time, the results are undefined and the bus may hang.

#### 17.4.1.6 Retried PCI Reads

The PCI specification requires that a PCI master must repeat any read that is retried. The PCI bridge adheres to this requirement. It is only mentioned here because, under certain conditions with respect to aborted PLB reads, the PCI bridge must execute a PCI read and discard the data.

#### 17.4.2 PCI-to-PLB Transaction Handling

This section describes how PCI bridge handles read and write requests from a PCI master device. PCI bridge responds as a PCI target to PCI memory transactions when the PCI address is in one of the two PTM ranges and PCIC0\_CMD[MA] = 1. PCI bridge responds by claiming the PCI cycle and mastering a cycle on the PLB. PCI bridge is also a PCI target for configuration cycles when its PCIIDSel pin is active. PCI bridge will master abort if a configuration cycle is run to itself.

| PCI Transaction<br>PCI Master → Bridge (PCI Target<br>Interface) | Bridge Mapping and Qualifications                                          | PLB Transaction<br>Bridge (PLB Master Interface) $\rightarrow$ PLB<br>Slave |
|------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Single-Beat Memory Read                                          | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | 8-byte/doubleword read                                                      |
| Burst Memory Read                                                | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | 8-byte/doubleword read                                                      |
| Memory Read Line                                                 | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | Doubleword burst read                                                       |
| Memory Read Multiple                                             | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | Doubleword burst read                                                       |
| Memory Read                                                      | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | Doubleword burst read                                                       |
| Single-Beat Memory Write                                         | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | $1 \rightarrow 8$ -byte write                                               |
| Single-Beat Memory Write and Invalidate                          | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | 1 $\rightarrow$ 8-byte write                                                |
| Burst Memory Write                                               | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | Word burst write                                                            |
| Burst Memory Write and Invalidate                                | PCI address decodes<br>to PTM1/BAR1 or<br>PTM2/BAR2, memory<br>access flag | Word burst write                                                            |
|                                                                  | Not supported                                                              | Memory line reads                                                           |
|                                                                  | Not supported                                                              | Memory line writes                                                          |

Table 17-6. Transaction Mapping:  $PCI \rightarrow PLB$ 

#### 17.4.2.1 PLB Master Commands

PCI bridge generates PLB transactions based on the type and length of received PCI transactions. The following sections describe the transaction types supported and outline the translation of commands from one bus to the other.

The term "single-beat" refers to the M\_size = 0000 transaction type. PCI slave devices are referred to as "targets."

PCI bridge initiates the following PLB master commands:

• 8-Byte Read:

Generated in response to single beat or burst Memory Read commands from the PCI bus.

• Doubleword Burst Read:

Generated in response to Memory Read Line and Memory Read Multiple commands on the PCI bus. PCI bridge can also be programmed to perform doubleword bursts on behalf of Memory Read.

• 1–8-Byte Write:

Generated in response to single-beat (1–4 byte) Memory Write commands on the PCI bus; also generated when the PCI master uses non-contiguous byte enables (see "Byte Enable Handling" on page 17-17).

• Doubleword Burst Write:

Generated in response to burst Memory Write and Memory Write and Invalidate commands on the PCI bus.

The PLB treats Memory Write and Memory Write and Invalidate identically (nothing on the PLB distinguishes a Memory Write from a Memory Write and Invalidate.)

PCI bridge does not generate line reads or line writes on the PLB.

#### 17.4.2.2 Handling of Reads from PCI Masters

PCI bridge responds to PCI Memory Read, Memory Read Line, and Memory Read Multiple commands. The PCI bridge initiates all PLB reads as single-beat or doubleword burst transfers.

Memory Read generates a PLB single-beat doubleword read. Memory Read Line and Memory Read Multiple commands generate PLB doubleword bursts. For Memory Read Line, PCI bridge encodes a burst length on the byte enable pins of the PLB that corresponds to the number of doublewords from the start address to the end of a word boundary and terminates when the encoded number of words has been transferred. This is called a PLB fixed length burst. If the starting address is the last doubleword on a word boundary (typically, this should not occur), PCI bridge executes a single-beat read. For Memory Read Multiple, PCI bridge sets the byte enables to 0s, indicating a variable length burst.

The PCI target can be programmed to treat Memory Reads as Memory Read Line commands or Memory Read Multiple commands in terms of PLB read behavior.

The PCI bridge guarantees the PCI initial target latency requirement by retrying the PCI cycle if read data is not immediately available in the read buffer. Subsequent latency is programmable using PCIC0\_BRDGOPT2[STLD].

The PCI bridge master latency timer can limit the length of read bursts using PCIC0\_BRDGOPT1[MLTC]. The timer limits the duration of a burst to the programmed value in units of PLB clock cycles.

#### **Read Buffer**

The PCI bridge read buffer stores all read data (including delayed read and prefetched data) when the data is received from the PLB, before it is passed to the PCI. The 96-byte read buffer can store one transaction.

#### **Delayed Reads**

A delayed read is queued if a PCI master requests a read while PCI master writes are posted. Posted writes are completed on the PLB before the read is run. PCI bridge continues to post PCI master writes (if buffer space is available) while a delayed read is in progress. Such writes complete on the PLB after the read, even though they complete on the PCI before the read.

A delayed read is also queued if data is not immediately available in the read buffer and a delayed read does not already exist.

When a PCI master returns for a previously requested delayed read, the data is passed out of the read buffer. While the PCI master accepts delayed read data, the PCI bridge can begin to prefetch more read data, if the PCI master posted write buffer is empty. See "Read Prefetching" on page 17-16 for more details.

Any data remaining in the read buffer after delayed read data has been passed to a PCI master is marked as prefetch data and discarded upon a write in either direction.

PCI bridge can hold one delayed read transaction. PCI bridge retries all other PCI master reads until the delayed read completes on the PCI. The read buffer discards data from a delayed read under only one condition. The PCI discard timer is used to track the amount of time it takes for a PCI master to re-request the read. If the PCI master does not re-request the read in 2<sup>15</sup> PCI clocks (about one millisecond for a 33 MHz PCI clock), PCI bridge discards the delayed read data. This timer begins counting at the beginning of the initial PCI cycle (delayed read request). If PCI bridge is used in a system on which the PLB target (memory) maximum latency (including PLB arbitration) is a significant portion of the timer duration, the timer can expire despite normal bus operation. One solution to this problem is to disable the PCI Discard Timer.

If a delayed read is burst terminated on the PLB (a rare occurrence), PCI bridge will not repeat the request until the PCI master re-requests and only then if the PCI master requests more data than is already buffered.

#### **Read Prefetching**

PCI bridge attempts to prefetch data to maximize burst throughput on PCI read requests. Read prefetching occurs only in response to Memory Read Multiple commands or Memory Read, if the PCI target is programmed to treat them as Memory Read Multiple (Memory Read Line causes prefetching to the next word boundary only). This prefetch buffer is 96 bytes.

If a PCI master reads from the read buffer while a PLB read is in progress, data is passed to PCI as it is being filled from the PLB. If the read buffer goes empty long enough for the PCI subsequent latency timer to expire, the PCI is target disconnected. If the read buffer fills up, the PLB cycle is master terminated. The bridge PLB master will not attempt to reacquire the PLB bus if its posted write buffer is not empty.

Prefetched data is discarded if a write is accepted from either the PLB or the PCI. A PCI master read that misses the prefetch buffer also causes current read data to be discarded and the new request to be serviced.

#### **Byte Enable Handling**

PCI byte enables are treated as don't cares for PCI reads. The PCI bridge performs doubleword burst or single-beat doubleword reads on the PLB, regardless of the byte enables presented by the requesting PCI master.

Note: This rule assumes that all PLB memory is prefetchable and that all PLB memory accesses are nondestructive.

#### 17.4.2.3 Handling Writes from PCI Masters

PCI bridge responds to Memory Write and Memory Write and Invalidate commands. All PCI master writes are posted. A 64-byte write buffer is used for this purpose. The write buffer accepts up to two separate PCI write transactions. Two single-beat writes, one burst write, or a combination of a single-beat and a burst writes can be posted. If the write buffer is full, new writes are retried until buffer space becomes available.

**Note:** The maximum of two posted transactions is as viewed from the PCI master. The number of writes performed on the PLB can be more than two, depending on the setting of byte enables of write burst data. See "Byte Enable Handling" on page 17-17.

The PCI bridge begins a PLB write request as soon as a PCI master write has completed on the PCI bus, or a bursting PCI master has written at least six words of data. The PCI bridge continues to receive data from a bursting PCI master as it transfers data to the PLB. If the write post buffer fills, the PCI master is target disconnected. If the write post buffer empties, the PLB cycle is master terminated.

Writes are executed in the same order they are received.

#### Byte Enable Handling

The PLB does not support non-contiguous byte enables, whereas the PCI bus does. The PLB supports the use of byte enables only for non-line, non-burst transactions, whereas the PCI bus supports any combination of byte enables for any data phase. Therefore, when a PCI master presents a data phase without all byte enables asserted, the bridge disconnects and treats that data phase as one or two single-beat writes on PLB, depending on whether or not byte enables are non-contiguous.

Masters presenting writes without all byte enables asserted experience degraded performance.

#### 17.4.2.4 Miscellaneous

The PCI target forces single-beat transfers when reserved burst or cache line wrap order is used.

The PCI target causes master abort of reserved command encodings, and does not respond to I/O, interrupt acknowledge, or special cycle commands.

The PLB master does not abort requests.

## 17.4.3 Completion Ordering

PCI bridge implements the following completion ordering rules:

- 1. PCI master writes are accepted if there is room in the PCI write post buffer.
- 2. New PCI master reads are accepted if there is no delayed read (DRR or DRC) in progress:
  - a. If PCI write post buffer is empty and read data is not buffered, then begin a delayed read (enter DRR state).
  - b. If PCI write post buffer is not empty, then begin delayed read (enter DRR state).

Delayed reads are handled as follows:

- a. While in DRR state, retry all PCI master reads. Wait for all PCI master writes if any that were posted before entering DRR state to complete on PLB.
- b. Execute PLB read, enter DRC state.
- c. While in DRC state, retry all PCI master reads if the address does not match. If it does match, pass the read data to the PCI master. If data is passed, exit the DRC state.
- 3. PLB master writes are accepted if there is room in the PLB write post buffer.
- 4. PLB master reads are accepted if the PLB write post buffer and the PCI write post buffer are both empty.

### 17.4.3.1 PCI Producer-Consumer Model

The PCI Producer-Consumer model is followed with one exception: PCI master reads do not flush PLB writes and PCI master writes do not cause PLB prefetched read data to be discarded. If the "flag" is stored in system memory (PLB side), but the "data" is stored in a PCI target, the control software must manually force coherency. This can be done by following two rules:

- 1. To ensure data written by a PLB master has reached the intended PCI target, the PLB master should execute a read from PCI, to any nondestructive address. This is only necessary if the write is postable.
- 2. To ensure data read by a PLB master is current (rather than old prefetched data), the PLB master should execute a read from PCI to any other nondestructive address. This is only necessary if the read is prefetchable.

### 17.4.4 Collision Resolution

The PCI bridge must resolve collisions when a PLB master and a PCI master attempt accesses through the PCI bridge at the same time. Table 17-7 summarizes collision resolution.

In general, PLB postable writes are always accepted (if buffer space is available), and passed to the PCI when given the chance. PCI master writes are always accepted (if buffer space is available), but cause PLB reads and non-postable writes to be rearbitrated to clear the path to the PLB. PLB reads and non-postable writes proceed as long as there is no PCI master activity, which causes the PLB cycle to be rearbitrated. PCI master reads are always allowed to proceed, and cause PLB reads and non-postable writes to be rearbitrated.

Internal configuration accesses have their own rules. Configuration writes are not allowed to complete while any write data is posted in the PCI bridge, or while the PCI master is prefetching. Otherwise,

there are no restrictions. Configuration reads have no restrictions; however, only one internal configuration access (PLB or PCI side) may be serviced at a time.

| Access Type       | PLB Read from PCI                           | PLB Postable Write to PCI | PLB Non-postable<br>Write to PCI |  |  |  |
|-------------------|---------------------------------------------|---------------------------|----------------------------------|--|--|--|
| PCI Write to PLB  | Rearbitrate PLB master (reads flush writes) | No conflict               | Rearbitrate PLB master           |  |  |  |
| PCI Read from PLB | Rearbitrate PLB master                      | No conflict               | Rearbitrate PLB master           |  |  |  |

Table 17-7. Collision Resolution

## 17.5 PCI Bridge Configuration Registers

The PCI bridge has two sets of configuration registers for configuring the bridge, handling errors, and reporting status. Local configuration registers control PLB functions, and are accessed only from the PLB. The PCI configuration registers control PCI functions, and can be accessed from the PLB and the PCI. In addition, the mechanism used to access the bridge configuration registers may also be used to configure other devices on the PCI bus.

### 17.5.1 PCI Bridge Register Summary

Table 17-8 provides a summary of all of the PCI bridge registers. The registers are discussed in detail in the following sections. See Chapter 8, "Reset and Initialization," for register reset values.

| Register        | Address    | Access | Description                 | Page  |
|-----------------|------------|--------|-----------------------------|-------|
| PCILO_PMM0LA    | 0xEF400000 | R/W    | PMM 0 Local Address         | 17-21 |
| PCILO_PMM0MA    | 0xEF400004 | R/W    | PMM 0 Mask/Attribute        | 17-25 |
| PCIL0_PMM0PCILA | 0xEF400008 | R/W    | PMM 0 PCI Low Address       | 17-22 |
| PCIL0_PMM0PCIHA | 0xEF40000C | R/W    | PMM 0 PCI High Address      | 17-23 |
| PCIL0_PMM1LA    | 0xEF400010 | R/W    | PMM 1 Local Address         | 17-23 |
| PCIL0_PMM1MA    | 0xEF400014 | R/W    | PMM 1 Mask/Attribute        | 17-21 |
| PCIL0_PMM1PCILA | 0xEF400018 | R/W    | PMM 1 PCI Low Address       | 17-24 |
| PCIL0_PMM1PCIHA | 0xEF40001C | R/W    | PMM 1 PCI High Address      | 17-25 |
| PCIL0_PMM2LA    | 0xEF400020 | R/W    | PMM 2 Local Address         | 17-25 |
| PCIL0_PMM2MA    | 0xEF400024 | R/W    | PMM 2 Mask/Attribute        | 17-25 |
| PCIL0_PMM2PCILA | 0xEF400028 | R/W    | PMM 2 PCI Low Address       | 17-26 |
| PCIL0_PMM2PCIHA | 0xEF40002C | R/W    | PMM 2 PCI High Address      | 17-27 |
| PCIL0_PTM1MS    | 0xEF400030 | R/W    | PTM 1 Memory Size/Attribute | 17-27 |
| PCIL0_PTM1LA    | 0xEF400034 | R/W    | PTM 1 Local Address         | 17-27 |
| PCIL0_PTM2MS    | 0xEF400038 | R/W    | PTM 2 Memory Size/Attribute | 17-28 |
| PCIL0_PTM2LA    | 0xEF40003C | R/W    | PTM 2 Local Address         | 17-28 |

Table 17-8. Directly Accessed MMIO Registers

| Register      | Address    | Access | Description                        |
|---------------|------------|--------|------------------------------------|
| PCIC0_CFGADDR | 0xEEC00000 | R/W    | PCI Configuration Address Register |
| PCIC0_CFGDATA | 0xEEC00004 | R/W    | PCI Configuration Data Register    |

### Table 17-9. PCI Configuration Address and Data Registers

### Table 17-10. PCI Configuration Register Offsets

|                                 |           | Acc   | ess |                                                                                                                            |
|---------------------------------|-----------|-------|-----|----------------------------------------------------------------------------------------------------------------------------|
| Register                        | Offset    | PLB   | PCI | Description                                                                                                                |
| PCIC0_VENDID                    | 0x01–0x00 | R/W   | R   | PCI Vendor ID                                                                                                              |
| PCIC0_DEVID                     | 0x03-0x02 | R/W   | R   | PCI Device ID                                                                                                              |
| PCIC0_CMD                       | 0x05-0x04 | R/W   | R/W | PCI Command Register                                                                                                       |
| PCIC0_STATUS                    | 0x07–0x06 | R/W   | R/W | PCI Status Register                                                                                                        |
| PCIC0_REVID                     | 0x08      | R/W   | R/W | PCI Revision ID                                                                                                            |
| PCIC0_PCICLS                    | 0x0B-0x09 | R/W   | R   | PCI Class Register                                                                                                         |
| PCIC0_CACHELS                   | 0x0C      | R     | R   | PCI Cache Line Size                                                                                                        |
| PCIC0_LATTIM                    | 0x0D      | R/W   | R/W | PCI Latency Timer                                                                                                          |
| PCIC0_HDTYPE                    | 0x0E      | R     | R   | PCI Header Type                                                                                                            |
| PCIC0_BIST                      | 0x0F      | R     | R   | PCI Built In Self Test Control                                                                                             |
| Reserved PCI BAR                | 0x13-0x10 | R     | R   | Reserved, PCI BAR                                                                                                          |
| PCIC0_PTM1BAR                   | 0x17-0x14 | R/W   | R/W | PCI PTM 1 BAR                                                                                                              |
| PCIC0_PTM2BAR                   | 0x1B-0x18 | R/W   | R/W | PCI PTM 2 BAR                                                                                                              |
| Reserved PCI BAR                | 0x1F-0x1C | R     | R   | Reserved PCI BAR. Refer to <i>PCI Specification</i> ,<br>Version 2.2 for more information on values.                       |
| Reserved PCI BAR                | 0x23-0x20 | R     | R   | Reserved PCI BAR. Refer to <i>PCI Specification</i> ,<br>Version 2.2 for more information on values.                       |
| Reserved PCI BAR                | 0x270x24  | R     | R   | Reserved PCI BAR. Refer to <i>PCI Specification</i> ,<br>Version 2.2 for more information on values.                       |
| Reserved Cardbus<br>CIS Pointer | 0x2B-0x28 | R     | R   | Reserved Cardbus CIS Pointer. Refer to <i>PCI</i><br>Specification, Version 2.2 for more information on values.            |
| PCIC0_SBSYSVID                  | 0x2D-0x2C | R/W   | R   | PCI Subsystem Vendor ID                                                                                                    |
| PCIC0_SBSYSID                   | 0x2F-0x2E | R/W · | R   | PCI Subsystem ID                                                                                                           |
| Reserved Exp ROM<br>Base Addr   | 0x33–0x30 | R     | R   | Reserved Expansion ROM Base Address. Refer<br>to <i>PCI Specification</i> , Version 2.2 for more<br>information on values. |
| PCIC0_CAP                       | 0x34      | R     | R   | PCI Capabilities Pointer                                                                                                   |
| Reserved                        | 0x3B-0x35 | R     | R   | Reserved                                                                                                                   |
| PCIC0_INTLN                     | 0x3C      | R/W   | R/W | PCI Interrupt Line                                                                                                         |
| PCIC0_INTPN                     | 0x3D      | R     | R   | PCI Interrupt Pin                                                                                                          |
| PCIC0_MINGNT                    | 0x3E      | R     | R   | PCI Minimum Grant                                                                                                          |
| PCICO_MAXLTNCY                  | 0x3F      | R     | R   | PCI Maximum Latency                                                                                                        |
| PCIC0_PCIICS                    | 0x44      | R/W   | R/W | PCI Interrupt Control/Status                                                                                               |

|                |           | Access |     |                                                   |
|----------------|-----------|--------|-----|---------------------------------------------------|
| Register       | Offset    | PLB    | PCI | Description                                       |
| PCIC0_ERREN    | 0x48      | R/W    | R/W | Error Enable                                      |
| PCIC0_ERRSTS   | 0x49      | R/W    | R/W | Error Status                                      |
| PCIC0_BRDGOPT1 | 0x4B-0x4A | R/W    | R/W | PCI Bridge Options 1                              |
| PCIC0_PLBBESR0 | 0x4F-0x4C | R/W    | R/W | PLB Slave Error Syndrome 0                        |
| PCIC0_PLBBESR1 | 0x53-0x50 | R/W    | R/W | PLB Slave Error Syndrome 1                        |
| PCIC0_PLBBEAR  | 0x57–0x54 | R/W    | R/W | PLB Slave Error Address Register                  |
| PCIC0_CAPID    | 0x58      | R      | R   | Capability Identifier                             |
| PCIC0_NEXTIPTR | 0x59      | R      | R   | Next Item Pointer                                 |
| PCIC0_PMC      | 0x5B-0x5A | R      | R   | Power Management Capabilities                     |
| PCIC0_PMCSR    | 0x5D-0x5C | R/W    | R/W | Power Management Control Status                   |
| PCIC0_PMCSRBSE | 0x5E      | R      | R   | PMCSR PCI-to-PCI Bridge Support Extensions        |
| PCIC0_DATA     | 0x5F      | R      | R   | Data                                              |
| PCIC0_BRDGOPT2 | 0x63-0x60 | R/W    | R/W | PCI Bridge Options 2                              |
| PCIC0_PMSCRR   | 0x64      | R/W    | R/W | Power Management State Change Request<br>Register |

Table 17-10. PCI Configuration Register Offsets (continued)

### 17.5.2 PCI Bridge Local Configuration Registers

The PCI bridge local configuration registers have fixed addresses in PLB space and must be accessed using single beat PLB read or write cycles of the same size as shown in the register descriptions.

Failure to access all bytes of a particular register could produce unexpected results. Reading of reserved bit locations produces unpredictable values. Software must use appropriate masks to extract the desired bits. Writes must preserve the values of reserved bit positions by first reading the register, merging the new value, and writing the result.

### 17.5.2.1 PMM 0 Local Address Register (PCIL0\_PMM0LA)

PCIL0\_PMM0LA defines the PLB starting address of range 0 in PLB space that is mapped to PCI memory. Only bits that are 1 in the PCIL0\_PMM0MA are used to determine the starting address; all other bits are don't cares. Only bits 31:12 are writable. Bits 11:0 are always 0.



| Figure 17-7. | PMM 0 Local | Address | Register | (PCILO | _PMM0LA) |
|--------------|-------------|---------|----------|--------|----------|
|--------------|-------------|---------|----------|--------|----------|

| 31:12 | WLA | Writable PLB Local Address |          |  |
|-------|-----|----------------------------|----------|--|
| 11:0  |     | PLB Local Address          | Always 0 |  |

### 17.5.2.2 PMM 0 Mask/Attribute Register (PCIL0\_PMM0MA)

PCIL0\_PMM0MA controls the size and attributes of the PLB space mapped to PCI memory for range 0.



#### Figure 17-8. PMM 0 Mask/Attribute Register (PCIL0\_PMM0MA)

| 31:12 | MASK | The mask bits determine the size of the address map range.       | The mask must be of the form 1110000.<br>Bits set to 1 cause the corresponding<br>PCIL0_PMM0LA bits to be compared with<br>incoming PLB addresses. Note that the<br>minimum range size is 4KB, and valid<br>ranges are powers of 2. For example, a<br>128MB range would be encoded as<br>0xF8000 and a 4KB range would be<br>encoded as all ones. |
|-------|------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:2  |      | Reserved                                                         | Returns 0 when read.                                                                                                                                                                                                                                                                                                                              |
| 1     | PRE  | Read Prefetching Enable<br>1 Read prefetching is enabled.        | If read prefetch is enabled, the PCI bridge<br>prefetches 64 bytes from PCI memory in<br>response to a PLB single-beat, byte-burst,<br>or half word burst read from PMM 0.                                                                                                                                                                        |
| 0     | ENA  | PLB to PCI Memory Mapping Enable<br>1 Memory mapping is enabled. | Note that PCIL0_PMM0LA,<br>PCIL0_PMM0PCIHA, and<br>PCIL0_PMM0PCILA must be initialized<br>before enabling.                                                                                                                                                                                                                                        |

### 17.5.2.3 PMM 0 PCI Low Address Register (PCIL0\_PMM0PCILA)

PCIL0\_PMM0PCILA defines the low-order 32 bits of the PCI address generated in response to a PLB access to range 0. Only bits that are 1 in PCIL0\_PMM0MA are passed to the PCI address. The other (least significant) bits of the PCI address are passed through from the PLB address. Only bits 31:12 are writable. Bits 11:0 are always 0.



#### Figure 17-9. PMM 0 PCI Low Address Register (PCIL0\_PMM0PCILA)

| 31:12 | WLA | Writable PCI Low Address |          |  |
|-------|-----|--------------------------|----------|--|
| 11:0  |     | PCI Low Address          | Always 0 |  |

### 17.5.2.4 PMM 0 PCI High Address Register (PCIL0\_PMM0PCIHA)

PCIL0\_PMM0PCIHA defines the high-order 32 bits of the PCI address generated in response to a PLB access to range 0. If PCIL0\_PMM0PCIHA is greater than 0, the PCI bridge generates a PCI dual address cycle using the value in PCIL0\_PMM0PCIHA as the high-order 32 bits of the PCI address.

|    |      | <br> |  |
|----|------|------|--|
| 31 |      | <br> |  |
|    | <br> |      |  |

| Figure 17-10. PMM 0 High Address Register (PCIL0_PMM0PCIHA) |  |
|-------------------------------------------------------------|--|
|-------------------------------------------------------------|--|

| 31:0 | PCI High Address |
|------|------------------|
| <br> |                  |

#### 17.5.2.5 PMM 1 Local Address Register (PCIL0\_PMM1LA)

PCIL0\_PMM1LA defines the PLB starting address of range 1 in PLB space that is mapped to PCI memory. See "PMM 0 Local Address Register (PCIL0\_PMM0LA)" on page 17-21.

\_\_\_\_\_

#### Figure 17-11. PMM 1 Local Address Register (PCIL0\_PMM1LA)

| 31:0 | PLB Local Address |      |      |
|------|-------------------|------|------|
|      |                   | <br> | <br> |

31

0

### 17.5.2.6 PMM 1 Mask/Attribute Register (PCIL0\_PMM1MA)

PCIL0\_PMM1MA defines the size and attributes of range 1 in PLB space that is mapped to PCI memory. See "PMM 0 Mask/Attribute Register (PCIL0\_PMM0MA)" on page 17-22.



| 31:12 | MASK | The mask bits determine the size of the address map range.       | The mask must be of the form 1110000.<br>Bits set to 1 cause the corresponding<br>PCIL0_PMM1LA bits to be compared with<br>incoming PLB addresses. Note that the<br>minimum range size is 4KB, and valid<br>ranges are powers of 2. For example, a<br>128MB range would be encoded as<br>0xF8000 and a 4KB range would be<br>encoded as 0x11111. |  |  |  |
|-------|------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 11:2  |      | Reserved                                                         | Returns 0 when read.                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 1     | PRE  | Read Prefetching Enable<br>1 Read prefetching is enabled.        | If read prefetch is enabled, the PCI bridge<br>prefetches 64 bytes from PCI memory in<br>response to a PLB single-beat, byte-burst,<br>or half word burst read from PMM 0.                                                                                                                                                                       |  |  |  |
| 0     | ENA  | PLB to PCI Memory Mapping Enable<br>1 Memory mapping is enabled. | Note that PCIL0_PMM1LA,<br>PCIL0_PMM1PCIHA, and<br>PCIL0_PMM1PCILA must be initialized<br>before enabling.                                                                                                                                                                                                                                       |  |  |  |

#### Figure 17-12. PMM 1 Mask/Attribute Register (PCIL0\_PMM1MA)

#### 17.5.2.7 PMM 1 PCI Low Address Register (PCIL0\_PMM1PCILA)

PCIL0\_PMM1PCILA defines the low-order 32 bits of the PCI address generated in response to a PLB access to range 1. See "PMM 0 PCI Low Address Register (PCIL0\_PMM0PCILA)" on page 17-22.

31

| Figure 17-13. | PMM 1 PCI Low | Address Register | (PCIL0_PMM1PCILA) |
|---------------|---------------|------------------|-------------------|
|               |               | naarooo nogiotor |                   |

| 31: | n l | PCI Low Address |
|-----|-----|-----------------|
|     |     |                 |

0

### 17.5.2.8 PMM 1 PCI High Address Register (PCIL0\_PMM1PCIHA)

PCIL0\_PMM1PCIHA defines the high-order 32 bits of the PCI address generated in response to a PLB access to range 1. See "PMM 0 PCI High Address Register (PCIL0\_PMM0PCIHA)" on page 17-23.

| 131 |   | <br> | <br> | <br> | <br> | <br> |    |
|-----|---|------|------|------|------|------|----|
| 51  | 0 |      |      |      |      |      | 31 |

#### Figure 17-14. PMM 0 High Address Register (PCIL0\_PMM0PCIHA)

#### 17.5.2.9 PMM 2 Local Address Register (PCIL0\_PMM2LA)

PCIL0\_PMM2LA defines the PLB starting address of range 2 in PLB space that is mapped to PCI memory. See "PMM 0 Local Address Register (PCIL0\_PMM0LA)" on page 17-21.

| 31:0 | - | PLB Local Address |
|------|---|-------------------|
|      |   |                   |

#### 17.5.2.10 PMM 2 Mask/Attribute Register (PCIL0\_PMM2MA)

PCIL0\_PMM2MA defines the size and attributes of range 2 in PLB space that is mapped to PCI memory. See "PMM 0 Mask/Attribute Register (PCIL0\_PMM0MA)" on page 17-22.



Figure 17-16. PMM 2 Mask/Attribute Register (PCIL0\_PMM2MA)

| 31:12 | P. MASK The mask bits determine the size of the address map range. |                                                                  | The mask must be of the form 1110000.<br>Bits set to 1 cause the corresponding<br>PCIL0_PMM2LA bits to be compared with<br>incoming PLB addresses. Note that the<br>minimum range size is 4KB, and valid<br>ranges are powers of 2. For example, a<br>128MB range would be encoded as<br>0xF8000 and a 4KB range would be<br>encoded as 0x11111. |  |  |
|-------|--------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 11:2  | 11:2 Reserved                                                      |                                                                  | Returns 0 when read.                                                                                                                                                                                                                                                                                                                             |  |  |
| 1     | 1 PRE Read Prefetching Enable<br>1 Read prefetching is enabled.    |                                                                  | If read prefetch is enabled, the PCI bridge<br>prefetches 64 bytes from PCI memory in<br>response to a PLB single-beat, byte-burst,<br>or half word burst read from PMM 0.                                                                                                                                                                       |  |  |
| 0     | ENA                                                                | PLB to PCI Memory Mapping Enable<br>1 Memory mapping is enabled. | Note that PCIL0_PMM2LA,<br>PCIL0_PMM2PCIHA, and<br>PCIL0_PMM2PCILA must be initialized<br>before enabling.                                                                                                                                                                                                                                       |  |  |

## 17.5.2.11 PMM 2 PCI Low Address Register (PCIL0\_PMM2PCILA)

PCIL0\_PMM2PCILA defines the low-order 32 bits of the PCI address generated in response to a PLB access to range 2. See "PMM 0 PCI Low Address Register (PCIL0\_PMM0PCILA)" on page 17-22.

| 31 ( | 5] |
|------|----|

#### Figure 17-17. PMM 2 Low Address Register (PCIL0\_PMM2PCILA)

| 31:0 | <br>PCI Low Address |   |
|------|---------------------|---|
|      |                     | L |

## 17.5.2.12 PMM 2 PCI High Address Register (PCIL0\_PMM2PCIHA)

PCIL0\_PMM2PCIHA defines the high-order 32 bits of the PCI address generated in response to PLB access to range 2. See "PMM 0 PCI High Address Register (PCIL0\_PMM0PCIHA)" on page 17-23.

| l | 21 |    |
|---|----|----|
|   |    | 01 |

#### Figure 17-18. PMM 2 PCI High Address Register (PCIL0\_PMM2PCIHA)

| 31:0 | PCI High Address |  |
|------|------------------|--|
|      |                  |  |

## 17.5.2.13 PTM 1 Memory Size/Attribute Register (PCIL0\_PTM1MS)

PCIL0\_PTM1MS defines the size and attributes of the of PCI memory region mapped to local (PLB) space through PTM 1. PCIL0\_PTM1MS affects the operation of PCI PTM 1 BAR.



Figure 17-19. PTM 1 Memory Size/Attribute Register (PCIL0\_PTM1MS)

| 31:12                                                                                                  | MASK | Defines the size of the region of PCI<br>memory space that is mapped to local<br>(PLB) space using PTM 1. | The minimum range size is 4KB. Valid<br>ranges are always a power of 2.<br>For example, a value of 0xFF000000<br>indicates that the region contains 16MB. |  |  |
|--------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 11:1 Reserved                                                                                          |      | Reserved                                                                                                  | Returns 0 when read.                                                                                                                                      |  |  |
| 0 EMM Determines if range 1 is enabled to map<br>PCI memory space to PLB space.<br>Always 1 (enabled). |      |                                                                                                           |                                                                                                                                                           |  |  |

## 17.5.2.14 PTM 1 Local Address Register (PCIL0\_PTM1LA)

PCIL0\_PTM1LA defines the local (PLB) address that is generated in response to a PCI access to local (PLB) space through PTM 1. Only bits that are 1 in PCIL0\_PTM1MS are passed to the PLB address. The other (least significant) bits of the PLB address are passed through from the PCI address. Only bits 31:12 are writable. Bits 11:0 are always 0.

ΕŃΑ



#### Figure 17-20. PTM 2 Local Address Register (PCIL0\_PTM1LA)

| 31:12 | 31:12 WLA Writable PTM 1 Local Address |  | Writable |  |
|-------|----------------------------------------|--|----------|--|
| 11:0  | 11:0 PTM 1 Local Address               |  | Always 0 |  |

#### 17.5.2.15 PTM 2 Memory Size/Attribute Register (PCIL0\_PTM2MS)

PCIL0\_PTM2MS defines the size of the region of PCI memory space mapped to local (PLB) space through PTM 2.

|    | SIZE   |           |
|----|--------|-----------|
| 31 | •••••• | 12 11 1 0 |
|    |        | ∱<br>ENA  |

Figure 17-21. PTM 2 Memory Size/Attribute Register (PCIL0\_PTM2MS)

| 31:12 | MASK | Defines the size of the region of PCI<br>memory space mapped to local (PLB)<br>space using PTM 2. | The minimum range size is 4KB. Valid<br>ranges are always a power of 2.<br>For example, a value of 0xFF000000<br>indicates that the region contains 16MB. |
|-------|------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:1  |      | Defines the size of the region of PCI<br>memory space mapped to local (PLB)<br>space using PTM 2. | The minimum range size is 4KB. Valid<br>ranges are always a power of 2.<br>For example, a value of 0xFF000000<br>indicates that the region contains 16MB. |
| 0     | ЕММ  | Determines if range 2 is enabled to map<br>PCI memory space to PLB space.                         | When EMM is disabled, PCIC0_PTM2BAR cannot be written. Set PCIC0_PTM2BAR to 0 before disabling EMM.                                                       |

### 17.5.2.16 PTM 2 Local Address Register (PCIL0\_PTM2LA)

This register defines the local (PLB) address generated in response to a PCI access to local (PLB) space through PTM 2. See "PTM 1 Local Address Register (PCIL0\_PTM1LA)" on page 17-27 for more information.



Figure 17-22. PTM 2 Local Address Register (PCIL0\_PTM2LA)

| 21.0 | <br>PTM 2 Local Address |
|------|-------------------------|
| 31.0 | r Im 2 Local Address    |

### 17.5.3 PCI Configuration Registers

The PCI configuration registers can be accessed from both the PLB and PCI buses.

PLB side configuration is supported using the mechanism defined in the *PCI Local Bus Specification* Version 2.2. This mechanism uses PCIC0\_CFGADDR and PCIC0\_CFGDATA to access the configuration registers indirectly. These registers reside at addresses 0xEEC00000 and 0xEEC00004, respectively.

To access (from the PLB side) the configuration space of other devices on the PCI bus, write a value to PCIC0\_CFGADDR that specifies the following:

- Bus number
- · Device number on that bus
- · Register number to be accessed

The value must also set PCIC0\_CFGADDR[EN] = 1. An access to PCIC0\_CFGDATA then results in a configuration cycle on the PCI bus.

To access the bridge configuration registers from the PLB side, use the same mechanism as described above, but set PCIC0\_CFGADDR[BN, DN] = 0. The bridge is assumed to reside on PCI bus 0 and to have a device number of 0.

The bridge configuration registers can be accessed from the PCI side by Type 0 configuration reads or writes, with the PCIIDSel pin asserted to the bridge. There are some restrictions on PCI side accesses that are noted in the register descriptions that follow.

PCIC0\_CFGADDR and CONFIG\_DATA should be accessed with single-beat PLB commands. All registers are byte addressable. Reading of reserved bit locations produces unpredictable values. Software must use appropriate masks to extract the desired bits. Writes must preserve the values of reserved bit positions by first reading the register, merging the new value, and writing the result.

### 17.5.3.1 PCI Configuration Address Register (PCIC0\_CFGADDR)

PCIC0\_CFGADDR controls the type of cycle generated when PCIC0\_CFGDATA is accessed. Its fields are shown in Figure 17-23.



Figure 17-23. PCI Configuration Address Register (PCIC0\_CFGADDR)

| 31    | EN            | Enable<br>0 Disabled<br>1 Enabled |
|-------|---------------|-----------------------------------|
| 30:24 | and in the st | Reserved                          |
| 23:16 | BN            | Bus Number                        |
| 15:11 | DN            | Device Number                     |
| 10:8  | FN            | Function Number                   |
| 7:2   | RN            | Register Number                   |
| 1     | 0             |                                   |
| 0     | 0             |                                   |

See the PCI Local Bus Specification Version 2.2 for details about how the fields are used.

#### 17.5.3.2 PCI Configuration Data Register (PCIC0\_CFGDATA)

Accessing PCIC0\_CFGDATA causes one of three things to happen, depending on the value of PCIC0\_CFGADDR.

- 1. Generation of a Type 0 configuration cycle on the PCI bus (PCIC0\_CFGADDR[BN] = 0, PCIC0\_CFGADDR[DN] > 0).
- 2. Generation of a Type 1 configuration cycle on the PCI bus (PCIC0\_CFGADDR[BN] > 0).
- 3. Access of a PCI bridge PCI configuration register (PCIC0\_CFGADDR[BN, DN] = 0).

Figure 17-24 illustrates the PCIC0\_CFGDATA register.

| 31 |  |  |  |
|----|--|--|--|
|    |  |  |  |
|    |  |  |  |

Figure 17-24. PCI Configuration Data Register (PCIC0\_CFGDATA)

| 31:0 Configuration Data |
|-------------------------|
|-------------------------|

0

### 17.5.3.3 PCI Vendor ID Register (PCIC0\_VENDID)

PCIC0\_VENDID identifies the manufacturer of a PCI device. This register contains 0x1014 (index 0x00 = 0x14, index 0x01 = 0x10) at reset. This vendor ID is assigned for all IBM PCI devices. The local CPU (PLB master) can write a different value to this register.

|     | <br> | <br> |
|-----|------|------|
| 16  |      | 0    |
| 110 |      | 01   |
| 1   |      |      |
|     |      | <br> |

Figure 17-25. PCI Vendor ID Register (PCIC0\_VENDID)

| 15:0 |   | Vendor ID |
|------|---|-----------|
| 10.0 |   | vendor iD |
|      | • |           |
|      |   |           |

### 17.5.3.4 PCI Device ID Register (PCIC0\_DEVID)

PCIC0\_DEVID identifies the PCI device. This value is 0x0156 (index 0x03 = 0x01, index 0x02 = 0x56) at reset. The local CPU (PLB master) can write a different value to this register.

15 0)

#### Figure 17-26. PCI Device ID Register (PCIC0\_DEVID)

| 15.0 | PCI Device ID |
|------|---------------|
| 15:0 |               |
|      |               |

### 17.5.3.5 PCI Command Register (PCIC0\_CMD)

PCIC0\_CMD controls the operation of the PCI bridge on the PCI bus. Figure 17-27 describes the bits.



Figure 17-27. PCI Command Register (PCIC0\_CMD)

| 15:10 | •   | Reserved                                         | •                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | FBB | Fast Back-to-Back Write Enable                   | Enables PCI masters to perform fast back-<br>to-back transactions. Because he PCI<br>bridge does not perform fast back-to-back<br>transactions; FBB is read-only and returns<br>0 when read.                                                                                                                                                                                                                                                             |
| 8     | SE  | PCISErr Enable<br>0 Disabled<br>1 Enabled        | Enables driving PCISErr when a PCI bus<br>parity error is detected when the PCI<br>bridge is the PCI target. PCICO_CMD[PER]<br>must be enabled for address parity errors.<br>PCICO_CMD[PER] and<br>PCICO_ERREN[WDPE] must be enabled<br>for write data parity errors.                                                                                                                                                                                    |
| 7     | AS  | Address stepping wait states.                    | The PCI bridge does not address step<br>(except for address stepping when<br>generating a Config Type 0 cycle); AS is<br>read-only and returns 0 when read.                                                                                                                                                                                                                                                                                              |
| 6     | PER | Parity error response<br>0 Disabled<br>1 Enabled | <ul> <li>This bit is enabled for all types of PCI bus<br/>parity errors, including the following:</li> <li>PCI data bus parity errors while PCI is<br/>master.</li> <li>PCI data bus parity errors while PCI is<br/>target.</li> <li>PCI address bus parity errors.</li> <li>When parity error response is disabled,<br/>detection of these errors is masked and<br/>PCIPErr (PERR#) is not asserted, although<br/>parity is still generated.</li> </ul> |
| 5     | PS  | Palette Snooping                                 | Enable special palette snooping.<br>The PCI bridge is not a VGA device; PS is<br>read-only and returns 0 when read                                                                                                                                                                                                                                                                                                                                       |
| 4     | MWI | Memory Write and Invalidate Enable               | The PCI bridge does not generate this<br>command; MWI is read-only and returns 0<br>when read.                                                                                                                                                                                                                                                                                                                                                           |
| 3     | SC  | Special Cycle Operations Enable                  | The PCI bridge never monitors special cycles; SC is read-only and returns 0 when read.                                                                                                                                                                                                                                                                                                                                                                   |

| 2 | ME  | Master Enable<br>0 Disabled<br>1 Enabled | Enables PCI bridge-to-master cycles on<br>the PCI bus. When ME is 0, the PCI bridge<br>only responds as a PLB slave to<br>PCIC0_CFGADDR, PCIC0_CFGDATA,<br>and PCI bridge local configuration register<br>access. Except for configuration cycles, the<br>PCI bridge cannot master cycles to the PCI<br>bus. If the pin strapping setting reflected in<br>CPC0_PSR[RL] = 1, ME resets to 1. |
|---|-----|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | MA  | Memory Access<br>0 Disabled<br>1 Enabled | Controls PCI bridge response as a PCI memory target. MA is disabled at reset.                                                                                                                                                                                                                                                                                                               |
| 0 | IOA | I/O Access                               | Controls the PCI bridge response as a PCI<br>I/O target. The PCI bridge does not<br>respond to I/O space accesses; IOA is<br>read-only and returns 0 when read.                                                                                                                                                                                                                             |

# 17.5.3.6 PCI Status Register (PCIC0\_STATUS)

PCIC0\_STATUS is a read/bit-reset register used to record status information for PCI bus events. Bits in PCIC0\_STATUS are set only as a result of specific events occurring on the PCI bus. They are reset by writing a 1 to the desired bit. Writing a 0 to a bit location leaves that bit unchanged.



| 15 | DEPE | Detected Parity Error<br>Write 1 to clear. | <ul> <li>The PCI bridge sets DEPE when the PCI bridge detects a PCI bus parity error, regardless of the setting of any enable bits (DEPE is non-maskable).</li> <li>The following events set DEPE:</li> <li>PCI address bus parity error detected when PCI bridge is a target.</li> <li>PCI data bus parity error detected when a PCI master writes to PLB memory (PCI bridge is the target).</li> <li>PCI data bus parity error detected when PCI bridge masters a PCI read cycle.</li> </ul> |
|----|------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14 | SSE  | Signaled System Error<br>Write 1 to clear. | The PCI bridge sets SSE if the PCI bridge<br>asserts PCISErr (see "Error Handling" on<br>page 17-55 for causes of PCISErr<br>assertion).                                                                                                                                                                                                                                                                                                                                                       |

| 13   | RMA  | Received Master Abort<br>Write 1 to clear.                                                                      | The PCI bridge sets RTA when a PCI cycle<br>for which the PCI bridge is the master is<br>terminated with master abort.                                                                                                                                                                                      |
|------|------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RTA  | Received Target Abort<br>Write 1 to clear.                                                                      | The PCI bridge sets RTA when a PCI cycle<br>for which it is the master is terminated with<br>target abort.                                                                                                                                                                                                  |
| 11   | STA  | Signaled Target Abort<br>Write 1 to clear.                                                                      | The PCI bridge sets STA when a PCI cycle<br>for which it is the target is terminated with<br>target abort.                                                                                                                                                                                                  |
| 10:9 | DST  | PCIDevSel Response Timing<br>Read-only.                                                                         | The PCI bridge asserts <u>PCIDevSel</u> on the<br>second clock after <u>PCIFframe</u> is asserted<br>(called medium response time).<br>Read-only; always returns 0b01 when<br>read.                                                                                                                         |
| 8    | DPE  | Data Parity Error Detected<br>Write 1 to clear.                                                                 | <ul> <li>DPE is set when the following conditions are met:</li> <li>The PCI bridge detects a data parity error (PCIPErr is asserted) when the PCI bridge is the master on a PCI read cycle, or is the master when it samples PCIPErr asserted on a PCI write cycle.</li> <li>PCIC0_CMD[PER] = 1.</li> </ul> |
| 7    | FBBC | Fast Back-to-Back Capable<br>Read-only; returns 0 when read.                                                    | Indicates that the PCI target can accept<br>fast back-to-back transactions when the<br>transactions are not to the same agent.<br>The PCI bridge target does not accept this<br>type of fast back-to-back transaction.                                                                                      |
| 6    | UDFS | UDF Supported<br>Read-only; returns 0 when read.                                                                | Indicates device support of user-definable features. The PCI bridge does not support user-definable features.                                                                                                                                                                                               |
| 5    | 66C  | <ul> <li>66 MHz Capable</li> <li>0 At reset</li> <li>1 PCI bridge is configured for 66MHz operation.</li> </ul> | Indicates that the device can run at 66<br>MHz. The PCI bridge can be configured to<br>run at 33 MHz max or 66 MHz. The local<br>CPU (PLB master) sets 66C to 1 if PCI<br>bridge is configured for 66 MHz operation.                                                                                        |
| 4    | CL   | Capabilities List<br>This bit is read only and returns 1 when<br>read.                                          | Indicates that the value at offset 0x34 is a pointer in configuration space to a linked list of new capabilities.                                                                                                                                                                                           |
| 3:0  |      | Reserved                                                                                                        | These bits return 0s when read.                                                                                                                                                                                                                                                                             |

# 17.5.3.7 PCI Revision ID Register (PCIC0\_REVID)

PCIC0\_REVID holds the current incremental revision number. The reset value is the version number of the PCI bridge macro (first version is 00). However, the local CPU (PLB master) can write a value to this register.

|   |      | <br> |
|---|------|------|
| 7 |      | 0    |
| L | <br> |      |

Figure 17-29. PCI Revision ID Register (PCIC0\_REVID)

| 7:0 | Revision ID | Revision level of device. |
|-----|-------------|---------------------------|
|     |             |                           |

### 17.5.3.8 PCI Class Register (PCIC0\_CLS)

This register holds the class code. This register is 0x060000 at reset, which indicates that the PCI bridge is a bridge device located between the PLB and the PCI bus; however, the local CPU (PLB master) can write a value to this register for the case where PCI bridge is not the host bridge.

Class information is defined in the PCI Local Bus Specification, Version 2.2.



| 23:16 | BASE | Base Class      | Reset to 0x06, which indicates bridge<br>device.<br>Users of the RISCWatch debugger must<br>use the PCIC0_BASECC register to<br>access this field. |
|-------|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8  | SUB  | Subclass        | Reset to 00, which indicates host bridge.<br>Users of the RISCWatch debugger must<br>use the PCIC0_SUBCLS register to<br>access this field.        |
| 7:0   | INT  | Interface Class | Reset to 00.<br>Users of the RISCWatch debugger must<br>use the PCIC0_INTCLS register to access<br>this field.                                     |

Figure 17-30. PCI Class Register (PCIC0\_PCICLS)

### 17.5.3.9 PCI Cache Line Size Register (PCIC0\_CACHELS)

PCIC0\_CACHELS determines the size of a PCI cache line. PCI bridge does not support a PCI cache. Therefore, this register is read-only and returns 0x00 when read.



Figure 17-31. PCI Cache Line Size Register (PCIC0\_CACHELS)

| 7:0 PCI Cache Line Size |
|-------------------------|
|-------------------------|

### 17.5.3.10 PCI Latency Timer Register (PCIC0\_LATTIM)

PCICO\_LATTIM holds the value of the PCI latency timer. The granularity of the latency timer is 8 PCI cycles. Therefore, the 3 low-order bits of this register are read-only and return 0x111.



#### Figure 17-32. PCI Latency Timer Register (PCIC0\_LATTIM)

| 7:0 | <br>PCI Latency Timer |  |
|-----|-----------------------|--|
|     |                       |  |

PCI Local Bus Specification Version 2.2 specifies that PCI masters capable of multi-beat bursts must, after losing their PCI grant, get off the bus after a number of clock cycles equivalent to the value in PCIC0\_LATTIM.

The actual number of clock cycles to disconnect varies somewhat when in asynchronous mode. If PCIC0\_LATTIM is programmed in asynchronous mode to a value that is less than 64, the PCI bridge PCI master interface could timeout, regardless of the state of its grant line.

In asynchronous mode, the PCI master starts its timer and can timeout regardless of the state of the PCI grant. This is strictly a performance issue and does not limit functionality or affect data integrity.

Several factors affect the frequency of timeouts.

- The amount of PCI bus traffic. In moderate to heavily loaded systems, this is less of an issue because a PCI master tends to lose its grant more often after gaining the bus.
- Fast targets that introduce few or no wait states reduce the chances of timeouts occurring.

## 17.5.3.11 PCI Header Type Register (PCIC0\_HDTYPE)

PCIC0\_HDTYPE (bits 0:6) identifies the second part of the PCI header, which begins at offset 0x10. It also determines whether a device contains multiple functions (bit 7). The PCI bridge implements the

standard header and is not a multi-function device; therefore, PCIC0\_HDTYPE is read-only and returns 0x00 when read.



### Figure 17-33. PCI Header Type Register (PCIC0\_HDTYPE)

| 7:0 | PCI Header Type |
|-----|-----------------|
|     |                 |

### 17.5.3.12 PCI Built-In Self Test (BIST) Control Register (PCIC0\_BIST)

PCIC0\_BIST is used for control and status of BIST. PCI bridge does not implement BIST. PCIBIST is read-only and returns 0x00 when read.



#### Figure 17-34. PCI Built-in Self Test Control Register (PCIC0\_BIST)

| 7:0 | PCI BIST Control | <br> | <br> |  |
|-----|------------------|------|------|--|
| 1   |                  |      |      |  |

#### 17.5.3.13 Unused PCI Base Address Register Space

PCI base address register space is defined to begin at offset 0x10; however, the first 32 bits of this space are unused by PCI bridge, and the defined base address registers begin at offset 0x14.

#### 17.5.3.14 PCI PTM 1 BAR (PCIC0\_PTM1BAR)

PCIC0\_PTM1BAR defines a space in PCI memory space mapped to PLB space (system memory or ROM).

17-37



Figure 17-35. PCI PTM 1 BAR Register (PCIC0\_PTM1BAR)

| 31:12 | BA  | Base Address<br>These bits determine where in PCI memory<br>address space this region is located. | Only corresponding bits in PCIL0_PTM1MS<br>that are set to 1 are writable. Bits in<br>PCIL0_PTM1MS that are set to 0 cause<br>the corresponding Base Address register<br>bits to be always 0. PCIL0_PTM1MS must<br>be initialized by a PLB master before any<br>PCI device is allowed to configure this<br>register. |
|-------|-----|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:4  | BAZ | Base Address Always Zero                                                                          | BAZ = 0x00 because the minimum size of this range is 4KB.                                                                                                                                                                                                                                                            |
| 3     | PF  | Prefetchable                                                                                      | PR = 1 to indicate that prefetching is allowed.                                                                                                                                                                                                                                                                      |
| 2:1   | LT  | Location Type                                                                                     | LT = 0b00 to indicate that the memory<br>space can be located anywhere in the 32-<br>bit address space.                                                                                                                                                                                                              |
| 0     | MSI | Memory Space Indicator                                                                            | MSI = 0 to indicate memory space, rather than I/O space.                                                                                                                                                                                                                                                             |

## 17.5.3.15 PCI PTM 2 BAR (PCIC0\_PTM2BAR)

PCIC0\_PTM2BAR defines a second space in PCI memory space that is mapped to PLB space (system memory or ROM). Note that if PCIC0\_PTM2BAR is disabled using PCIL0\_PTM2MSA, PCIC0\_PTM2BAR cannot be written. Set PCIC0\_PTM2BAR to 0 before disabling this bit. If disabled in this way, reads to PCIC0\_PTM2BAR always return 0.



Figure 17-36. PCI PTM 2 BAR Register (PCIC0\_PTM2BAR)

| 31: | 12 BA | Base Address<br>These bits determine where in PCI<br>Memory address space this region is<br>located. | Only corresponding bits in<br>PCILO_PTM2MS that are set to 1 are<br>writable. Bits in PCILO_PTM2MS that<br>are set to 0 cause the corresponding<br>Base Address register bits to be always<br>0. PCILO_PTM2MS must be initialized<br>by a PLB master before any PCI device<br>can configure this register. |
|-----|-------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11: | 4 BAZ | Base Address Always Zero                                                                             | BAZ = 0x00 because the minimum size of this range is 4KB.                                                                                                                                                                                                                                                  |
| 3   | PF    | Prefetchable                                                                                         | PF = 1 to indicate that prefetching is allowed.                                                                                                                                                                                                                                                            |
| 2:1 | LT    | Location Type                                                                                        | LT = 0b00 to indicate that the memory<br>space can be located anywhere in the<br>32-bit address space.                                                                                                                                                                                                     |
| 0   | MSI   | Memory Space Indicator                                                                               | MSI = 0 to indicate memory space,<br>rather than I/O space.                                                                                                                                                                                                                                                |

## 17.5.3.16 PCI Subsystem Vendor ID Register (PCIC0\_SBSYSVID)

PCIC0\_SBSYSVID holds the vendor ID for a subsystem or add-in board.

15 0

Figure 17-37. PCI Subsystem Vendor ID Register (PCIC0\_SBSYSVID)

```
15:0 PCI Subsystem Vendor ID
```

## 17.5.3.17 PCI Subsystem ID Register (PCIC0\_SBSYSID)

PCIC0\_SBSYSID holds the device ID of a subsystem or add-in board.



#### Figure 17-38. PCI Subsystem ID Register (PCIC0\_SBSYSID)

| 15:0 | PCI Subsystem ID | <br> |  |
|------|------------------|------|--|
|      |                  |      |  |

## 17.5.3.18 PCI Capabilities Pointer (PCIC0\_CAP)

PCIC0\_CAP contains an 8-bit pointer in configuration space to the next capability. This data structure is indicated by PCIC)\_STATUS[CL]. PCIC0\_CAP points to the first item in the list of capabilities at address offset 0x58, which is the PCI power management capability structure.



#### Figure 17-39. PCI Capabilities Pointer (PCIC0\_CAP)

| 7:0 | PCI Capabilities Pointer |
|-----|--------------------------|
|     |                          |

### 17.5.3.19 PCI Interrupt Line Register (PCIC0\_INTLN)

PCIC0\_INTLN contains interrupt line routing information.



### Figure 17-40. PCI Interrupt Line Register (PCIC0\_INTLN)

| 7:0 | · · | PCI Interrupt Line |  |
|-----|-----|--------------------|--|
|     |     |                    |  |

# 17.5.3.20 PCI Interrupt Pin Register (PCIC0\_INTPN)

PCIC0\_INTPN specifies the PCI interrupt line that the device uses. The value 0x01 indicates INTA#.



### Figure 17-41. PCI Interrupt Pin Register (PCIC0\_INTPN)

| 7:0 | PCI Interrupt Pin |
|-----|-------------------|
|     |                   |

## 17.5.3.21 PCI Minimum Grant Register (PCIC0\_MINGNT)

PCIC0\_MINGNT specifies the burst period length of a PCI device. PCIC0\_MINGNT is read-only and returns 0x00 when read.



#### Figure 17-42. PCI Minimum Grant Register (PCIC0\_MINGNT)

| 7:0 | PCI Minimum Grant |
|-----|-------------------|
| L   |                   |

### 17.5.3.22 PCI Maximum Latency Register (PCIC0\_MAXLTNCY)

PCIC0\_MAXLTNCY specifies how often a PCI device needs to access to the PCI bus. PCIC0\_MAXLTNCY is read-only and returns 0x00 when read.

| 7 | 0    |
|---|------|
|   | <br> |

#### Figure 17-43. PCI Maximum Latency Register (PCIC0\_MAXLTNCY)

| 7:0 PCI Maximum Latency |
|-------------------------|
|-------------------------|

## 17.5.3.23 PCI Interrupt Control/Status Register (PCIC0\_ICS)

A PLB master or a PCI master device may generate an interrupt to the PCI bus by writing a 1 to bit 0. Clearing this bit clears the interrupt. Bit 0 also reports the status of the interrupt. A value of 1 means that the interrupt is asserted, a value of 0 means that the interrupt is deasserted.

7 1 0

Figure 17-44. PCI Interrupt Control/Status Register

| 7:1 |     | Reserved            | These bits return 0 when read.                                         |
|-----|-----|---------------------|------------------------------------------------------------------------|
| 0 / | API | Asset PCI interrupt | When software sets this bit, the PCI bridge asserts its Interrupt pin. |

## 17.5.3.24 Error Enable Register (PCIC0\_ERREN)

ERREN enables detection and reporting of various errors for the PCI bridge (see "Error Handling" on page 17-55).



| 7 |      | Reserved                                             |                                                                                                                                                                                        |
|---|------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | TAEE | Target Abort Error Enable<br>0 Disabled<br>1 Enabled | While the PCI bridge is the PCI master,<br>this bit enables the detection of a target<br>abort as an error condition. If TAEE is<br>enabled, the PCI bridge reports PLB bus<br>errors. |

| 5:4 | MERE | <ul> <li>PLB Bus Error Response Enable</li> <li>00 No action is taken.</li> <li>01 The PCI target should drive PCISErr on the PCI bus.</li> <li>10 Target should target abort the offending read.</li> <li>11 Indicates the PCI target should drive PCISErr and target abort.</li> </ul> | MERE controls the response taken by the<br>PCI bridge on the PCI bus (as the PCI<br>target) when PLB bus errors are asserted<br>to the PCI bridge PLB master.<br>Note: Only reads can be target aborted.<br>Note: Modes 10 and 11 cannot be used in<br>asynchronous mode.              |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | MEDE | PLB Master Error Detection Enable<br>0 Disables detection of PLB master errors.<br>1 Enables detection of PLB master errors.                                                                                                                                                             | MEDE enables the detection of PLB bus errors when the PCI bridge is a PLB master.                                                                                                                                                                                                      |
| 2   | MEAE | PLB Bus Error Assertion Enable<br>0 Disabled<br>1 Enabled                                                                                                                                                                                                                                | MEAE enables the reporting of a PLB bus error when the PCI bridge is a PLB slave.                                                                                                                                                                                                      |
| 1   | WDPE | Write Data Parity PCISErr Enable<br>0 Disabled<br>1 Enabled.                                                                                                                                                                                                                             | The PCI bridge drives PCISErr when a data parity error is detected on a write cycle when the PCI bridge is the PCI target. PCIC0_CMD[SE] must also be 1.                                                                                                                               |
| 0   | MAEE | Master Abort Error Enable<br>0 Disabled<br>1 Enabled                                                                                                                                                                                                                                     | MAEE enables the detection of a master<br>abort as an error condition when the PCI<br>bridge is the master. The PCI bridge drives<br>SI_MErr on the PLB bus in response to a<br>master abort. If this bit is disabled, driving<br>of SI_Merr in response to master abort is<br>masked. |

# 17.5.3.25 Error Status Register (PCIC0\_ERRSTS)

PCIC0\_ERRSTS contains status for detected error conditions (see "Error Handling" on page 17-55). Bits in PCIC0\_ERRSTS can be set to 1 only as the result of a system error. Writing a 1 to a PCIC0\_ERRSTS bit clears the bit. Writing a 0 to a bit leaves that bit unchanged.



| Figure 17-46. | <b>Error Status</b> | Register ( | (PCIC0_ERRSTS) |
|---------------|---------------------|------------|----------------|
|               |                     |            |                |

| 7:5 |       | Reserved                                      |                                                                                                                                   |
|-----|-------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 4   | SARME | PCISErr Asserted on Received PLB Bus<br>Error | Set when PCI bridge asserts PCISErr on<br>the PCI bus in response to PCI bridge<br>receiving a PLB bus error while PLB<br>master. |

| 3 | MED  | PLB Bus Error Detected<br>1 Error detected                                                            | Set when a PLB bus error signal is<br>asserted when PCI bridge is the PLB<br>master. MED is set regardless of whether<br>the PCI bridge is enabled to treat this as an<br>error condition (the setting of MED is not<br>maskable).       |
|---|------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | MEAE | PLB Bus Error Assertion Event<br>1 An PCI bridge error, which can cause a<br>PLB bus error, occurred. | Set when an error occurs that would cause<br>PCI bridge (as PLB slave) to assert a PLB<br>bus error signal. MEAE is set regardless of<br>whether the the PLB bus error assertion is<br>enabled (the setting of MEAE is not<br>maskable). |
| 1 | WDPE | PCISerr on Write Data Parity Error                                                                    | Set when the PCI bridge drives PCISErr in response to a data parity error detected on a PCI write to PLB memory. PCIPErr is also driven.                                                                                                 |
| 0 | PUR  | PLB Unsupported Request                                                                               | Set when the PCI bridge is a PLB slave<br>and detects an unsupported request from<br>a PLB master to an address range that PCI<br>bridge decodes. The PCI bridge allows<br>such requests to time out.                                    |

# 17.5.3.26 Bridge Options 1 Register (PCIC0\_BRDGOPT1)

PCIC0\_BRDGOPT1 controls various operating parameters of the PCI bridge. The parameters must be initialized before PCI masters access the PCI bridge.



| 15:8 | PMLTCR | PLB Master Latency Timer Count Register                                                                 | PMLTCR contains the value used by the<br>PLB master to load its latency timer. The<br>granularity of this timer is 16 PLB cycles;<br>therefore, the low-order bits of this<br>register are read-only and are hardwired<br>to 1. |
|------|--------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | PLESE  | PLB Lock Error Status Enable<br>0 Slave error locking is disabled.<br>1 Slave error locking is enabled. | PLESE controls the handling of slave error locking.                                                                                                                                                                             |

| 6:5 | PRP    | PLB Request Priority<br>11 Highest<br>10 Next highest<br>01 Next highest<br>00 Lowest                                                                                              | PRP controls the request priority for PLB accesses.                                                                                                                                                                                                                          |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | PGMAE  | <ul> <li>PLB Guarded Memory Access Enable</li> <li>0 Bridge PLB master memory accesses<br/>are unguarded.</li> <li>1 Bridge PLB master memory accesses<br/>are guarded.</li> </ul> | PGMAE controls whether PLB accesses are guarded or unguarded.                                                                                                                                                                                                                |
| 3   | PAPM   | <ul> <li>PCI Arbiter Park Mode</li> <li>The arbiter parks on requester 0 (the bridge PCI master).</li> <li>The arbiter parks on the last master granted the bus.</li> </ul>        | PAPB defines how the internal PCI arbiter handles bus parking.                                                                                                                                                                                                               |
| 2:1 | PTMRCI | PCI Target Memory Read Command<br>Interpretation<br>00 Memory Read<br>01 Memory Read Line<br>10 Memory Read Multiples<br>11 Reserved                                               | PTMRCI enables the PCI bridge to be<br>forced to treat a PCI memory read as a<br>memory read multiple, or as a memory<br>read line, with respect to the burst size<br>implied by the read commands. This is for<br>masters that use memory read for multiple<br>beat bursts. |
| 0   | APLRM  | Atomic PLB Line Read Mode<br>0<br>1 PLB slave asserts Addrack and begins<br>its data tenure immediately after the PCI<br>master receives the first read data word.                 | APLRM controls the behavior of the<br>bridge PLB slave with respect to PLB line<br>reads. APLRM must not be set to 1<br>unless all PCI target devices can<br>guarantee no disconnects for PLB line<br>reads.                                                                 |

# 17.5.3.27 PLB Slave Error Syndrome Register 0 (PCIC0\_PLBBESR0)

PCIC0\_PLBBESR0 stores information about errors reported by the PCI bridge PLB slave. There are four groups of errors, one each for PLB masters 0–3. PCIC0\_PLBBESR0[MxET] fields (x represents a particular PLB master ID) contain information about the type of error. PCI parity errors set PCIC0\_PLBBESR0[MxET] to 0b001. Master and target aborts set PCIC0\_PLBBESR0[MxET] to 0b101 (non-configured bank error). The PCIC0\_PLBBESR0[MxRWS] fields show whether the transaction causing the error was a read or write.

Each error field can be locked by PCIC0\_PLBBESR0[MxFL], which is set by a PLB lock error signal to the bridge PLB slave. If the PCIC0\_PLBBESR0[MxFL] field associated with a master is 0, the PLB lock error signal is driven high to the bridge PLB slave, and an error associated with that master occurs. The error is then reported, and PCIC0\_PLBBESR0[MxFL] is set. Subsequent errors do not set PCIC0\_PLBBESR0 fields for that master until PCIC0\_PLBBESR0[MxFL] is cleared. If PCIC0\_PLBBESR0[MxFL] = 0, and the PLB lock error signal is low, the error is reported, and PCIC0\_PLBBESR0[MxFL] is not set. Additional errors are also reported. Only software can clear PCIC0\_PLBBESR0[MxFL].

Writing 1 to a PCIC0\_PLBBESR0 field clears the field.



| Figure 17-48. PLE | 3 Slave Error S | vndrome Re | eqister 0 (I | PCIC0 PLBBE | SR0) |
|-------------------|-----------------|------------|--------------|-------------|------|
|-------------------|-----------------|------------|--------------|-------------|------|

| 31:29 | MOET  | Master 0 Error Type<br>000 No Error<br>001 Parity Error<br>010 Reserved<br>011 Reserved<br>100 Reserved           |                          |
|-------|-------|-------------------------------------------------------------------------------------------------------------------|--------------------------|
|       |       | 101 Non-configured Bank Error<br>110 Reserved<br>111 Reserved                                                     |                          |
| 28    | MORWS | Master 0 Read/Write Status<br>0 Error operation was a write<br>1 Error operation was a read                       |                          |
| 27    | MOFL  | Master 0 PCIC0_PLBBESR0 Field Lock<br>0 PCIC0_PLBB ESR0 unlocked<br>1 PCIC0_PLBB ESR0 locked                      |                          |
| 26    | MOAL  | Master 0 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 0<br>1 PCIC0_PLBBEAR locked by Master 0 |                          |
| 25:23 | M1ET  | Master 1 Error Type                                                                                               | See PCIC0_PLBBESR0[M0ET] |
| 22    | M1RWS | Master 1 Read/Write Status<br>0 Error operation was a write<br>1 Error operation was a read                       |                          |
| 21    | M1FL  | Master 1 PCIC0_PLBBESR0 Field Lock<br>0 PCIC0_PLBB ESR0 unlocked<br>1 PCIC0_PLBB ESR0 locked                      |                          |
| 20    | M1AL  | Master 1 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 1<br>1 PCIC0_PLBBEAR locked by Master 1 |                          |
| 19:17 | M2ET  | Master 2 Error Type                                                                                               | See PCIC0_PLBBESR0[M0ET] |
| 16    | M2RWS | Master 2 Read/Write Status<br>0 Error operation was a write<br>1 Error operation was a read                       |                          |
| 15    | M2FL  | Master 2 PCIC0_PLBBESR0 Field Lock<br>0 PCIC0_PLBB ESR0 unlocked<br>1 PCIC0_PLBB ESR0 locked                      |                          |
| 14    | M2AL  | Master 2 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 2<br>1 PCIC0_PLBBEAR locked by Master 2 |                          |

| 13:11 | МЗЕТ                                     | Master 3 Error Type                                                                                               | See PCIC0_PLBBESR0[M0ET] |
|-------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------|
| 10    | M3RWS                                    | Master 3 Read/Write Status<br>0 Error operation was a write<br>1 Error operation was a read                       |                          |
| 9     | M3FL                                     | Master 3 PCIC0_PLBBESR0 Field Lock<br>0 PCIC0_PLBBESR0 unlocked<br>1 PCIC0_PLBBESR0 locked                        |                          |
| 8     | M3AL                                     | Master 3 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR Unlocked by Master 2<br>1 PCIC0_PLBBEAR Locked by Master 2 |                          |
| 7:0   | A SA | Reserved                                                                                                          |                          |

## 17.5.3.28 PLB Slave Error Syndrome Register 1 (PCIC0\_PLBBESR1)

PCIC0\_PLBBESR1 stores information about errors reported by the bridge PLB slave. There are four groups of errors, one each for PLB masters 4–7. See "PLB Slave Error Syndrome Register 0 (PCIC0\_PLBBESR0)" on page 17-45 for additional information about the fields of this register.

Only software can clear PCIC0\_PLBBESR1[MxFL]. The PCIC0\_PLBBESR1[MxAL] fields control the and PCIC0\_PLBBESR0 and PCIC0\_PLBBESR1 in the same way. Writing a 1 to a field of the PCIC0\_PLBBESRx clears the bit.



| 31:29 | M4ET  | Master 4 Error Type<br>000 No Error<br>001 Parity Error<br>010 Reserved<br>011 Reserved<br>100 Reserved<br>101 Non-configured Bank Error<br>110 Reserved<br>111 Reserved |
|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | M4RWS | Master 4 Read/Write Status<br>0 Write error operation<br>1 Read error operation                                                                                          |
| 27    | M4FL  | Master 4 PCIC0_PLBBESR1 Field Lock<br>0 PCIC0_PLBBESR1 unlocked<br>1 PCIC0_PLBBESR1 locked                                                                               |

| 26    | M4AL  | Master 4 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 4<br>1 PCIC0_PLBBEAR locked by Master 4 |                          |
|-------|-------|-------------------------------------------------------------------------------------------------------------------|--------------------------|
| 25:23 | M5ET  | Master 5 Error Type                                                                                               | See PCIC0_PLBBESR1[M4ET] |
| 22    | M5RWS | Master 5 Read/Write Status<br>0 Write error operation<br>1 Read error operation                                   |                          |
| 21    | M5FL  | Master 5 PCIC0_PLBBESR1 Field Lock<br>0 PCIC0_PLBBESR1 Unlocked<br>1 PCIC0_PLBBESR1 Locked                        |                          |
| 20    | M5AL  | Master 5 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 5<br>1 PCIC0_PLBBEAR locked by Master 5 |                          |
| 19:17 | M6ET  | Master 6 Error Type                                                                                               | See PCIC0_PLBBESR1[M4ET] |
| 16    | M6RWS | Master 6 Read/Write Status<br>0 Write error operation<br>1 Read error operation                                   |                          |
| 15    | M6FL  | Master 6 PCIC0_PLBBESR1 Field Lock<br>0 PCIC0_PLBBESR1 unlocked<br>1 PCIC0_PLBBESR1 locked                        |                          |
| 14    | M6AL  | Master 6 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 6<br>1 PCIC0_PLBBEAR locked by Master 6 |                          |
| 13:11 | M7ET  | Master 7 Error Type                                                                                               | See PCIC0_PLBBESR1[M4ET] |
| 10    | M7RWS | Master 7 Read/Write Status<br>0 Write error operation<br>1 Read error operation                                   |                          |
| 9     | M7FL  | Master 7 PCIC0_PLBB ESR1 Field Lock<br>0 PCIC0_PLBBESR1 unlocked<br>1 PCIC0_PLBBESR1 locked                       |                          |
| 8     | M7AL  | Master 7 PCIC0_PLBBEAR Address Lock<br>0 PCIC0_PLBBEAR unlocked by Master 7<br>1 PCIC0_PLBBEAR locked by Master 7 |                          |
| 7:0   |       | Reserved                                                                                                          |                          |

# 17.5.3.29 PLB Slave Error Address Register (PCIC0\_PLBBEAR)

PCIC0\_PLBBEAR contains addresses associated with errors, as indicated by the PLB slave asserting SI\_MErr for transactions initiated by the PCI bridge on the PCI bus. PCIC0\_PLBBEAR is read-only.

31

#### Figure 17-50. PLB Slave Error Address Register (PCIC0\_PLBBEAR)

| 01.0 |                         |
|------|-------------------------|
| 31:0 | PLB Slave Error Address |
|      |                         |

### 17.5.3.30 Capability Identifier (PCIC0\_CAPID)

When PCIC0\_CAPID contains 0x01, the PCI bridge supports power management and the data structure currently being pointed to is the PCI power management capability structure.



Figure 17-51. Capability Identifier (PCIC0\_CAPID)

| 7:0 | PCI Capability Identifier |
|-----|---------------------------|
|     |                           |

## 17.5.3.31 Next Item Pointer (PCIC0\_NEXTIPTR)

PCIC0\_NEXTIPTR describes the location of the next item in the capability list of the function. PCIC0\_NEXTIPTR is set to 0x00 to indicate that this is the last item on the capability list.

#### Figure 17-52. Next Item Pointer (PCIC0\_NEXTIPTR)

7:0

PCI Next Item Pointer

0

## 17.5.3.32 Power Management Capabilities (PCIC0\_PMC)

PCIC0\_PMC provides information about the capabilities of the function related to power management. A value of 0x0202 indicates no specific capabilities.



| PMES   | PME Support                                                                | The PCI bridge does not support PME#; therefore, PMES is hardwired to 0b00000.                                                                                                                                                                                                                                                    |
|--------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D2S    | D2 Support<br>Determines if the D2 power management<br>state is supported. | The PCI bridge does not support the D2<br>power management state; therefore, D2S<br>is hardwired to 0.                                                                                                                                                                                                                            |
| D1S    | D1 Support<br>Determines if the D1 power management<br>state is supported. | The PCI bridge supports the D1 power management state; therefore, D1S is hardwired to 1.                                                                                                                                                                                                                                          |
| AUXCUR | Auxiliary Current Support                                                  | The PCI bridge does not support<br>Aux_Current; therefore, AUXCUR is<br>hardwired to 0b000.                                                                                                                                                                                                                                       |
| DSI    | Device Specific Initialization<br>0 after reset                            | This bit indicates whether special<br>initialization of this function is required<br>(beyond the standard PCI configuration<br>header) before the generic class device<br>driver is able to use it.                                                                                                                               |
|        | Reserved                                                                   | Always read as 0.                                                                                                                                                                                                                                                                                                                 |
| PMECLK |                                                                            | This bit is hardwired to 0 indicating that the function does not support PME# generation in any state.                                                                                                                                                                                                                            |
| VERS   |                                                                            | Returns 0b010 on reads, indicating that<br>PMC complies with Revision 1.1 of <i>PCI</i><br><i>Power Management Interface</i><br><i>Specification</i> .                                                                                                                                                                            |
|        | D2S<br>D1S<br>AUXCUR<br>DSI<br>PMECLK                                      | D2S       D2 Support         Determines if the D2 power management state is supported.         D1S       D1 Support         Determines if the D1 power management state is supported.         AUXCUR       Auxiliary Current Support         DSI       Device Specific Initialization 0 after reset         PMECLK       Reserved |

#### Figure 17-53. Power Management Capabilities Register (PCIC0\_PMC)

### 17.5.3.33 Power Management Control/Status Register (PCIC0\_PMCSR)

PCIC0\_PMCSR is used to manage the PCI power management state and to enable and monitor PMEs.



Figure 17-54. Power Management Control/Status Register (PCIC0\_PMCSR)

| 15    | PMEST |                                                                                                                                             | The PCI bridge does not support PME#;                                                                                                                          |
|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |                                                                                                                                             | therefore, PMEST is hardwired to 0.                                                                                                                            |
| 14:13 | DSCAL | The PCI bridge does not support data register; therefore, DSCAL is hardwired to 0b00.                                                       |                                                                                                                                                                |
| 12:9  | DSEL  |                                                                                                                                             | The PCI bridge does not support a data<br>register; therefore, DSEL is hardwired to<br>0b0000.                                                                 |
| 8     | PMEEN |                                                                                                                                             | The PCI bridge does not support PME generation; therefore, PMEEN is hardwired to 0.                                                                            |
| 7:2   |       | Reserved                                                                                                                                    | Returns 0 when read.                                                                                                                                           |
| 1:0   | PSTAT | Determine the current power state of a<br>function and sets the function into a new<br>power state.<br>00 D0<br>01 D1<br>10 D2<br>11 D3 Hot | If software attempts to write a value for an<br>unsupported power state to PSTAT, its value<br>does not change. Writing this fiield may<br>change PCI0_PMSCRR. |

## 17.5.3.34 PMCSR PCI-to-PCI Bridge Support Extensions (PCIC0\_PMCSRBSE)

PCIC0\_PMCSRBSE is required for all PCI-to-PCI bridges. The PCI bridge in not a PCI-to-PCI bridge; therefore, it returns 0 when this register is read.

| 7 | <br>0 |
|---|-------|
|   |       |

#### Figure 17-55. PMCSR PCI to PCI Bridge Support Extensions (PCIC0\_PMCSRBSE)

| ſ | 7:0 |   | PCI to PCI Bridge Support Extensions |
|---|-----|---|--------------------------------------|
|   |     | - |                                      |

## 17.5.3.35 PCI Data Register (PCIC0\_DATA)

PCIC0\_DATA is an optional register that provides a mechanism for the function to report state dependent operating data such as power consumed or heat dissipation. The PCI bridge does not implement this register; therefore, it returns 0 when this register is read.



## Figure 17-56. PCI Data (PCIC0\_DATA)

| 7:0 | PCI Data |
|-----|----------|
| L   |          |

## 17.5.3.36 Bridge Options 2 Register (PCIC0\_BRDGOPT2)

PCIC0\_BRDGOPT2 controls various operating parameters of the PCI bridge.



#### Figure 17-57. Bridge Options 2 Register (PCIC0\_BRDGOPT2)

| 15:14 |        | Reserved                                                                                                                                                                          |                                                                                                                                                                                                                                                                    |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13    | EWPCI  | External Write to PCI Command Interrupt<br>0 No write to PCIC0_CMD has occurred.<br>1 External PCI master has written to<br>PCIC0_CMD.                                            | Software can also set or clear this bit.                                                                                                                                                                                                                           |
| 12    | DPR    | Drive PCI Reset<br>0 Normal operation<br>1 Causes PCIReset pin to be asserted.                                                                                                    | Software that asserts this bit must leave is<br>asserted long enough to guarantee the<br>PCI pulse width requirements. DPR does<br>not reset PLB bus interface registers or<br>PCI bridge registers.<br>PCIReset is also asserted when the PCI<br>bridge is reset. |
| 11:8  | PSSTLD | Subsequent Target Latency Timer Duration<br>Specifies the number of PCI clocks that a<br>PCI master burst can be held in a wait<br>state before a target disconnect is initiated. | Only set on reads.<br>In synchronous mode, PSSLTD equals the<br>maximum number of PCI clocks to<br>disconnect. In asynchronous mode,<br>PSSLTD plus 3 equals the maximum<br>number of PCI clocks to disconnect. The<br>asynchronous value must be 2 or less.       |

| 7:3 |      | Reserved                                             |                                                                                                                                                                                                                                                                    |
|-----|------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | PTDT | PCI Discard Timer Disable<br>0 Disabled<br>1 Enabled | When enabled, the PCI bridge never discards delayed read data.                                                                                                                                                                                                     |
| 1   |      | Reserved                                             |                                                                                                                                                                                                                                                                    |
| 0   | HCE  | Host Configuration Enable<br>0 Disabled<br>1 Enabled | HCE controls host PCI access to the PCI<br>bridge configuration registers. All host<br>attempts to access the PCI bridge PCI<br>configuration registers are retried. This<br>give the local CPU (PLB master) time to<br>initialize them before the host sees them. |

In synchronous mode, the PCI subsequent target latency timer duration equals the maximum number of PCI clocks to disconnect. In asynchronous mode, PCI subsequent target latency timer duration plus 3 equals the maximum number of PCI clocks to disconnect. The asynchronous value must be 2 or less.

## 17.5.3.37 Power Management State Change Request Register (PCIC0\_PMSCRR)

PCIC0\_PMSCRR provides a method of informing the local processor of a power management state change request and prevents the completion of the write to PCIC0\_PMCSR until the local processor indicates it is ready for the state change. All writes to PCIC0\_PMCSR are retried until the local processor sets PCIC0\_PMSCRR[APW] = 1. PCIC0\_PMSCRR is used with the registers in the capability structure for power management. Descriptions of each bit are shown in Figure 17-58.



#### Figure 17-58. Power Management State Change Request Register (PCIC0\_PMSCRR)

| 7:5 |       | Reserved                                                     | Always read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|-------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | APW   | Accept PMCI0_PCMSR Writes<br>Always 1 if DWE is 0.           | The local processor sets APW when the local processor is ready to change the power management state. APW is cleared when the host configuration writes to the PCIC0_PMCSR register is accepted. The local processor can write 0 to APW.                                                                                                                                                                                                                                                                                                                                                                |
| 3   | SCR   | State Change Request                                         | The PCI bridge sets SCR when a host<br>writes PCICO_PMCSR to request a power<br>management state change. This drives an<br>interrupt to the local processor informing it<br>of a state change request. The local<br>processor must simultaneously clear SCR<br>and set APW = 1 when the local processor<br>is ready to change the state. After SCR is<br>cleared, new requests are not detected<br>until the outstanding delayed write is<br>accepted. The local processor can set<br>SCR = 1. Note that any host side write to<br>any byte (0x5C–0x5F) is considered a<br>power state change request. |
| 2:1 | REQST | Request State                                                | Indicates the new power management<br>state requested by a delayed host write to<br>PCIC0_PMCSR. This field is read-only<br>from the PLB side.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0   | DWE   | Delayed Write Enable<br>0 Immediate write<br>1 Delayed write | When DWE is set to 1, any configuration<br>write to the PCIC0_PMCSR is completed<br>as a delayed write. All writes to<br>PCIC0_PMCSR are retried until the local<br>processor sets the "Accept PCIC0_PMCSR<br>Write bit" (bit 4). When 0, any configuration<br>write to the PCIC0_PMCSR is completed<br>immediately. DWE is a don't care if a host<br>write to PCIC0_PMCSR requests a state<br>change from D3hot to D0.                                                                                                                                                                                |

# 17.6 Error Handling

The PCI bridge detects and reports several types of errors, which are reported to the PLB or the PCI. Status information is saved in the configuration registers to enable error type determination.

All errors are associated with either a cycle on the PLB or a cycle on the PCI bus.

Each error that can be detected is associated with a mask. If the mask is set, detection of that error condition is disabled. There are also masks for the PCISErr, PCIPErr, and PLB bus error signals that prevent reporting of any error by these signals. The masks do not prevent error detection.

The error types are as follows:

- PLB unsupported transfer type
- PCI master abort generated (while PCI master)
- PCI target abort received (while PCI master)
- PCI target data bus parity error detection
- PCI master data bus parity error detection
- PCI target address parity error detection
- PLB bus error detection

The following sections describe in detail how these errors are generated, what actions are taken for each, and how to reset a given error.

## 17.6.1 PLB Unsupported Transfer Type

This error occurs when the bridge PLB slave encounters an unsupported PLB transfer type. Table 17-11 outlines transfers not supported by the bridge PLB slave.

| PLB Transaction               | PCI Address Space Nonmemory |  |
|-------------------------------|-----------------------------|--|
| 4- and 8-word line read/write |                             |  |
| 16-word line read/write       | Any                         |  |
| Burst                         | Nonmemory                   |  |

Table 17-11. PLB Unsupported Transfer Types

Upon detection of this error, the bridge sets PCIC0\_ERRSTS[PUR] = 1.

### 17.6.2 PCI Master Abort

This error is generated by the bridge PCI master when no target responds with PCIDevSel within the required time-out window and error detection is enabled. The bridge PLB slave may assert a PLB bus error signal on the PLB in response to this error, as explained below.

Two masks are associated with a PCI master abort. PCIC0\_ERREN[MAEE] masks error reporting. If the error is detected, a PLB bus error signal is asserted if PCIC0\_ERREN[MAEE] = 1. For reads, the bridge PLB slave still completes the transfer on the PLB, but drives 1s on the read data bus and the appropriate PLB bus error signal for each data beat. For posted writes, a PLB bus error is asserted for

1 cycle, asynchronously to the corresponding write data beat on the PLB. For connected writes, a PLB bus error signal is asserted with the data transfer, and the data is discarded. If PCIC0\_ERREN[MAEE] = 0, error reporting is masked. No PLB bus error signal is asserted, regardless of the setting of PCIC0\_ERREN[MEAE].

The following status bits are set:

- 1. If a master abort is signalled, PCIC0\_STATUS[RMA] = 1. Setting of this field is non-maskable. Writing a 1 to PCIC0\_STATUS[RMA] resets the field.
- If master abort is detected as an error, PCIC0\_ERREN[MEAE] is set to 1 to indicate an event that would cause a PLB bus error to be asserted by the bridge PLB slave, regardless of the setting of PCIC0\_ERREN[MEAE]. This field can be reset by writing a 1 to PCIC0\_ERREN[MEAE].
- 3. PCIC0\_PLBBEAR and PCIC0\_PLBBESRx are updated as follows:

The address of the aborted request is saved in PCIC0\_PLBBEAR if all PCIC0\_PLBBESRx[MxAL] = 0 (PCIC0\_PLBBEAR is unlocked). If all PCIC0\_PLBBESRx[MxFL] = 0, PCIC0\_PLBBESRx[MxET] = 0b101 to indicate a non-configured bank error; and PCIC0\_PLBBESRx[MxRWS] is set to 0 on a write, 1 on a read. If PCIC0\_ERREN[MAEE] = 0 or PCIC0\_ERREN[MEAE] = 0, no PCIC0\_PLBBEAR or PCIC0\_PLBBESRx update is performed.

### 17.6.3 Bridge PCI Master Receives Target Abort While PCI Bus Master

This error is generated when the bridge PCI master receives a target abort while mastering a cycle on the PCI bus. Upon detection of this error, the bridge PLB slave may assert a PLB bus error signal on the PLB in response to this error, as explained below.

Two masks are associated with a target abort. PCIC0\_ERREN[TAEE] masks error reporting. If the error is detected, a PLB bus error signal is asserted if PCIC0\_ERREN[TAEE] = 1. For reads, the bridge PLB slave still completes the transfer on the PLB and drives the appropriate PLB bus error line for each data beat (note that for line reads, a PLB bus error signal is asserted for all data beats). For posted writes, if PCIC0\_ERREN[TAEE] = 1, the bridge PLB slave asserts a PLB bus error for 1 cycle, asynchronously to the corresponding write data beat on the PLB. For connected writes, a PLB bus error signal is asserted with the data transfer, and the data is discarded. If PCIC0\_ERREN[TAEE] = 0, error reporting is masked No PLB bus error signal is asserted, regardless of the setting of PCIC0\_ERREN[MEAE]. If prefetching is occurring when a target abort is received, data preceding the target abort is kept in a prefetch buffer.

The following status bits are set:

- 1. If a target abort is received, PCIC0\_STATUS[RTA] = 1. Setting this field is non-maskable. Writing a 1 to PCIC0\_STATUS[RTA] clears the field.
- If a target abort is detected as an error, PCIC0\_ERRSTS[MEAE] = 1 to indicate an event that would cause the bridge PLB slave to assert a PLB bus error signal, regardless of the setting of PCIC0\_ERREN[MEAE]. Writing a 1 to PCIC0\_ERRSTS[MEAE] resets the field.
- 3. PCIC0\_PLBBEAR and PCIC0\_PLBBESRx are updated as follows:

The address of the aborted request is saved in PCIC0\_PLBBEAR if all PCIC0\_PLBBESRx[MxAL] = 1 (PCIC0\_PLBBEAR is unlocked). If all PCIC0\_PLBBESRx[MxFL] = 1, PCIC0\_PLBBESRx[MxET] = 0b101 to indicate a nonconfigured bank error, and PCIC0\_PLBBESRx[MxRWS] is set to 0 on a write, or to 1 on a read. If PCIC0\_ERREN[MAEE] = 0 or PCIC0\_ERREN[MEAE] = 0, no PCIC0\_PLBBEAR or PCIC0\_PLBBESRx update is performed.

## 17.6.4 PCI Target Data Bus Parity Error Detection

This error is generated when the bridge PCI target detects a data bus parity error on write data from a PCI master doing a write cycle to PLB memory. PCI uses even parity.

Setting PCIC0\_CMD[PER] = 0 masks this error.

The following status bits are set:

- 1. PCIC0\_STATUS[DEPE] = 1 to indicate a PCI bus parity error. Setting this field is non-maskable. Writing a 1 to PCIC0\_STATUS[DEPE] clears the field.
- 2. PCIC0\_STATUS[SSE] = 1 if PCIC0\_ERREN[WDPE] = 1. Writing a 1 to PCIC0\_STATUS[SSE] clears the field.
- 3. PCIC0\_ERRSTS[WDPE] = 1 if PCIC0\_ERREN[WDPE] = 1. Writing a 1 to PCIC0\_STATUS[SSE] clears the field.

### 17.6.5 PCI Master Data Bus Parity Error Detection

This error is generated when a data bus parity error is detected on the PCI bus during a cycle mastered by the bridge PCI master. The bridge PCI master checks parity on read cycles and samples PCIPErr on write cycles. The bridge PCI master may assert PCIPErr if the master detects a parity error on a read. PCI uses even parity.

Setting PCIC0\_CMD[PER] = 0 masks this error. PCIC0\_STATUS[DEPE] = 1. If a parity error is detected, writing a 1 to PCIC0\_STATUS[DEPE] = 1 clears the field.

If PCIC0\_ERREN[MEAE] = 1 and the error is detected as described, the PLB slave asserts a PLB error signal on the PLB in response to the error. For reads, a PLB bus error is asserted for each data beat in which bad parity was detected. For writes, a PLB bus error is asserted for each data beat in which bad parity was detected, but asynchronously to the actual transfer of write data on the PLB.

The following status bits are set:

- 1. PCIC0\_STATUS[DEPE] = 1 if the bridge PCI master detects bad parity on read data, regardless of the state of PCI0\_CMD[PER]. Writing a 1 to PCIC0\_STATUS[DEPE] clears the field.
- 2. If a data bus parity error is detected as an error, PCIC0\_ERRSTS[MEAE] = 1 to indicate an event that would cause a PLB bus error signal to be asserted by the bridge PLB slave, regardless of the state of PCIC0\_ERREN[MEAE]. Writing a 1 to PCIC0\_ERRSTS[MEAE] = 1 clears the field.
- 3. PCIC0\_PLBBEAR and the PCIC0\_PLBBESRx are updated as follows:

The address of the PCI transaction where parity errors occurred is saved in the PCIC0\_PLBBEAR. PCIC0\_PLBBEAR is set if all PCIC0\_PLBBESRx[MxAL] = 1 (PCIC0\_PLBBEAR is unlocked). If PCIC0\_PLBBESRx[MxFL] = 1, PCIC0\_PLBBESRx[MxET] = 0b001 to indicate a parity error, and PCIC0\_PLBBESRx[MxRWS] is set to 0 on a write, 1 on a read. If PCI0\_CMD[PER] = 0 or PCIC0\_ERRSTS[MEAE] = 0, no PCIC0\_PLBBEAR or PCIC0\_PLBBESRx update is performed.

Note: For clock ratios greater than 2:1 (independent of asynchronous/synchronous mode), the PCI bridge detects errors but does not assert a PLB bus error signal or log the error in PCIC0\_PLBBEAR, PCIC0\_PLBBESRx, and PCIC0\_ERRSTS[MEAE].

## 17.6.6 PCI Address Bus Parity Error While PCI Target

This error occurs when a PCI address bus parity error is detected during the address phase of a cycle in which the bridge is the PCI target. PCI uses even parity.

Setting PCIC0\_CMD[PER] = 0 masks this error. This error does not have an explicit status bit, however the following actions are taken:

- 1. PCIC0\_STATUS[SSE] = 1 to indicate assertion of PCISErr, if the mask at PCIC0\_CMD[SE] = 1. Writing a 1 to PCIC0\_STATUS[SSE] clears the field.
- PCIC0\_STATUS[DEPE] = 1 to indicate a PCI bus parity error, regardless of the state of PCI0\_CMD[PER]. PCIC0\_STATUS[DEPE] = 1 when any type of PCI parity error is detected. Writing a 1 to PCIC0\_STATUS[DEPE] clears the field.

## 17.6.7 PLB Master Bus Error Detection

This error occurs when the bridge PLB master detects a PLB bus error. If the bridge PLB master receives a PLB bus error while mastering a read, the master associates the error with the currently executing read. If the master receives a PLB bus error while mastering a write or while idle, the master associates the error with a write.

PLB bus error detection is masked by PCIC0\_ERREN[MEDE] = 0. If PCIC0\_ERREN[MEDE] = 1, PLB bus error detection is enabled.

PCIC0\_ERREN[MERE] controls the response of the bridge PCI target to PLB bus error detection. If PCIC0\_ERREN[MERE] = 10 or 11, the bridge PCI target will execute a target abort. If PCIC0\_ERREN[MERE] = 01 or 11, the bridge PCI target asserts PCISErr and allows the transaction to continue. If PCIC0\_ERREN[MERE] = 11, the bridge PCI target both target aborts and asserts PCISErr. The following status bits are set:

- 1. If the bridge PCI target executes a target abort, PCIC0\_STATUS[STA] = 1. The setting of PCIC0\_STATUS[STA] in such an event is non-maskable. Writing a 1 to PCIC0\_STATUS[STA] clears the field.
- f the bridge PCI target asserts PCISErr, PCIC0\_STATUS[SSE] = 1. The setting of PCIC0\_STATUS[SSE] is non-maskable. Writing a 1 to PCIC0\_STATUS[SSE] clears the field.
- If the bridge PCI target asserts PCISErr, PCIC0\_ERRSTS[SARME] = 1 to indicate that the bridge PCI target asserted PCISErr in response to a received PLB bus error signal. The setting of PCIC0\_ERRSTS[SARME] is non-maskable. Writing a 1 to PCIC0\_ERRSTS[SARME] clears the field.
- PCIC0\_ERRSTS[MED] = 1 to indicate that the bridge PLB master received a PLB bus error signal. Setting of PCIC0\_ERRSTS[MED] is non-maskable. Writing a 1 to PCIC0\_ERRSTS[MED] clears the field.

# 17.7 PCI Bridge Clocking Configuration

See "PCI Clocking" on page 7-7 for detailed information regarding the choice and setup involved with both synchronous and asynchronous PCI clocking modes.

# 17.8 PCI Power Management Interface

The PCI bridge supports PCI Power Management Interface Specification Revision 1.1 (PCI-PM).

## 17.8.1 Capabilities and Power Management Status and Control Registers

The PCI bridge has a capabilities structure in the PCI configuration space that indicates that the PCI bridge core is PCI Power Management capable. The capabilities structure includes the following registers:

- PCIC0\_CAPID, value 0x01, indicates Power Management
- PCIC0\_NEXTIPTR, points to next capabilities structure
- PCIC0\_PMC, value 0x0202, indicates no specific capabilities
- PCIC0\_PMCSR, indicates hold the current PowerState
- PCIC0\_PMCSR\_BSE, value 0x00, unused in PCI-to-PCI bridge
- PCIC0\_Data, value 0x00, not used
- See "PCI Configuration Registers" on page 17-29 for details.

## 17.8.2 Power State Control

The current power management state is reported by reading PCIC0\_PMCSR. The PCI bridge supports states D0, D1, D3hot, and D3cold. State D2 is not supported. When the state is not D0, the PCI bridge is masked from being a master or a memory or I/O target on the PCI bus. The PCI bridge can still be a config target. Thus, accesses claimed by the PCI bridge when in state D0 are no longer claimed, resulting in master aborts on the PLB or PCI if such an access is attempted. Note that this mask is independent of the state of the PCI Command register.

## 17.8.3 Changing Power States

The PCI bridge has two registers that control changing the power state. The host requests a change in the power state by writing to the PCIC0\_PMCSR. The other register is PCIC0\_PMSCRR), which provides a method of informing the local processor of a state change request and of preventing completion of the write to the PCIC0\_PMCSR until the local processor indicates that it is ready for the state change.

Power state changes are handled as follows:

- If a host write to PCIC0\_PMCSR requests an unsupported state change (such as a change to D2), the write is accepted but is ignored (no state change occurs).
- If a host write to PCIC0\_PMCSR requests a change from D3hot to D0, the write is accepted. Then, the PCI bridge asserts the power management reset signal, which causes the entire SOC to be reset.

Note: The PCI bridge assumes that any requested state change from D3hot is always to D0.

• All other change requests are handled with the following sequence:

1. The host requests a new power state by a PCI write to the PCIC0\_PMCSR.

- 2.The host PCI write is retried (unless PCIC0\_PMSCRR[DWE] = 0).
- 3. The host PCI write (retried or not) sets PCIC0\_PMSCRR[SCR] = 1, which drives an interrupt to the local processor.
- 4.The local processor recognizes the interrupt. The local processor checks PCIC0\_PMSCRR[SCR, REQST] to determine the nature of the request.
- 5. The local processor proceeds to power down the subsystem if the requested state is valid.
- 6.When the subsystem has been powered down and is ready to change state, the local processor clears the PCIC0\_PMSCRR[SCR] and sets PCIC0\_PMSCRR[APW] = 1.

7.When the host PCI write reoccurs:

- It is accepted.
- PCIC0\_PMSCR is updated (only if the transition is valid).
- PCIC0\_PMSCRR[APW] = 0, unless PCIC0\_PMSCRR[DWE] = 0, in which case PCIC0\_PMSCRR[APW] = 1 always.
- The PCI bridge enters a new power state.

The PCI bridge operates with the clock power management (CPM) logic to enable the bridge to be put into sleep mode under control of software. See Chapter 13, "Clock and Power Management" for discussion of the CPM function.

# 17.9 PCI Bridge Reset and Initialization

The following sections discuss resetting and initializing the PCI bridge.

### 17.9.1 Address Map Initialization

When the PCI bridge is the PCI master, it can generate memory, I/O, configuration, interrupt acknowledge, and special cycles. The method of cycle generation, and the associated address ranges, are fixed, except for memory cycles. PCI memory cycles are generated when the PCI bridge detects a cycle in one of three specified PLB address ranges. The sizes and address spaces of these ranges are specified using the PMM registers. Also, the address of the resulting PCI memory cycle can be an offset from the PLB address (address translation occurs). This translation is also specified in the PMM registers. The PMM registers *do not* default to usable values following reset; they must be initialized before attempting to generate PCI memory cycles.

When the PCI bridge is a target on the PCI bus, the PCI bridge can respond to memory cycles. The memory cycle address ranges that the PCI bridge responds to are specified in PCIC0\_PTM1BAR and PCIC0\_PTM2BAR. These registers are typically initialized as part of the standard PCI initialization process.

Figure 17-59 shows the desired address map. System memory resides from 0x0000000– 0x0FFF FFFF in the CPU/PLB address space, which is accessible from the PCI in the same address space (PCI bridge as a memory target) as defined by PTM1/BAR1. PTM2/BAR2 is disabled in this example. The CPU/PLB master has two spaces in which to access PCI Memory space. Range 0 is 0x20000000 to 0x27FFFFFF and is mapped to the same address on the PCI bus, and is nonprefetchable. Range 1 is 0x28000000 to 0x2BFFFFFF, and is translated to address range 0x30000000 to 0x33FFFFFF of PCI memory space. Range 2 is disabled.



Figure 17-59. Example Address Map

The following register values provide the address map shown in Figure 17-59:

| Register Name   | Value      | Comments                                                            |  |  |  |  |  |  |  |  |
|-----------------|------------|---------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| PCIL0_PMM0LA    | 0x20000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM0MA    | 0xF8000001 | 128MB; enabled; read prefetching not allowed.                       |  |  |  |  |  |  |  |  |
| PCIL0_PMM0PCILA | 0x20000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM0PCIHA | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM1LA    | 0x28000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM1MA    | 0xFC000003 | 64MB; enabled; prefetching allowed.                                 |  |  |  |  |  |  |  |  |
| PCIL0_PMM1PCILA | 0x30000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM1PCIHA | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM2LA    | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM2MA    | 0x00000000 | Not enabled.                                                        |  |  |  |  |  |  |  |  |
| PCIL0_PMM2PCILA | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PMM2PCIHA | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PTM1MSr   | 0xF0000001 | 256MB; enabled.                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PTM1LA    | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIL0_PTM2MS    | 0x00000000 | Not enabled.                                                        |  |  |  |  |  |  |  |  |
| PCIL0_PTM2LA    | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |
| PCIC0_PTM1BAR   | 0x0000008  | PCI memory space; address decode starts at PCI address 0x0000 0000. |  |  |  |  |  |  |  |  |
| PCIC0_PTM2BAR   | 0x00000000 |                                                                     |  |  |  |  |  |  |  |  |

Table 17-12. Address Map Register Values

# 17.9.2 Other Configuration Register Initialization

Additional register initialization is required, as follows:

- Error handling is initially disabled (error detection is masked). If error handling is to be enabled, PCIC0\_ERREN must be initialized appropriately.
- PCIC0\_BRDGOPT1 contains options for controlling the PLB. Its default values can be used.
- PCIC0\_BRDGOPT2 contains options for controlling the PCI bus. Its default values assume that the
  PCI is run synchronously to the PLB, and that the PCI bridge is the primary host bridge. If the PCI
  bridge is used otherwise, the values must be changed accordingly.

# 17.9.3 Target Bridge Initialization

The PCI bridge can also respond as a configuration target; however, the PCI bridge only responds as a configuration target when the PCIIDSel pin is attached, rather than pulled inactive. Note that if the size and local address of these ranges are not strapped to desired values at reset, the local CPU must specify them by setting the PTM Memory Size and Local Address registers before initializing PCIC0\_PTM1BAR and PCIC0\_PTM2BAR.

The local CPU must update the following registers (if the default value is not suitable or they were not strapped to appropriate values at reset) before setting the Host Config Enable bit:

- The address map registers (see "Address Map Initialization" on page 17-61)
- PCIC0\_VENDID
- PCIC0\_DEVID
- PCIC0\_REVID
- PCIC0\_CLS
- PCIC0\_SBSYSID
- PCIC0\_SBSYSVID

#### 17.9.4 Local Processor Boot from PCI Memory

The PCI bridge has a mode that enables a PLB master to access a PCI memory range without initial configuration cycles. This mode is enabled when CPC0\_PSR[RL] = 1. System designers can use this mode to enablea processor to access a boot ROM in PCI memory space.

The PCI bridge comes out of reset with PMM0 enabled and programmed for the address range, 0xFFFE0000–0xFFFFFFF. Also, PCIC0\_CMD[ME] = 1 after reset. Note that enabling PCI boot mode does not prevent subsequent updates to the PMM0 registers.

Note: The PPC405GP allows booting from PCI memory. See Chapter 9, "Pin Strapping and Sharing" for more information.

#### 17.9.5 Type 0 Configuration Cycles for Other Devices

Twenty-one devices can be accessed using the PCIIDSel mechanism. The PCI master asserts 1 bit of AD(31:11) for type 0 configuration cycles based on the value in the Device Number field. The mapping is as follows:

- If device number is 1, AD(11) is asserted
- If device number is 2, AD(12) is asserted
  - •
  - •
- If device number is 21, AD(31) is asserted

If device number contains a value of 22–31, no bit of AD(31:11) is asserted.

# 17.10 Timing Diagrams

This section contains timing diagrams of several different PCI bridge operations. The following paragraphs describe each diagram in detail. Each description assumes basic knowledge of PCI and PLB protocols.

Each operation is shown in both synchronous and asynchronous modes. The PCI is clocked at 33 MHz in synchronous mode and 66 MHz in asynchronous mode. The PLB is clocked at 100 MHz in all cases.

The SDRAM uses a 32-bit, PC100 memory interface configured for  $\overline{CAS}$  latency of 2, command leadoff of 2, and RAS to CAS delay ( $T_{rcd}$ ) of 2. All memory accesses are page idle, unless indicated otherwise.

**Note:** The PLB signals shown in the following timing diagrams are not externally accessible. They are included for information purposes and as an aid to understanding the PCI operations. For more information on these signals, refer to *Processor Local Bus Architecture Specifications*.

## 17.10.1 PCI Timing Diagram Descriptions

The following sections briefly describe each of the timing diagrams that follow the descriptions. Each description covers both the asynchronous and synchronous clocking modes for that operation. The timing diagrams then follow with all of the asynchronous diagrams grouped together followed by all of the synchronous diagrams grouped together.

#### 17.10.1.1 PCI Master Burst Read From SDRAM

Figure 17-60 (asynchronous) and Figure 17-67 (synchronous) show a PCI Master executing a 128byte Read Multiple from SDRAM. PCI bridge retries the initial request and performs a delayed read. PCI bridge executes a variable-length, doubleword read burst on PLB to SDRAM, filling its 96-byte read buffer. The read is a page hit. When the PCI master re-requests its read, PCI bridge begins bursting out of its read buffer, while continuing to prefetch from SDRAM.

### 17.10.1.2 PCI Master Burst Write To SDRAM

Figure 17-61 and Figure 17-68 show a PCI Master executing a 128-byte Write to SDRAM. PCI bridge accepts several beats of data into its 64-byte write buffer before executing variable-length, doubleword write bursts on PLB to SDRAM. The final write burst is fixed-length, since the PCI write has completed, and PCI bridge knows the exact burst length.

### 17.10.1.3 CPU Read From PCI Memory Slave, Nonprefetching

In Figure 17-62 and Figure 17-69, a PLB Master (CPU) executes a single-beat 64-bit read from a region of PCI memory marked as nonprefetchable. PCI bridge responds as a 32-bit PLB slave, so the CPU executes conversion cycles for each read. PCI bridge executes a single-beat PCI read for both PLB read requests.

#### 17.10.1.4 CPU Read From PCI Memory Slave, Prefetching

In Figure 17-63 and Figure 17-70, a PLB Master (CPU) executes 8, 64-bit, single-beat reads from a region of PCI memory marked as prefetchable. The first PLB read causes PCI bridge to execute a 64-byte Read Multiple to fill its 64-byte read prefetch buffer. The data for subsequent PLB reads is provided from the read buffer and no PCI cycles are generated. PCI bridge responds as a 32-bit PLB slave, so the CPU executes conversion cycles for each read.

#### 17.10.1.5 CPU Write To PCI Memory Slave

Figure 17-64 and Figure 17-71 show a PLB Master (CPU) executing 4, 64-bit, single-beat writes to PCI memory. PCI bridge responds as a 32-bit slave, so the CPU executes conversion cycles for each write. PCI bridge posts the writes in its 4-entry write buffer, and executes a PCI single-beat Memory Write for each request.

## 17.10.1.6 PCI Memory To SDRAM DMA Transfer

Figure 17-65 and Figure 17-72 show a DMA transfer of data from PCI memory to SDRAM. The DMA PLB Master executes a 4-doubleword read burst to PCI bridge followed by a 4-doubleword write burst to SDRAM. For the read, PCI bridge executes a 32-byte PCI Read Line.

### 17.10.1.7 SDRAM To PCI Memory DMA Transfer

Figure 17-66 and Figure 17-73 show a DMA transfer of data from SDRAM to PCI memory. The DMA PLB Master executes a 4-doubleword read burst from SDRAM followed by a 4-doubleword write burst to PCI memory. PCI bridge then executes a 32-byte write on the PCI bus.

### 17.10.2 Asynchronous

The following diagrams are for asynchronous clocking mode. Note that all of the diagrams flow across multiple pages. Each diagram begins with cycle 1 on the left facing page.



Figure 17-60. PCI Master Burst Read From SDRAM



Figure 17-60. PCI Master Burst Read From SDRAM (Continued)



Figure 17-60. PCI Master Burst Read From SDRAM (Continued)



Figure 17-60. PCI Master Burst Read From SDRAM (Continued)



Figure 17-61. PCI Master Burst Write To SDRAM

| Cycles      | 21 22 23     | 24 25 26       | 27 28 2                  | 9 30 3     | 1 32 33     | 34 35      | 36 37           | 38 39       | 40       |
|-------------|--------------|----------------|--------------------------|------------|-------------|------------|-----------------|-------------|----------|
| PLBCIk      |              | עעע            |                          | цц         |             |            |                 |             |          |
| BE0:7       | X <u>h00</u> |                |                          |            |             |            | han <u>ta</u> k | h           | 00       |
| ABus0:31    | X A0         |                |                          | and the    | Charles and |            | NY THE REAL     |             | +48      |
| R/W         |              |                |                          |            |             |            |                 |             |          |
| AddrAck     |              |                | · · ·                    | · · · ·    |             | · · ·      |                 |             |          |
| WrDAck      |              |                |                          |            |             |            |                 |             |          |
| RdDBus0:31  |              |                | , <u>10</u><br>X D8X D10 |            |             |            |                 |             |          |
| RdDBus32:63 |              |                | X D9X D11                |            |             |            |                 | · · ·       | 219°     |
|             |              | PCICI          | k                        |            |             |            |                 |             |          |
| PCIC        | ҝ҇҅҇҅҇҅҇҅҅   | PCIAD31:0      |                          | -          |             | - <u>`</u> |                 |             |          |
| 5014504     | DIX DII X D  | 12 X D13 X D14 |                          | D16 X D1   | 7 X D18 X   | D19 X C    | 20 X D21        | X D22 X     | D23      |
| PCIAD31     |              | PCIC[BE]3:0    | )                        | <u> </u>   | 1           |            |                 |             |          |
| PCIC[BE]3   | h0           |                |                          |            | ·           |            |                 |             |          |
| 1 010[02]0  |              | PCIFrame       | Э ;                      |            |             |            |                 |             | i        |
| PCIFram     | ne           | PCIIRD         |                          |            |             |            |                 |             | <u> </u> |
|             | : :          |                | · .                      | · ·        | 1           | 1          |                 | 1           | 1        |
| PCIIRD      | Ŷ            | PCITRD         | 7                        | ; ;        |             |            | ······          |             | 1        |
|             |              |                |                          | 1 1<br>1 1 | 1           | :          |                 |             | :/       |
| PCITRD      | Y;           | PCISTOR        |                          | i i        | 1           |            |                 |             | -        |
| PCISto      | <del>p</del> | PCIDevSe       | ī                        |            |             |            |                 | 1<br>1<br>1 |          |
| PCIDevS     | <u></u>      | I              | <u> </u>                 | • •        |             | 1          | 1               | 1           | <u>.</u> |

Figure 17-61. PCI Master Burst Write To SDRAM (Continued)

| Cycles      | 41                 | 42          | 43               | 44          | 45       | 46               | 47       | 48 | 49               | 50               | _51         | 52               | 53               | 54               | 55          | 56  | 57                    | _58              | 59               | 60               |
|-------------|--------------------|-------------|------------------|-------------|----------|------------------|----------|----|------------------|------------------|-------------|------------------|------------------|------------------|-------------|-----|-----------------------|------------------|------------------|------------------|
| PLBClk      |                    | Ļ           | Ļ                | Ļ           | Γ_       |                  | ΓЦ       |    | $[] \square$     | Ļ                | ŗ.          | Ļ                | Ļ                | ŗĹ               | Ļ           | ŗ∟  | ŗ∟                    | $[ \square ]$    | ļ l              | ΓIJ              |
| BE0:7       | h00                | ۶X<br>۲     |                  |             |          |                  |          |    |                  |                  | 1           | 1                |                  | 1                | (           |     | -<br>                 | 1                |                  |                  |
| ABus0:31    | A0+4               | •<br>•<br>• |                  |             | 100101   |                  |          |    |                  |                  | 1           |                  | ,<br>,           | ,                |             |     | •                     |                  | Landara<br>L     |                  |
| R/W         |                    |             | <u>.</u>         | <u>.</u>    |          |                  | · ·      |    |                  | *                | <u> </u>    | ¦                | ۱<br>۱۰۰۰        |                  |             |     | 1<br>1<br>1           |                  |                  | <u>.</u>         |
| AddrAck     |                    |             |                  | ;           |          |                  | · · ·    |    |                  | ;<br>;           |             |                  |                  | ,<br>,<br>,      |             |     |                       |                  |                  |                  |
| WrDAck      |                    |             | -<br>-<br>-<br>- | 1<br>1<br>1 |          | ,<br>,<br>,<br>, |          |    | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 |             | 1<br>1<br>1<br>1 | ,<br>,<br>,<br>, | ,<br>,<br>,<br>, | 1<br>1<br>1 |     | 1<br>1<br>1<br>1<br>1 | ,<br>,<br>,<br>, | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 |
| RdDBus0:31  |                    |             | 14)(D1           | ¢ D         |          |                  |          |    |                  |                  |             | 1<br>            | 1<br>1           |                  |             | •   |                       | -<br>            |                  |                  |
| RdDBus32:63 | ,<br>K <u>D1</u> ; | <u>3 XD</u> | 1 <u>5</u> /D-   |             | 19(D2    |                  | 23       |    |                  |                  | •<br>•<br>• |                  |                  |                  |             | •   | 1<br>•                |                  |                  |                  |
| PCICik      | Ц                  |             |                  | L           |          |                  |          |    |                  | Ľ                |             |                  |                  |                  |             | Ц   |                       |                  |                  |                  |
| PCIAD31:0   | λ,                 |             |                  |             |          |                  |          |    |                  | i                |             | 40+9             | ×,               | D24              | Ļχ          | D25 | χD                    | <u>26 X</u>      | D2               |                  |
| PCIC[BE]3:0 |                    |             | 1                | 1           |          |                  | <u>ا</u> |    |                  | 1                |             | h7               | <u>x</u>         | _                | 1           |     | h0                    | 1                | 1                |                  |
| PCIFrame    | ,<br>,<br>,        |             |                  | <br>        | <u>.</u> |                  | i        |    | +<br>            |                  | ╲           |                  |                  |                  | 1<br>1<br>1 |     |                       | ,<br>,<br>,      |                  |                  |
| PCIIRDY     | ,                  |             | /                |             |          |                  |          |    |                  |                  |             | +                | ;                |                  | ,<br>,      |     |                       |                  | 1<br>1<br>1      |                  |
| PCITRDY     |                    |             |                  |             |          |                  |          |    |                  |                  |             |                  |                  | \                |             |     |                       |                  | 1                |                  |
| PCIStop     |                    |             | /                |             |          |                  |          |    | 1                |                  |             |                  |                  |                  |             |     |                       |                  | 1                |                  |
| PCIDevSel   |                    |             | /                |             |          | :                |          |    |                  |                  |             | ;                |                  | \                |             | 1   |                       |                  |                  |                  |

•

Figure 17-61. PCI Master Burst Write To SDRAM (Continued)



Figure 17-61. PCI Master Burst Write To SDRAM (Continued)



Figure 17-62. CPU Read From PCI Memory Slave, Nonprefetching



Figure 17-62. CPU Read From PCI Memory Slave, Nonprefetching (Continued)



Figure 17-63. CPU Read From PCI Memory Slave, Prefetching



Figure 17-63. CPU Read From PCI Memory Slave, Prefetching (Continued)



Figure 17-63. CPU Read From PCI Memory Slave, Prefetching (Continued)



Figure 17-63. CPU Read From PCI Memory Slave, Prefetching (Continued)



Figure 17-64. CPU Write To PCI Memory Slave



Figure 17-64. CPU Write To PCI Memory Slave (Continued)



Figure 17-64. CPU Write To PCI Memory Slave (Continued)

.



Figure 17-65. PCI Memory To SDRAM DMA Transfer



Figure 17-65. PCI Memory To SDRAM DMA Transfer (Continued)





Ω



Figure 17-66. SDRAM To PCI Memory DMA Transfer (Continued)



Figure 17-66. SDRAM To PCI Memory DMA Transfer (Continued)

## 17.10.3 Synchronous

The following diagrams are for synchronous clocking mode. Note that all of the diagrams flow across multiple pages. Each diagram begins with cycle 1 on the left facing page.







Figure 17-67. PCI Master Burst Read From SDRAM (Continued)



Figure 17-67. PCI Master Burst Read From SDRAM (Continued)



Figure 17-67. PCI Master Burst Read From SDRAM (Continued)



Figure 17-67. PCI Master Burst Read From SDRAM (Continued)



Figure 17-67. PCI Master Burst Read From SDRAM (Continued)

| Cycles      | 121         | 122       | 123       | 124      | 125 | 126          | 127         | 128             | 129         | 130 | 131         | 132    | 133              |
|-------------|-------------|-----------|-----------|----------|-----|--------------|-------------|-----------------|-------------|-----|-------------|--------|------------------|
| PLBClk      |             |           | $\square$ | <u> </u> |     |              |             |                 | <u> </u>    |     | [ ]         |        | $\square$        |
| BE0:7       | <u> </u>    |           | ·         |          | ·   | ·            | ·           |                 |             |     |             | ·      | ·                |
| ABus0:31    |             | •         |           |          |     | ·            | 1           |                 | 1           | 1   | (           |        |                  |
| R/Ŵ         | ь           | •         |           |          |     | ·<br>· · · · |             | ;               |             |     |             | ·      |                  |
| AddrAck     | ¦<br>!      | · · · · · |           |          |     | 1<br>1<br>1  | (<br>)      |                 | 1<br>1<br>1 |     | *<br>*<br>* | ·<br>· | 1<br>6<br>1      |
| RdDAck      |             | <u> </u>  |           | <b>`</b> |     |              |             |                 |             |     |             |        | 1<br>1<br>1<br>1 |
| RdDBus0:31  | İx          | D42       |           | D44      |     | <br>D46      |             | 048             |             |     | _           | D52    |                  |
| RdDBus32:63 |             | D43       | X         | D45      |     | D47          |             | 049             |             | 051 |             | D53    | X                |
| PCICik      |             |           |           |          |     |              | [           |                 |             | [   |             |        |                  |
| PCIAD31:0   |             | D29       | )         |          | D30 | 0            |             | D3 <sup>-</sup> | 1           |     |             |        |                  |
| PCIC[BE]3:0 |             |           |           |          |     |              | ·           |                 |             |     |             |        |                  |
| PCIFrame    | 1<br>1<br>1 |           |           |          |     |              |             |                 |             | 1   |             |        | L                |
| PCIIRDY     |             |           |           |          |     |              | 1<br>1<br>1 |                 |             |     |             |        | ,<br>,<br>,      |
| PCITRDY     | 1<br>1<br>1 |           |           |          |     |              | 1<br>1<br>1 |                 |             |     |             |        | ,<br>,           |
| PCIStop     |             |           |           |          |     |              |             | <u> </u>        |             |     |             |        |                  |
| PCIDevSel   | <br> <br>   |           |           | .'<br>   |     |              | 1<br>1<br>1 |                 |             |     | <u></u>     |        |                  |

Figure 17-67. PCI Master Burst Read From SDRAM (Continued)



Figure 17-68. PCI Master Burst Write To SDRAM

| Cycles      | 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
|-------------|-------------------------------------------------------------|
| PLBCIk      |                                                             |
| BE0:7       | X noo X                                                     |
| ABus0:31    |                                                             |
| R/W         |                                                             |
| AddrAck     |                                                             |
| WrDAck      |                                                             |
|             |                                                             |
| WrDBus0:31  |                                                             |
| WrDBus32:63 | <u>D1 X D3 X D5 X D7 X</u>                                  |
|             |                                                             |
| PCIClk      |                                                             |
| PCIAD31:0   | D4 X D5 X D6 X D7 X D8 X D9 X D10 X                         |
| PCIC[BE]3:0 |                                                             |
| PCIFrame    |                                                             |
| PCIIRDY     |                                                             |
| PCITRDY     |                                                             |
| PCIStop     |                                                             |
| PCIDevSel   |                                                             |

Figure 17-68. PCI Master Burst Write To SDRAM (Continued)

.



Figure 17-68. PCI Master Burst Write To SDRAM (Continued)



Figure 17-68. PCI Master Burst Write To SDRAM (Continued)



Figure 17-68. PCI Master Burst Write To SDRAM (Continued)



Figure 17-68. PCI Master Burst Write To SDRAM (Continued)



Figure 17-69. CPU Read From PCI Memory Slave, Nonprefetching



Figure 17-69. CPU Read From PCI Memory Slave, Nonprefetching (Continued)



Figure 17-70. CPU Read From PCI Memory Slave, Prefetching



Figure 17-70. CPU Read From PCI Memory Slave, Prefetching (Continued)



### Figure 17-70. CPU Read From PCI Memory Slave, Prefetching (Continued)



Figure 17-70. CPU Read From PCI Memory Slave, Prefetching (Continued)



Figure 17-71. CPU Write To PCI Memory Slave



Figure 17-71. CPU Write To PCI Memory Slave (Continued)



Figure 17-71. CPU Write To PCI Memory Slave (Continued)

| Cycles      | 61                | 62  | 63      | 64      | 65  | 66     | 67                 | 68          | 69          | 70                   | 71                                    | 72          | 73         |
|-------------|-------------------|-----|---------|---------|-----|--------|--------------------|-------------|-------------|----------------------|---------------------------------------|-------------|------------|
| PLBClk      |                   |     |         |         |     |        |                    |             |             |                      |                                       |             |            |
| BE0:7       | · · ·             | 1   |         |         |     |        | <u>.</u>           | •           | 1           |                      |                                       |             | ;<br>)     |
|             |                   | 1   | 1       | i       |     |        | 1                  | 1           | ;           | •                    |                                       | •           | :          |
| ABus0:31    |                   |     |         |         | h00 | 000000 | 000000             | 000         |             |                      |                                       |             |            |
| R/W         |                   |     |         |         |     |        | ,<br>,<br>,        |             | 1<br>1<br>1 | ·<br>· · · · · · · · | 1<br>1<br>1                           |             |            |
| AddrAck     |                   |     |         |         |     |        | 1<br>1<br>1        | ·<br>·      | •<br>•<br>• |                      |                                       | ,<br>,<br>, | :          |
| WrDAck      | 1 I<br>1 I<br>1 I |     |         |         |     |        | 1<br>1<br>1        | 1<br>1<br>1 | 1           | 1                    | 1                                     | 1           |            |
|             |                   | •   |         | 1       |     | 1      | •<br>•<br>•        |             | 1           | 1<br>1<br>1          | 1                                     | 1<br>1<br>1 |            |
| WrDBus0:63  | ·                 | •   | · · · · |         | h00 | 000000 | 000000             | 00          | •           | ·                    | · · · · · · · · · · · · · · · · · · · | ·           | ·>         |
|             |                   |     |         |         |     |        |                    |             |             |                      |                                       |             |            |
| · PCICIk    | [                 | _   | Г       |         |     |        |                    |             |             |                      |                                       |             |            |
| Gnt         | ,<br>,<br>,       | L   |         |         | L   |        | 4<br>1<br>1        |             |             | 4<br>•<br>•          | L                                     |             | -          |
| PCIAD31:0   |                   | D6  |         | X       |     |        | γ                  | A7          | ,           |                      | D7                                    | ,           |            |
| PCIC[BE]3:0 | рс<br>i-v         | h0  |         |         | a.  |        |                    | h7          |             |                      | h0                                    |             |            |
|             | L^                | 110 |         | <u></u> |     |        | <u></u>            |             |             |                      | 110                                   |             | _ <b>^</b> |
| PCIFrame    |                   |     | :       |         |     |        | <u> </u>           |             |             |                      |                                       |             |            |
| PCIIRDY     | <u> </u>          |     | :       | <i></i> |     |        | •                  |             |             | <u> </u>             |                                       |             | <u> </u>   |
| PCITRDY     |                   |     |         |         |     |        |                    |             |             | <u>;</u><br>;        |                                       |             |            |
| PCIStop     |                   |     |         |         |     |        | 1<br><u>}</u><br>1 |             |             | 1<br>1<br>1          |                                       |             | <u>;</u>   |
| PCIDevSel   |                   |     | :       | /       |     |        |                    | ··          |             | <u>:</u>             |                                       |             | <u>:</u>   |

Figure 17-71. CPU Write To PCI Memory Slave (Continued)

| Cycles      | 1       | 2  | 3                | 4                | 5           | 6     | 7           | 8         | 9                | 10          | 11          | 12               | 13               | 14               | 15          | 16          | 17           | 18       | 19       | 20             |
|-------------|---------|----|------------------|------------------|-------------|-------|-------------|-----------|------------------|-------------|-------------|------------------|------------------|------------------|-------------|-------------|--------------|----------|----------|----------------|
| PLBClk      |         | ٦_ |                  | ŗ_               |             |       |             |           |                  |             |             |                  |                  |                  |             |             |              |          |          |                |
| BE0:7       |         |    | ,<br>,           |                  | . –         | <br>  |             |           | ,                | h30         |             | ,                |                  | ,<br>,<br>,      | ,           | ,           | ,<br>,       | ,        | -        |                |
| ABus0:31    | [       |    | ·                |                  |             | ·     |             |           |                  | AO          |             | ·                |                  |                  | r           | ·           | ·            |          | ,        | <u></u>        |
| R/W         |         |    | ,<br>,<br>,      |                  | ,<br>,<br>, |       |             |           |                  | ,<br>,<br>, |             |                  | ,<br>,           | ,<br>,<br>,      | :           |             | <u>.</u><br> | ;        |          | <u>.</u>       |
| AddrAck     |         |    | 1<br>1<br>1      | <u>.</u>         | ,<br>,<br>, |       |             | <br> <br> |                  | ·<br>·      |             | 1<br>1<br>1      | 1<br>1<br>1<br>1 | ,<br>,<br>,      | 1<br>1<br>1 | 1<br>1<br>1 |              | <u>.</u> | <u> </u> | <u>.</u>       |
| RdDAck      |         |    | 1<br>1<br>1<br>1 | •<br>•<br>•      | ,<br>,      | ;<br> |             |           |                  |             |             |                  | •<br>•<br>•      |                  | •<br>•<br>• | 1<br>1      | '<br>'<br>'  | <u>.</u> | :        | 1<br>1<br>1    |
| RdDBus0:31  |         |    |                  |                  |             |       |             |           | ;<br>            | ;<br>       |             |                  | ;<br>            |                  |             |             |              |          | ;<br>;   |                |
| RdDBus32:63 |         |    |                  |                  |             |       |             |           | i (Norm          |             |             | fa Ver           | 1.0              |                  |             |             |              |          |          |                |
| WrDAck      |         |    | 1<br>1<br>1      | 1<br>1<br>1<br>1 | (           | ;<br> |             |           | 1<br>1<br>1<br>1 | 1<br>1<br>1 | ,<br>,<br>, | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 |             |             | 1<br>1<br>1  | :        | ;        | •<br>•<br>•    |
| WrDBus0:31  |         |    |                  |                  |             |       |             |           | 1<br>2 (         |             |             |                  |                  |                  | 1.45        | ۱<br>۲۰۰۰ ج |              |          |          | •<br>• • • • • |
| WrDBus32:63 |         |    |                  |                  |             |       |             | Sec. 10   |                  |             |             |                  |                  |                  |             |             |              |          | İ.       |                |
| PCIClk      | <b></b> |    |                  | <u> </u>         |             |       | <b></b>     |           | _                | [           |             |                  | [                |                  |             |             | -            |          |          |                |
| Gnt         | 1<br>1  |    |                  | ;                |             |       | ;           |           |                  | 1<br>1<br>1 |             |                  |                  |                  |             | ı           |              |          | :        |                |
| PCIAD31:0   |         |    |                  | ¢⊂               | A           | 0     | ;<br>;      |           |                  | ÷c          |             | 0                | Ċ                | 0                | 01          | Ċ           |              | 02       | έx       | D3             |
| PCIC[BE]3:0 |         |    |                  | ĎХ—              | hE          |       | <u>'</u> x_ |           |                  |             |             |                  |                  | h0               |             |             |              |          |          |                |
| PCIFrame    | ¦       |    |                  | ÷                |             |       |             |           |                  |             |             |                  |                  |                  |             |             |              |          | <u>.</u> |                |
| PCIIRDY     | <br>    |    |                  | <u>;</u>         |             |       |             |           |                  |             |             |                  | ,<br>,<br>,      |                  |             |             |              |          | ;        |                |
| PCITRDY     |         |    |                  |                  |             |       | 1<br>1<br>1 |           |                  | <u>¦</u> _  |             |                  |                  |                  |             | <u> </u>    |              |          |          |                |
| PCIStop     |         |    |                  | ;                |             |       |             |           |                  |             |             |                  |                  |                  |             |             |              |          |          |                |
| PCIDevSel   | <u></u> |    |                  | <u>;</u>         |             |       | :\          |           |                  | 1<br>1      |             |                  |                  |                  |             |             |              |          |          |                |

Figure 17-72. PCI Memory To SDRAM DMA Transfer

| Cycles      | 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | 9 40         |
|-------------|----------------------------------------------------------|--------------|
| PLBCIk      |                                                          |              |
| BE0:7       |                                                          | <u>teren</u> |
| ABus0:31    | X                                                        |              |
| R/W         |                                                          |              |
| AddrAck     |                                                          |              |
| RdDAck      |                                                          | <u> </u>     |
| RdDBus0:31  | X D0X D2X D4                                             | X De XI      |
| RdDBus32:63 | $\chi_{D1}\chi_{D3}\chi_{D5}$                            |              |
| WrDAck      |                                                          |              |
| WrDBus0:31  |                                                          |              |
| WrDBus32:63 |                                                          |              |
| PCICIk      |                                                          |              |
| Gnt         |                                                          |              |
| PCIAD31:0   | D3 X D4 X D5 X D6 X D7 X                                 |              |
| PCIC[BE]3:0 | h0 X                                                     |              |
| PCIFrame    |                                                          |              |
| PCIIRDY     |                                                          |              |
| PCITRDY     |                                                          |              |
| PCIStop     |                                                          |              |
| PCIDevSel   |                                                          | :            |

Figure 17-72. PCI Memory To SDRAM DMA Transfer (Continued)

| Cycles          | 41                    |   | 42                                                                                                               | 4     | 3 | 4                     | 14 | 45 | 5          | 46          | 6       | 47  | ,             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|-----------------------|---|------------------------------------------------------------------------------------------------------------------|-------|---|-----------------------|----|----|------------|-------------|---------|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLBClk          |                       |   |                                                                                                                  |       | L |                       | 1  |    |            |             | [       |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| BE0:7           |                       |   | X                                                                                                                | ,<br> |   |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ABus0:31<br>R/W |                       |   | X                                                                                                                | A1    |   |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AddrAck         | ,<br>,<br>,           |   |                                                                                                                  |       | / |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RdDAck          | 1<br>1<br>1<br>1<br>1 |   |                                                                                                                  |       |   | •<br>•<br>•<br>•<br>• |    |    |            |             |         |     |               | ,<br>,<br>,<br>,<br>,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RdDBus0:31      |                       |   |                                                                                                                  |       |   | 1                     |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RdDBus32:63     |                       |   | and the second second second second second second second second second second second second second second second | -     |   |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WrDAck          |                       |   |                                                                                                                  |       |   |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WrDBus0:31      |                       |   |                                                                                                                  |       |   |                       | D0 |    | D2         |             | :<br>D4 | _X_ | D6            | :<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| WrDBus32:63     |                       | 1 |                                                                                                                  | 1     |   | j                     | D1 |    | D3         | X_          | D5      | _X_ | D7            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCICIk          | L                     |   |                                                                                                                  | [     |   |                       | 1  |    |            |             |         | [   |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Gnt             |                       |   |                                                                                                                  |       | - |                       |    |    |            |             |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCIAD31:0       |                       |   | 0000000                                                                                                          |       |   |                       |    |    | 1 COLUMN   |             |         |     | Constant from |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCIC[BE]3:0     |                       |   | Statute of State                                                                                                 |       |   |                       |    |    | fre Careta |             |         |     |               | and the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second se |
| PCIFrame        |                       |   |                                                                                                                  |       |   |                       |    |    |            | 1<br>1<br>1 |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCIIRDY         |                       |   |                                                                                                                  |       |   |                       |    |    |            | 1<br>1<br>1 |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCITRDY         |                       |   |                                                                                                                  |       |   |                       |    |    |            | ,<br>,<br>, |         |     |               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PCIStop         |                       |   |                                                                                                                  |       |   |                       |    |    |            |             |         |     | -             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCIDevSel       | ·                     |   |                                                                                                                  |       |   |                       |    |    |            | ,<br>,      |         |     |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



Preliminary

•







#### Figure 17-73. SDRAM To PCI Memory DMA Transfer (Continued)

| Cycles      | 41          | 42         | 43_        | 44          | _45_           | 46                  | 47                                    | 48          | 49          | 50          | 51          | 52 | 53           | 54          | 55                                    | 56       |
|-------------|-------------|------------|------------|-------------|----------------|---------------------|---------------------------------------|-------------|-------------|-------------|-------------|----|--------------|-------------|---------------------------------------|----------|
| PLBClk      |             |            |            |             |                |                     |                                       |             |             |             |             |    |              |             |                                       |          |
| BE0:7       |             |            |            |             |                |                     |                                       |             |             |             |             |    | i<br>Vite sp |             |                                       |          |
| ABus0:31    |             |            |            |             |                |                     |                                       |             |             |             |             |    |              |             |                                       |          |
| R/W         | ,<br>,      | •          |            | •           |                |                     |                                       | •           | ,<br>,      |             |             |    | ,<br>1<br>1  | •           |                                       |          |
| AddrAck     | ¦           | •          | •<br>• •   | (<br>(<br>( |                |                     | •<br>•<br>•                           | 1<br>1<br>1 | (<br>(<br>( | •<br>•<br>• | 1<br>1<br>1 |    | )<br> <br>   | )<br>†<br>( | •<br>•<br>•                           | <u>.</u> |
| RdDAck      |             | 1<br>1     | (<br> <br> | <br>        | <br>           |                     | ,<br>,<br>,                           |             |             | <br>        |             |    |              |             |                                       |          |
|             |             | 1 1<br>1 1 | 1          |             | )  <br>   <br> | 1                   | •                                     | 1           | :<br>:<br>: | 1           | 1<br>1<br>1 |    | :<br>:<br>:  | i<br>i<br>i | 1                                     |          |
| RdDBus0:31  |             |            |            |             |                |                     |                                       |             |             |             |             |    |              |             |                                       |          |
| RdDBus32:63 |             |            |            |             |                |                     |                                       | .,          |             |             |             |    | a Santana (  |             |                                       |          |
| WrDAck      |             |            |            |             |                |                     |                                       |             |             |             |             |    |              | ,<br>,      |                                       | 1<br>1   |
| WrDBus0:31  |             |            | 195        |             |                |                     |                                       |             |             |             |             |    |              |             |                                       |          |
| WrDBus32:63 |             |            |            |             |                | 241 <sup>(</sup> ), |                                       | 10. T. W.   |             |             |             |    |              | ,           |                                       |          |
|             |             |            |            |             |                |                     |                                       |             |             |             |             |    |              |             |                                       |          |
| PCICIk      | ļ           |            |            |             | L              |                     | ]                                     |             |             |             | L           |    | ļ            |             |                                       | ļ        |
| Gnt         | <u>.</u>    |            |            | <br>        |                |                     | 1<br>1<br>1                           |             |             |             |             |    | ,<br>,,      |             |                                       | ·<br>·   |
| PCIAD31:0   | p_          | D3         |            | X           | D4             |                     |                                       | D5          |             | X           | D6          |    | X            | D7          | ,                                     |          |
| PCIC[BE]3:0 |             |            | _          |             |                |                     | ,<br>h(                               | 2           |             |             |             |    | ,<br>        |             |                                       |          |
| PCIFrame    |             |            |            |             |                |                     | ,<br>,                                |             |             |             |             |    |              |             |                                       |          |
| PCIIRDY     |             |            |            | ,<br>,      |                |                     | ,<br>,<br>,                           |             |             |             |             |    |              |             | · · · · · · · · · · · · · · · · · · · |          |
| PCITRDY     | I<br>I<br>I |            |            |             |                |                     | i<br>r                                |             |             |             |             |    | ı<br>ı       |             |                                       |          |
| PCIStop     |             |            |            |             |                |                     | · · · · · · · · · · · · · · · · · · · |             |             |             |             |    | ,<br>,<br>,  |             |                                       | •        |
| PCIDevSel   | 1<br>1      |            |            |             |                |                     |                                       |             |             |             |             |    | 1<br>1       |             |                                       |          |



•

# **Chapter 18. Direct Memory Access Controller**

The Direct Memory Access (DMA) controller is a Processor Local Bus (PLB) and On-chip Peripheral Bus (OPB) master which supports the autonomous transfer of data between memory and peripherals and from memory-to-memory. The controller provides four DMA channels, each of which has an independent set of configuration registers. Each channel has its own control, source address, destination address, count, and scatter/gather address registers. Once these registers are programmed by the PPC405 processor, the DMA controller performs the requested data transfer without the need for processor intervention.

The four DMA channels also support scatter/gather transfers. During a scatter/gather transfer the configuration registers for a particular DMA channel are automatically loaded from a data structure in memory instead of being individually programmed. Since the scatter/gather address register is updated in this process, the channel can optionally reconfigure itself for another transfer when the current one completes.

As master on both the PLB and OPB the DMA controller can read and write any address accessible by the PPC405 processor. This includes memory and memory-mapped peripherals on the EBC interface, SDRAM memory and PCI addresses that have been mapped into PLB address space. The DMA controller can also service DMA peripherals attached to the EBC via the DMAReqn, DMAAckn and EOTn[TCn] I/Os, along with the OPB-attached UART0.

# 18.1 External Interface Signals

Figure 18-1 illustrates the external I/Os associated with the DMA controller and the EBC I/Os used during external peripheral transfers. External peripheral and EBC device-paced memory transfers request service from the DMA controller by driving a DMA request line (DMAReq0-3) active. For peripheral mode transfers the DMA controller acknowledges the request and transfers data by asserting a DMA acknowledge signal (DMAAck0-3). In contrast, an EBC device-paced memory-to-memory transfer occurs when the chip select (PerCSn) associated with the memory location is driven active. The timing of PerCSn and the other EBC I/Os is determined by the Bank Access Parameter Register (EBC0\_BnAP) for the particular memory location. See Chapter 16, "External Bus Controller" for details on EBC configuration and timings.

| Signal    | Usage                                                                                                                                                                                    |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMAAckn   | DMA Request, used to request either a peripheral mode transfer or an EBC device-<br>paced memory-to-memory transfer.                                                                     |
| DMAAckn   | DMA Acknowledge, instructs an EBC-attached DMA peripheral to transfer data.                                                                                                              |
| EOTn[TCn] | End of Transfer or Terminal Count. Used to stop the channel when programmed as EOT. When configured as TC, goes active when the channel transfer count register (DMA0_CTn) reaches zero. |

| Table 18-1. | <b>DMA Controller</b> | External I/Os |
|-------------|-----------------------|---------------|
|             |                       |               |

**Note 1:** The active level (polarity) of DMAReqn, DMAAckn, and EOTn[TCn] are individually programmable. See "DMA Polarity Configuration Register (DMA0\_POL)" on page 18-5.



Figure 18-1. DMA Controller External Bus Control Signals

### **18.2 Functional Overview**

As a specialized controller, the DMA unit provides system designers and programmers with a highly efficient method of moving data. During any DMA transfer the controller always buffers data read from the source prior to writing the data to the destination. Since many buses, including the internal PLB and the SDRAM interface, provide substantially better performance when bursting data, the DMA controller includes a 32-byte (4 doubleword) buffer. This buffer is enabled on a per-channel basis by setting DMA0\_CRn[BEN] and serves to minimize the number of discrete memory transactions. Each of the four DMA channels is configurable for either peripheral or memory-to-memory transfers.

### 18.2.1 Peripheral Mode Transfers

Peripherals are either devices attached to the EBC interface via the DMAReqn and DMAAckn lines, or the internal serial port (UART0). Memory is any address accessible from the PLB, including PLB-

mapped PCI address space, SDRAM memory, and memory and memory-mapped devices on the peripheral bus. During a peripheral mode transfer the peripheral requests a DMA transfer by asserting a DMA request line. For UARTO, this signal is internal to the PPC405GP, while external peripherals use one of the DMAReqn lines. When the requesting channel has the highest priority of any active channel, the requesting device receives a DMA acknowledge. In the case of external peripherals, the appropriate DMAAckn line is driven to the active state, with the timing specified in the DMA Control Register for the channel (DMA0\_CRn).

There are two types of peripheral mode transfers: peripheral-to-memory and memory-to-peripheral. A peripheral-to-memory transfer reads data from a DMA device, while a memory-to-peripheral transfer writes data. In both cases, the peripheral interface never bursts and data is transferred at the width of the peripheral. If the DMA buffer is disabled for the active channel (DMA0\_CRn[BEN]=0), each peripheral transfer causes a corresponding memory operation.

When buffering is enabled during a peripheral-to-memory transfer, data is collected until the 32-byte buffer is full, the peripheral deasserts DMAReqn, a higher priority DMA request becomes pending, or the channel completes. The buffer contents are then written to the target memory as efficiently as possible. If the initial programming of the channel's destination address register (DMA0\_DAn) is 32-byte aligned, the buffer is emptied in one burst operation to the target memory.

Memory-to-peripheral transfers differ since the amount of data that will be requested by the peripheral is unknown. If the DMA buffer is disabled (DMA0\_CRn[BEN]=0) a discrete source memory read occurs for each element in the DMA transfer. Since this is inefficient, the buffer should only be disabled for low data rate transfers or when the source memory is FIFO-like, and reads are therefore destructive. When the 32-byte buffer is enabled the controller uses the setting in DMA0\_CRn[PF] to prefetch 1, 2, or 4 64-bit doublewords from the source memory. The DMA controller provides data from the buffer until the peripheral deasserts its request, the channel is interrupted by one of higher priority, or the transfer completes. Whenever any of these conditions occurs any unused data in the DMA buffer is discarded.

#### 18.2.2 Memory-to-Memory Transfers

The DMA controller can perform either device-paced (hardware-initiated) or software-initiated memory-to-memory transfers. Device-paced memory transfers function identically to peripheral mode transfers, except that a chip select (PerCSn) serves as the DMA acknowledge instead of a DMAReqn output. As with peripheral mode transfers, bursts never occur on the device-paced side of the transaction.

Software-initiated memory-to-memory transfers between memories with fixed timings provide the best overall performance. During a software-initiated transfer the DMA controller knows the exact amount of data to be transferred. As a result, when the 32-byte DMA buffer is enabled (DMA0\_CRn[BEN]=1) the controller uses bursts as much as possible. To ensure the highest bandwidth, source and destination addresses should be aligned on 32-byte boundaries.

There are three cases that limit the ability to burst during software-initiated memory-to-memory transfers. Bursting is not possible from the source memory when the source address increment is zero (DMA0\_CRn[SAI]=0). Similarly, the DMA controller does not burst to the destination when the destination address increment is zero (DMA0\_CRn[DAI]=0). Finally, the DMA controller cannot burst to or from any address that maps to a device-paced (EBC0\_BnAP[RE]=1) EBC chip select (PerCSn).

#### 18.2.3 Scatter/Gather Transfers

Each of the four DMA channels supports scatter/gather transfers. This scatter/gather capability allows the chaining of multiple DMA controller operations within a channel. During a normal DMA operation software must program the control, source address, destination address, and count registers for each transfer. Scatter/gather transfers differ in that these registers are automatically loaded from a linked list data structure in system memory. When a channel completes one transfer the DMA controller loads the next set of configuration values into the channel's registers and the channel continues with the new programmings.

# 18.3 Configuration and Status Registers

Table 18-2 on page 18-4 lists the DMA configuration and status registers, each of which is accessed using the PowerPC **mtdcr** and **mfdcr** instructions. As example, the following PowerPC assembly code writes the control register for DMA channel 0 and then reads the DMA status register:

| #define DMA0_0<br>#define DMA0_9 |             |                                            |  |
|----------------------------------|-------------|--------------------------------------------|--|
| mtdcr                            | DMA0_CR0,r3 | ! write r3 to channel 0 control register   |  |
| mfdcr                            | r4,DMA0_SR  | ! read contents of status register into r4 |  |

The DMA configuration and status registers are readable at any time. However, since each register read requires a separate operation, it is not possible to guarantee that the values read from multiple registers correspond to a state that ever existed in the DMA controller. To illustrate, consider software that reads the destination address for channel 0 (DMA0\_DA0) and then the count for channel 0 (DMA0\_CT0). If the DMA controller updates the count between these two operations, the values read differ from what is expected.

While reads can occur at any time, software must not write the configuration registers for any channel that is currently enabled (DMA0\_CRn[CE]=1). The only exception is that a channel may be disabled by reading the channel control register, clearing the channel enable bit, and then writing the new value to the control register. Once a channel is disabled, all of its configuration registers may be reprogrammed as desired.

| Mnemonic | DCR Address | Access | Description                                      | Page  |
|----------|-------------|--------|--------------------------------------------------|-------|
| DMA0_CR0 | 0x100       | R/W    | DMA Channel Control Register 0                   | 18-8  |
| DMA0_CT0 | 0x101       | R/W    | DMA Count Register 0                             | 18-11 |
| DMA0_DA0 | 0x102       | R/W    | DMA Destination Address Register 0               | 18-11 |
| DMA0_SA0 | 0x103       | R/W    | DMA Source Address Register 0                    | 18-10 |
| DMA0_SG0 | 0x104       | R/W    | DMA Scatter/Gather Descriptor Address Register 0 | 18-12 |
| DMA0_CR1 | 0x108       | R/W    | DMA Channel Control Register 1                   | 18-8  |
| DMA0_CT1 | 0x109       | R/W    | DMA Count Register 1                             | 18-8  |
| DMA0_DA1 | 0x10A       | R/W    | DMA Destination Address Register 1               | 18-11 |
| DMA0_SA1 | 0x10B       | R/W    | DMA Source Address Register 1                    | 18-10 |
| DMA0_SG1 | 0x10C       | R/W    | DMA Scatter/Gather Descriptor Address Register 1 | 18-12 |
| DMA0_CR2 | 0x110       | R/W    | DMA Channel Control Register 2                   | 18-8  |
| DMA0_CT2 | 0x111       | R/W    | DMA Count Register 2                             | 18-11 |

Table 18-2. DMA Controller Configuration and Status Registers

| Mnemonic | DCR Address | Access  | Description                                      | Page  |
|----------|-------------|---------|--------------------------------------------------|-------|
| DMA0_DA2 | 0x112       | R/W     | DMA Destination Address Register 2               | 18-11 |
| DMA0_SA2 | 0x113       | R/W     | DMA Source Address Register 2                    | 18-10 |
| DMA0_SG2 | 0x114       | R/W     | DMA Scatter/Gather Descriptor Address Register 2 | 18-12 |
| DMA0_CR3 | 0x118       | R/W     | DMA Channel Control Register 3                   | 18-8  |
| DMA0_CT3 | 0x119       | R/W     | DMA Count Register 3                             | 18-11 |
| DMA0_DA3 | 0x11A       | R/W     | DMA Destination Address Register 3               | 18-11 |
| DMA0_SA3 | 0x11B       | R/W     | DMA Source Address Register 3                    | 18-10 |
| DMA0_SG3 | 0x11C       | R/W     | DMA Scatter/Gather Descriptor Address Register 3 | 18-12 |
| DMA0_SR  | 0x120       | R/Clear | DMA Status Register                              | 18-7  |
| DMA0_SGC | 0x123       | R/W     | DMA Scatter/Gather Command Register              | 18-13 |
| DMA0_SLP | 0x125       | R/W     | DMA Sleep Mode Register                          | 18-6  |
| DMA0_POL | 0x126       | R/W     | DMA Polarity Configuration Register              | 18-5  |

 Table 18-2. DMA Controller Configuration and Status Registers (continued)

### 18.3.1 DMA Polarity Configuration Register (DMA0\_POL)

The Polarity Configuration Register (DMA0\_POL) is used to set the polarity (active state) of the external DMA I/O signals: DMAReqn, DMAAckn, and EOTn[TCn]. As shown in Figure 18-2, if a bit in DMA0\_POL is zero, the corresponding signal is active high, otherwise the signal is active low.

Whenever any of the EOT polarities are changed (DMA0\_POL[EnP), software must subsequently clear the corresponding EOT status bits in the DMA Status Register (DMA0\_SR[TS0:3]) prior to enabling the associated DMA channel. This is necessary to prevent a channel from being disabled because of an incorrect EOT status stored in the status bits.



| Figure 18-2  | DMA Polarity  | y Configuration | Register |  |
|--------------|---------------|-----------------|----------|--|
| rigule 10-2. | DIVIA FUIAITI | y configuration | negister |  |

| 0 | R0P | DMAReq0 Polarity<br>0 DMAReq0 is active high<br>1 DMAReq0 is active low       |
|---|-----|-------------------------------------------------------------------------------|
| 1 | AOP | DMAAck0 Polarity<br>0 DMAAck0 is active high<br>1 DMAAck0 is active low       |
| 2 | E0P | EOT0[TC0] Polarity<br>0 EOT0[TC0] is active high<br>1 EOT0[TC0] is active low |
| 3 | R1P | DMAReq1 Polarity<br>0 DMAReq1 is active high<br>1 DMAReq1 is active low       |

| 4     | A1P | DMAAck1 Polarity<br>0 DMAAck1 is active high<br>1 DMAAck1 is active low       |
|-------|-----|-------------------------------------------------------------------------------|
| 5     | E1P | EOT1[TC1] Polarity<br>0 EOT1[TC1] is active high<br>1 EOT1[TC1] is active low |
| 6     | R2P | DMAReq2 Polarity<br>0 DMAReq2 is active high<br>1 DMAReq2 is active low       |
| 7     | A2P | DMAAck2 Polarity<br>0 DMAAck2 is active high<br>1 DMAAck2 is active low       |
| 8     | E2P | EOT2[TC2] Polarity<br>0 EOT2[TC2] is active high<br>1 EOT2[TC2] is active low |
| 9     | R3P | DMAReq3 Polarity<br>0 DMAReq3 is active high<br>1 DMAReq3 is active low       |
| 10    | АЗР | DMAAck3 Polarity<br>0 DMAAck3 is active high<br>1 DMAAck3 is active low       |
| 11    | E3P | EOT3[TC3] Polarity<br>0 EOT3[TC3] is active high<br>1 EOT3[TC3] is active low |
| 12:31 |     | Reserved                                                                      |

### 18.3.2 DMA Sleep Mode Register (DMA0\_SLP)

The Sleep Mode Register (DMA0\_SLP) enables the DMA controller to enter sleep (low-power) mode and programs the number of PLB clock cycles to wait when the controller is idle before going to sleep. The DMA controller only goes to sleep when no DMA channels are enabled and no configuration or status (DCR) register operations are in progress. Reading or writing any of the DMA control or status register awakens the DMA controller.

To enable sleep mode set DMA0\_SLP[SME] and CPM0\_ER[DMA]. When sleep mode is enabled and the DMA controller becomes idle the 10-bit idle timer begins counting down from the programmed value. Only the upper 5 bits of the idle counter are programmable; the lower 5 bits are hardcoded to 0b11111. Therefore, the minimum granularity of the idle timer is 32 PLB clock cycles. When the counter reaches zero, the controller is placed in sleep mode.



Figure 18-3. DMA Sleep Mode Register (DMA0\_SLP)

| 0:4   | IDU | Idle Timer Upper<br>0-31                                 | Upper 5-bits of the idle timer.                                                                                             |
|-------|-----|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 5:9   | IDL | Idle Timer Lower<br>Hardcoded to 0b11111                 | Lower 5-bit portion of the idle timer.<br>Writing this field has no effect.                                                 |
| 10    | SME | Sleep Mode Enable<br>0 Sleep disabled<br>1 Sleep enabled | If SME=1, also set CPM0_ER[DMA] to<br>enable the Clock and Power<br>Management macro to put the DMA<br>controller to sleep. |
| 11:31 |     | Reserved                                                 | · · · · · · · · · · · · · · · · · · ·                                                                                       |

### 18.3.3 DMA Status Register (DMA0\_SR)

As shown in Figure 18-4, the DMA Status Register (DMA0\_SR) provides status information for each of the DMA channels. Bits in DMA0\_SR are set in hardware, and can be either read or cleared by software. Clearing is performed by writing a word to DMA0\_SR containing a 1 in any bit position to be cleared and 0 in all other bit positions.

The terminal count status (DMA0\_SR[CSn]), end of transfer status (DMA0\_SR[TSn]) and error status (DMA0\_SR[RIn]) must be cleared for a DMA channel to operate. If a scatter/gather operation generates an interrupt for any of the above conditions, the channel pauses until software clears the associated status field(s) in DMA0\_SR.



| 0:3 | CS[0:3] | Channel 0-3 Terminal Count Status<br>0 Terminal count has not occurred<br>1 Terminal count has been reached            | Set when the transfer count reaches 0.        |  |
|-----|---------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|
| 4:7 | TS[0:3] | Channel 0-3 End of Transfer Status<br>0 End of transfer has not been requested<br>1 End of transfer has been requested | Only valid for channels with DMA0_CRn[ETD]=0. |  |

Figure 18-4. DMA Status Register (DMA0\_SR)

| 8:11  | RI[0:3] | Channel 0-3 Error Status<br>0 No error<br>1 Error occurred                                                   | See "Errors" on page 18-14 for more information. |
|-------|---------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| 12:15 | IR[0:3] | Internal DMA Request<br>0 No internal DMA request pending<br>1 Internal DMA request is pending               |                                                  |
| 16:19 | ER[0:3] | External DMA Request<br>0 No external DMA request pending<br>1 External DMA request is pending               |                                                  |
| 20:23 | CB[0:3] | Channel Busy<br>0 Channel is idle<br>1 Channel currently active                                              |                                                  |
| 24:27 | SG[0:3] | Scatter/Gather Status<br>0 No scatter/gather operation in progress<br>1 Scatter/gather operation in progress |                                                  |
| 28:31 |         | Reserved                                                                                                     |                                                  |

# 18.3.4 DMA Channel Control Registers (DMA0\_CR0-DMA0\_CR3)

The DMA Channel Control Registers (DMA0\_CR0-DMA0\_CR3) are used to configure and enable their respective DMA channels. Before a DMA channel can transfer data, the channel control, source address, destination address, and transfer count registers must be programmed. If a DMA channel is setup for scatter/gather transfers (DMA\_SGC[SSGn]=1) the DMA channel control register is automatically loaded from memory. For additional details see "Scatter/Gather Transfers" on page 18-16.



| 0 | CE  | Channel Enable<br>0 Channel is disabled<br>1 Channel is enabled                                             | This field is automatically cleared when<br>the transfer completes or an error occurs.                                                          |
|---|-----|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | CIE | Channel Interrupt Enable<br>0 Disable interrupts from this channel<br>1 Enable interrupts from this channel | When enabled, interrupts are generated<br>for terminal count, end of transfer, and<br>errors conditions. See "DMA Interrupts"<br>on page 18-15. |

| 2     | TD  | In peripheral mode:<br>0 Transfers are from memory-to-peripheral<br>1 Transfers are from peripheral-to-memory<br>In device-paced memory-to-memory mode:<br>0 Peripheral is at the destination address<br>1 Peripheral is at the source address                                                                                                                                             | TD is not used (don't care) for software-<br>initiated memory-to-memory transfers.                                                                                                                              |
|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | PL  | Peripheral Location<br>0 External peripheral (EBC) bus<br>1 OPB (UART0)                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                 |
| 4:5   | PW  | Peripheral Width/Memory alignment<br>00 Byte (8 bits)<br>01 Halfword (16 bits)<br>10 Word (32 bits)<br>11 Doubleword (64 bits) memory-to-memory<br>transfers only                                                                                                                                                                                                                          | Transfer width equals peripheral width for peripherals.                                                                                                                                                         |
| 6     | DAI | Destination Address Increment<br>0 Do not increment destination address<br>1 After each data transfer increment the<br>destination address by:<br>1, if the transfer width is a byte (8 bits)<br>2, if the transfer width is a halfword (16 bits)<br>4, if the transfer width is a word (32 bits)<br>8, if the transfer width is a doubleword (64 bit)                                     |                                                                                                                                                                                                                 |
| 7     | SAI | <ul> <li>Source Address Increment</li> <li>Do not increment source address</li> <li>1 After each data transfer increment the source address by:</li> <li>1, if the transfer width is a byte (8 bits)</li> <li>2, if the transfer width is a halfword (16 bits)</li> <li>4, if the transfer width is a word (32 bits)</li> <li>8, if the transfer width is a doubleword (64 bit)</li> </ul> |                                                                                                                                                                                                                 |
| 8     | BEN | Buffer Enable<br>0 Disable DMA 32-byte buffer<br>1 Enable DMA 32-byte buffer                                                                                                                                                                                                                                                                                                               | If BEN=0 discrete read and write operations occur for each data transfer.                                                                                                                                       |
| 9:10  | ТМ  | Transfer mode<br>00 Peripheral<br>01 Reserved<br>10 Software-initiated memory-to-memory<br>11 Device-paced memory-to-memory                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                 |
| 11:12 | PSC | Peripheral Setup Cycles<br>0-3                                                                                                                                                                                                                                                                                                                                                             | Number of PerClk cycles that the EBC<br>peripheral bus is idle from the last<br>peripheral bus transaction to DMAAckn<br>becoming active. Used only for the<br>peripheral side of peripheral mode<br>transfers. |
| 13:18 | PWC | Peripheral Wait Cycles<br>0-63                                                                                                                                                                                                                                                                                                                                                             | DMAAckn remains active for PWC+1<br>PerClk cycles. Used only for the<br>peripheral side of peripheral mode<br>transfers.                                                                                        |

| 19:21 | PHC | Peripheral Hold Cycles<br>0-7                                                                                                                                                                         | The number of PerClk cycles between<br>the time that DMAAckn becomes inactive<br>until the peripheral bus is available for the<br>next bus access. Used only during the<br>peripheral side of peripheral mode<br>transfers. |
|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22    | ETD | End-of-Transfer/Terminal Count (EOTn[TCn])<br>Pin Direction<br>0 EOTn[TCn] is an EOT input<br>1 EOTn[TCn] is a TC output                                                                              | ETD must be set to 1 if the channel is configured for software-initiated memory-to-memory transfers.                                                                                                                        |
| 23    | TCE | Terminal Count (TC) Enable<br>0 Channel does not stop when TC is reached<br>1 Channel stops when TC is reached                                                                                        | If TCE=1, it is required that ETD=1.                                                                                                                                                                                        |
| 24:25 | СР  | Channel Priority<br>00 Low priority<br>01 Medium low priority<br>10 Medium high priority<br>11 High priority                                                                                          | Actively requesting channels of the same<br>priority are ranked in order by channel<br>number, channel 0 having the highest<br>priority. See "Channel Priorities" on<br>page 18-13 for more information.                    |
| 26:27 | PF  | Memory Read Prefetch Transfer<br>00 Prefetch 1 doubleword<br>01 Prefetch 2 doublewords<br>10 Prefetch 4 doublewords<br>11 Reserved                                                                    | Used only during memory-to-peripheral<br>and deviced-paced memory-to-memory<br>transfers. To enable prefetching it is<br>required that BEN=1.                                                                               |
| 28    | PCE | Parity Check Enable<br>0 Disable parity checking<br>1 Enable parity checking                                                                                                                          | Enables parity checking for peripheral<br>mode transfers. See "Data Parity During<br>DMA Peripheral Transfers" on<br>page 18-14.                                                                                            |
| 29    | DEC | <ul> <li>Address Decrement</li> <li>O SAI and DAI fields control memory address incrementing.</li> <li>1 After each data transfer the memory address is decremented by the transfer width.</li> </ul> | If DEC=1, it is required that BEN=0. This field is valid only for peripheral mode transfers (TM=00).                                                                                                                        |
| 30:31 |     | Reserved                                                                                                                                                                                              |                                                                                                                                                                                                                             |

### 18.3.5 DMA Source Address Registers (DMA0\_SA0–DMA0\_SA3)

The DMA Source Address Registers (DMA0\_SA0–DMA0\_SA3) contain the source address for memory-to-memory and memory-to-peripheral transfers. If a DMA channel is setup for scatter/gather transfers (DMA\_SGC[SSGn]=1) the source address register is automatically loaded from memory. For additional details see "Scatter/Gather Transfers" on page 18-16.

The source address must be aligned at the transfer width programmed in DMA0\_CRn[TW], otherwise the error bit (DMA0\_SR[RIn]) is set for the channel and no transfer occurs. If the source address increment bit in the channel's control register is set (DMA0\_CRn[SAI]) the address is incremented by the transfer width after each data transfer. In contrast, if the channel is performing a memory-to-peripheral transfer and the address decrement bit is set (DMA0\_CRn[DEC]=1), the address is decremented by the transfer width after each transfer.

0

Figure 18-6. DMA Source Address Registers (DMA0\_SA0–DMA0\_SA3)

| 0:31 | Source address for memory-to-memory |
|------|-------------------------------------|
|      | and memory-to-peripheral transfers. |

#### 18.3.6 DMA Destination Address Registers (DMA0\_DA0–DMA0\_DA3)

The DMA Destination Address Registers (DMA0\_DA0-DMA0\_DA3) contain the destination address for memory-to-memory and peripheral-to-memory transfers. When a DMA channel is configured for scatter/gather transfers (DMA\_SGC[SSGn]=1) the destination address register is automatically loaded from memory. For additional details see "Scatter/Gather Transfers" on page 18-16.

The destination address must be aligned at the transfer width programmed in DMA0\_CRn[TW], otherwise the error bit (DMA0\_SR[RIn]) is set for the channel and no transfer occurs. If the destination address increment bit in the channel's control register is set (DMA0\_CRn[DAI]) the address is incremented by the transfer width after each data transfer. However, if the channel is performing a peripheral-to-memory transfer and the address decrement bit is set (DMA0\_CRn[DEC]=1), the destination address is decremented by the transfer.

|   |  | <br> |
|---|--|------|
| 0 |  | 31   |

Figure 18-7. DMA Destination Address Registers (DMA0\_DA0-DMA0\_DA3)

| 0:31 | Destination address for memory-to- |
|------|------------------------------------|
|      | memory and peripheral-to-memory    |
|      | transfers.                         |

#### 18.3.7 DMA Count Registers (DMA0\_CT0-DMA0\_CT3)

The DMA Count Registers (DMA0\_CT0-DMA0\_CT3) contain the number of transfers left in the DMA transaction for their respective channels when EOTn[TCn] is programmed as a terminal count output. When EOTn[TCn] is programmed as an end-of-transfer input (DMA0\_CRn[ETD]=1), DMA0\_CTn continues to count down past zero until EOTn is asserted.

31

If a DMA channel is setup for scatter/gather transfers (DMA\_SGC[SSGn]=1) the count register is automatically loaded from memory. For additional details see "Scatter/Gather Transfers" on page 18-16.

The value in the DMA count register is interpreted as the number of **transfers** of the width specified in DMA0\_CRn[PW], **not** the total number of bytes. The maximum number of transfers is 64K, and each transfer can be either 1, 2, 4, or 8 bytes as programmed in DMA0\_CR[PW]. The maximum count of 64K transfers is programmed by writing zero to DMA0\_CTn.



#### Figure 18-8. DMA Count Registers (DMA0\_CT0-DMA0\_CT3)

| 0:15  |     | Reserved                      |
|-------|-----|-------------------------------|
| 16:31 | NTR | Number of transfers remaining |

# 18.3.8 DMA Scatter/Gather Descriptor Address Registers (DMA0\_SG0-DMA0\_SG3)

When a DMA channel is setup for scatter/gather transfers (DMA\_SGC[SSGn]=1), the Scatter/Gather Descriptor Address Register (DMA0\_SGn) contains the memory address of the next scatter/gather descriptor table. Prior to starting a scatter/gather transfer, software must write the address of the channel's descriptor table to DMA0\_SGn. Once the scatter/gather transfer starts, DMA0\_SGn is automatically updated from the descriptor table. For additional details see "Scatter/Gather Transfers" on page 18-16.

| 0 | 21 |  |
|---|----|--|
| 0 | 31 |  |

#### Figure 18-9. DMA Scatter/Gather Descriptor Address Registers (DMA0\_SG0-DMA0\_SG3)

| 0:31 | Address of next scatter/gather descriptor |
|------|-------------------------------------------|
|      | table.                                    |

# 18.3.9 DMA Scatter/Gather Command Register (DMA0\_SGC)

The DMA Scatter/Gather Command Register (DMA0\_SGC) is a 32-bit register, of which 8-bits are implemented. Bits 0:3 are the Start Scatter/Gather Enable bits for channels 0 to 3, and bits 16:19 are the corresponding Enable Mask bits for the Start Scatter/Gather Enable bits. Setting a Start Scatter/Gather Enable bit causes the selected channel to begin a scatter/gather operation, while writing a 0 stops the Scatter/Gather operation. To start or stop a specific Scatter/Gather channel, the corresponding Enable Mask bit must be set to 1; otherwise, the register holds the previous value. Note that halting a scatter/gather transfer does not stop the transfer currently in progress.

Upon completion of a scatter/gather sequence of transfers the DMA controller clears DMA0\_SGC[SSGn].

If an error occurs when the DMA controller is reading the Scatter/Gather descriptor table, DMA0\_SGC[SSGn] is cleared for the affected channel, and the channel's error status bit (DMA0\_SR[RIn]) is set.



For additional details see "Scatter/Gather Transfers" on page 18-16.

| Figure 18-10 | <b>DMA Scatter/Gather</b> | Command Register   | (DMA0 SGC) |
|--------------|---------------------------|--------------------|------------|
|              |                           | oominiana negister |            |

|       | 0        |                                                                                                                       | <b>o</b> ( <u> </u>                                                             |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 0:3   | SSG[0:3] | Start Scatter/Gather for channels 0-3.<br>0 Scatter/gather support is disabled<br>1 Scatter/gather support is enabled | To start a scatter/gather operation for<br>channel n, EM[n] must also be set.   |
| 4:15  |          | Reserved                                                                                                              |                                                                                 |
| 16:19 | EM[0:3]  | Enable Mask for channels 0-3.<br>0 Writes to SSG[n] are ignored<br>1 Allow writing to SSG[n]                          | To write SSG[n], EM[n] must be set.<br>Otherwise, writing SSG[n] has no effect. |
| 20:31 |          | Reserved                                                                                                              |                                                                                 |

# **18.4 Channel Priorities**

The priority of DMA transfers is controlled on a per-channel basis by the channel priority field in the channel control register. Table 18-3 shows the different priority settings for DMA0\_CRn[PW].

| DMA0_CRn[CP] | Priority Level |
|--------------|----------------|
| 0600         | Low            |
| 0b01         | Medium Low     |
| 0b10         | Medium High    |

| Table 18-3. | DMA | Transfer | Priorities |
|-------------|-----|----------|------------|
|             |     |          |            |

# DMA0\_CRn[CP] Priority Level Ob11 High

#### Table 18-3. DMA Transfer Priorities

These priorities serve two purposes. First, the DMA controller arbitrates among all actively requesting channels and selects the highest priority one for service. If multiple channels request at the same priority, the arbiter selects the lowest numbered channel for service. Secondly, DMA0\_CRn[CP] determines the priority of the internal PLB transactions that the DMA controller uses to read and write data.

# 18.5 Data Parity During DMA Peripheral Transfers

The DMA controller works in conjunction with the peripheral bus controller (EBC) to generate and check parity during peripheral mode DMA transfers. When DMA0\_CRn[PCE]=1 parity checking is enabled for peripheral mode transfers on channel n.

During memory-to-memory transfers any data error checking and/or correction is dependent on the configuration of the relevant memory controller. For example, if ECC is enabled on the SDRAM controller, only uncorrectable errors are reported to the DMA controller. Similarly, an EBC memory bank with parity enabled will report an error if a parity error is encountered during a memory read operation. See "Peripheral Bank Access Parameters (EBC0\_BnAP)" on page 16-26 for more information on peripheral bus parity checking.

# 18.6 Errors

The DMA controller detects and reports three types of errors: address alignment, PLB timeout and slave errors. The DMA controller reports errors through the channel error status bit in the DMA status register (DMA0\_SR[RIn]). If the error status bit for a channel is set, the channel enable bit (DMA0\_CRn[CE]) is cleared, disabling the channel. An interrupt signal is also presented to the interrupt controller if DMA0\_CRn[CIE] is set. See "DMA Interrupts" on page 18-15 for more information on interrupt processing.

When the DMA controller has multiple channels active, an error may be reported on the current channel which was in actuality caused by a previously active channel. This causes the current channel to have its error status bit set. Therefore, for deterministic error analysis with multiple DMA channels active the PLB slave bus controller's error status registers (the bus error address register in particular), must be queried to isolate the actual channel which encountered the error. In any case, the channel causing the errors will eventually cause all active channels, including itself, to be disabled.

# 18.6.1 Address Alignment Error

The source address (DMA0\_SAn) and destination address (DMA0\_DAn) registers must be aligned to the programmed transfer width (DMA0\_CRn[TW]). The address alignment rules are outlined in Table 18-4. In addition, when a channel is configured for scatter/gather transfers, the scatter/gather

table must be word-aligned. If the source, destination and scatter/gather address registers are not appropriately aligned an error occurs immediately after the channel is enabled.

| DMA0_CRn[PW]<br>Setting | Required Alignment for:<br>Source Address Register (DMA0_SAn)<br>and<br>Destination Address (DMA0_DAn) |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------|--|--|
| 0b00                    | Byte (8-bit)                                                                                           |  |  |
| 0b01                    | Halfword (16-bit)                                                                                      |  |  |
| 0b10                    | Word (32-bit)                                                                                          |  |  |
| 0b11                    | Doubleword (64-bit)                                                                                    |  |  |

Table 18-4. Address Alignment Requirements

#### 18.6.2 PLB Timeout

The DMA controller uses PLB operations to read and write memory. A PLB timeout results if the DMA controller attempts to access a non-existent memory location. This will occur if the source, destination or scatter/gather address registers do not map to valid memory locations.

#### 18.6.3 Slave Errors

If the DMA controller detects an error from a PLB slave, it finishes any active read/write pair transfer on the channel and then reports an error. An SDRAM uncorrectable ECC error and an EBC bank protection error are examples of PLB slave errors.

# 18.7 DMA Interrupts

Each DMA channel can generate interrupts for end of transfer, terminal count and error conditions. Interrupts from a particular DMA channel are enabled by setting the channel enable bit in the channel's control register (DMA0\_CRn[CIE]=1). When an interrupt occurs for a given channel, the DMA controller sends a signal to the Universal Interrupt Controller. For the PPC405GP's CPU to take an exception, interrupts from the particular DMA channel must be enabled in the interrupt controller's interrupt enable register (UIC0\_ER). Also, the CPU's machine state register's interrupt enable bit must be enabled for the appropriate interrupt type (critical or non-critical), MSR[EE,CE]. See Chapter 10, "Interrupt Controller Operations" for more information on interrupt controller processing.

For DMA channels with interrupts enabled (DMA0\_CRn[CIE]=1) and not performing a scatter/gather transfer an interrupt is generated while any of the following are true:

DMA0\_CRn[TCE]=1 and DMA0\_SR[CSn]=1 DMA0\_SR[TSn]=1 DMA0\_SR[RIn]=1

When a channel is performing a scatter/gather transfer, interrupt generation is further qualified by the TCI, ETI and ERI bits loaded from the descriptor table (see Table 18-5, "Scatter/Gather Descriptor Table," on page 18-16). Any of the following conditions cause an interrupt during a scatter/gather transfer when interrupts are enabled for the channel (DMA0\_CRn[CIE=1]):

TCI=1 and DMA0\_CRn[TCE]=1 and DMA0\_SR[CSn]=1 ETI=1 and DMA0\_SR[TSn]=1 ERI=1 and DMA0\_SR[RIn]=1

For both normal DMA and scatter/gather transfers the interrupt remains active until the appropriate bits are cleared in the DMA Status Register (DMA0\_SR). In addition, interrupts from a channel performing a scatter/gather transfer cause the channel to pause until the interrupt is cleared.

# 18.8 Scatter/Gather Transfers

With a normal DMA transfer it is necessary to program a channel's control, source, destination, and count registers for each transfer. The scatter/gather capability of the DMA controller provides a more efficient solution for applications that require multiple transactions on a single DMA channel. Instead of individually programming a channel's registers, software creates a set (linked list) of descriptor tables in system memory. Table 18-5 illustrates the required table format.

| Memory Address   | Byte 0<br>(MSB)                              |                |        | Byte 1      | Byte 2  | Byte 3<br>(LSB) |  |
|------------------|----------------------------------------------|----------------|--------|-------------|---------|-----------------|--|
| x (word aligned) |                                              |                | DMA Ch | annel Contr | ol Word |                 |  |
| x + 4            |                                              | Source Address |        |             |         |                 |  |
| x + 8            | Destination Address                          |                |        |             |         |                 |  |
| x + 12           | LK TCI ETI ERI Count                         |                |        |             |         |                 |  |
| x + 16           | Next Scatter/Gather Descriptor Table Address |                |        |             |         |                 |  |

 Table 18-5.
 Scatter/Gather Descriptor Table

Table 18-6 details the usage of the bit fields in the scatter/gather table.

#### Table 18-6. Bit Fields in the Scatter/Gather Descriptor Table

| Bit | Mnemonic | Description                                                                                                                             |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0   | LK       | Link<br>0 This is the last descriptor.<br>1 Fetch next descriptor from address DMA0_SGn when the channel completes                      |
| 2   | TCI      | Enable Terminal Count Interrupt<br>0 Do not interrupt when terminal count occurs<br>1 Allow an interrupt when terminal count occurs     |
| 3   | ETI      | Enable End of Transfer Interrupt<br>0 Do not interrupt when end of transfer occurs<br>1 Allow an interrupt when end of transfer occurs. |
| 4   | ERI      | Enable Error Interrupt<br>0 Do not interrupt if an error occurs<br>1 Allow an interrupt if an error occurs                              |

To configure a channel for a scatter/gather transfer the DMA Scatter/Gather Descriptor Address Register (DMA0\_SGn) for the channel is set to the address of the first descriptor table, which must be word-aligned. To begin the scatter/gather transfer, software then writes a start scatter/gather and enable mask to the Scatter/Gather Command Register (DMA0\_SGC). The DMA controller then reads the descriptor table at address DMA0\_SGn and updates the DMA controller registers as shown in

Table 18-7. Upon receiving the data from the scatter/gather descriptor table, the channel's terminal count status bit (DMA0\_SR[TCn]) is automatically cleared.

| Descriptor Table Entry  | Register Loaded |
|-------------------------|-----------------|
| Channel Control Word    | DMA0_CRn        |
| Source Address          | DMA0_SAn        |
| Destination Address     | DMA0_DAn        |
| Count                   | DMA0_CTn        |
| Next Descriptor Address | DMA0_SGn        |

Table 18-7. DMA Registers Loaded from Scatter/Gather Descriptor Table

After loading the channel's registers from the descriptor table, the transfer functions as a normal nonscatter/gather operation.

If the channel control word loaded from the descriptor table enables interrupts for the channel (DMA0\_CRn[CIE]=1), the TCI, ETI, and ERI bits further qualify the generation of interrupts. See "DMA Interrupts" on page 18-15 for more information on scatter/gather interrupts.

If the LK (link) bit was not set the scatter/gather process stops when the current transfer completes. Otherwise, the DMA controller reads the descriptor table at address DMA0\_SGn and the process repeats.

# **18.9 Programming the DMA Controller**

Before the DMA controller can transfer data it must be configured, both globally and on a per-channel basis. Global settings include the DMA Polarity Register (DMA0\_POL) and DMA Sleep Mode Register (DMA0\_SLP). For most applications, these registers should be configured when the DMA controller is first initialized. To prevent spurious activity resulting from changing the active level for DMAReqn, DMAAckn, or EOTn[TCn], a channel's configuration in the Polarity Register should not be altered when the channel is enabled (DMA0\_CRn[CE]=1).

Each channel has a Control (DMA0\_CRn), Source Address (DMA0\_SAn), Destination Address (DMA0\_DAn), Count (DMA0\_CTn), and Scatter/Gather Descriptor Address (DMA0\_SGn) register. The type of DMA transfer determines which of these registers must be programmed and what causes the channel to start. In all cases, the terminal count (CSn), end of transfer (TSn) and error status (RIn) bits in the DMA Status Register (DMA0\_SR) must be cleared or the channel will not start.

The programming information that follows assumes that the DMA controller is operating in nonscatter/gather mode. To use scatter/gather transfers the channel configuration data must be written into a set of descriptor tables in system memory. See "Scatter/Gather Transfers" on page 18-16 for additional details.

#### 18.9.1 Peripheral Mode Transfers

DMA peripherals are either devices attached to the EBC interface via the DMAReqn and DMAAckn lines, or the internal serial port (UARTO). During a peripheral mode transfer an external peripheral asserts DMAReqn to request a DMA transfer. For metastability protection DMAReqn is double latched in the DMA upon assertion, and sampled with a single latch on the deassertion.

Timings on the memory-access portion of peripheral mode DMA transfers are governed by the configuration of the associated memory controller. In contrast, timing during the peripheral portion of the transfer is controlled by the PSC, PWC and PHC fields in the DMA Channel Control Registers. The effect of these parameters on peripheral timings is illustrated in Figure 18-11 on page 18-18 and Figure 18-12 on page 18-19. Although shown as active high, the polarity (active state) of DMAReqn, DMAAckn, and EOTn[TCn] are programmable via the DMA Polarity Register (DMA0\_POL).



Figure 18-11. Peripheral-to-Memory DMA Transfer

Peripheral setup cycles (DMA0\_CRn[PSC]) provide a delay between any previous operation on the peripheral bus and DMAAckn becoming active. Following the setup time DMAAckn is driven active for (DMA0\_CRn[PWC] + 1) PerClk cycles. During peripheral-to-memory transfers read data from the peripheral is sampled on the PerClk edge where DMAAckn rises. After DMAAckn becomes inactive the peripheral bus is held idle for DMA0\_CRn[PHC] PerClk cycles.

The second transfer in Figure 18-11 on page 18-18 illustrates the required DMAReqn timing to prevent a subsequent DMA transfer. For all peripheral mode transfers DMAReqn must be sampled inactive at the end of the last PerClk cycle where DMAAckn is active.

The EOTn[TCn] I/O can be configured either as an end of transfer input (DMA0\_CRn[ETD]=0) or a terminal count output (DMA0\_CRn[ETD]=1). When programmed as a terminal count output, EOTn[TCn] is asserted in the cycle after DMAAckn became inactive and the channel's count register (DMA0\_CTn) reached zero. EOTn[TCn] remains active until the terminal count status bit is cleared in the DMA status register (DMA0\_SR[CSn]).

If EOTn[TCn] is configured as an end of transfer input (DMA0\_CRn[ETD]=0), EOTn[TCn] must be sampled active during the last DMAAckn cycle. If the channel is configured for scatter/gather transfers

EOTn[TCn] should be immediately deasserted to prevent the subsequent transfer from ending prematurely. Figure 18-12 on page 18-19 shows the required timing.



Figure 18-12. Memory to Peripheral DMA Transfer

For both peripheral-to-memory and memory-to-peripheral transfers the transfer width (DMA0\_CR[PW]) must be set to the data bus width of the peripheral. This is because the DMA controller does not pack or unpack data on the peripheral side of transaction.

#### Peripheral-to-Memory Transfer

To perform a peripheral-to-memory DMA transfer from an EBC-attached DMA peripheral:

- Set destination address register (DMA0\_DAn) to the desired memory location. The address must be aligned to the programmed transfer width (DMA0\_CRn[PW]), otherwise an alignment error will occur.
- 2. Program the count register (DMA0\_CTn) for the number of transfers.
- 3. Clear the channel's status bits in the DMA status register (DMA0\_SR).
- 4. In the channel control register (DMA0\_CRn):
  - a. Optionally enable the DMA buffer, BEN=1.
  - b. Optionally enable parity checking, PCE=1.
  - c. Set the destination address increment, DAI=1.
  - d. Set the transfer mode to peripheral, TM=0b00.
  - e. Set the peripheral location to external, PL=0.
  - f. Set the transfer direction to peripheral-to-memory, TD=1.

g. Enable the channel CE=1.

Once the DMA channel is active, the peripheral initiates a transfer by activating the DMAReqn pin for the channel. The PPC405GP then activates the DMAAckn pin to read data from the peripheral. This continues until either a terminal count or end of transfer condition occurs.

#### **Memory-to-Peripheral Transfer**

To perform a memory-to-peripheral DMA transfer to an EBC-attached DMA peripheral:

- Set source address register (DMA0\_SAn) to the desired memory location. The address must be aligned to the programmed transfer width (DMA0\_CRn[PW]), otherwise an alignment error will occur.
- 2. Program the count register (DMA0\_CTn) for the number of transfers.
- 3. Clear the channel's status bits in the DMA status register (DMA0\_SR).
- 4. In the channel control register (DMA0\_CRn):
  - a. Optionally enable the DMA buffer, BEN=1, and set the desired prefetch count, PF.
  - b. Optionally enable parity generation, PCE=1.
  - c. Set the source address increment, SAI=1.
  - d. Set the transfer mode to peripheral, TM=0b00.
  - e. Set the peripheral location to external, PL=0.
  - f. Set the transfer direction to memory-to-peripheral TD=0.
  - g. Enable the channel, CE=1.

Once the DMA channel is active, the peripheral initiates a transfer by activating the DMAReqn pin for the channel. The PPC405GP then reads the source memory and subsequently activates the DMAAckn pin to write data to the peripheral. This continues until either a terminal count or end of transfer condition occurs.

#### 18.9.2 Memory-to-Memory Transfers

Memory-to-memory transfers can be initiated either by software or by an external device. If initiated via software, the transfer begins as soon as the channel is configured and enabled. When initiated by hardware (also known as a device-paced memory-to-memory transfer), software configures the channel for a memory-to-memory move and transfers begin when an external device places an active request on the channel request line, DMAReqn.

#### Hardware-Initiated (Device-Paced) Memory-to-Memory Transfers

To perform a device-paced memory-to-memory DMA transfer:

- 1. Set the transfer width (DMA0\_CRn[PW]) to the width of the device-paced memory.
- Set the source (DMA0\_SAn) and destination (DMA0\_DAn) address registers to the desired memory locations. These addresses must be aligned to the programmed transfer width (DMA0\_CRn[PW]), otherwise an alignment error will occur.
- 3. Program the count register (DMA0\_CTn) for the number of transfers.
- 4. Clear the channel's status bits in the DMA status register (DMA0\_SR).
- 5. In the channel control register (DMA0\_CRn):
  - a. Optionally enable the DMA buffer, BEN=1, and set the desired prefetch count, PF.

- b. If the device-paced memory is at the source memory location set PL=1.
- c. Set the source address increment, SAI, and destination address increment, DAI, as desired.
- d. Set the transfer mode to device-paced memory-to-memory, TM=0b11.
- e. Enable the channel, CE=1.

Once the DMA channel is configured for this mode, the external device initiates a transfer by activating the DMAReqn input. The PPC405GP then reads the source memory, buffers the data in the DMA controller and then outputs the data to the destination memory address. Transfers continue as long as the controlling device maintains an active signal on DMAReqn and the channel count register (DMA0\_CTn) is non-zero. To pause a device paced memory-to-memory transfer, the controlling device-paced memory access.

#### 18.9.3 Software-Initiated Memory-to-Memory Transfers (Non-Deviced Paced)

To perform a software-initiated memory-to-memory DMA transfer:

- 1. Set the transfer width (DMA0\_CRn[PW]) as desired.
- Set the source (DMA0\_SAn) and destination (DMA0\_DAn) address registers to the desired memory locations. These addresses must be aligned to the programmed transfer width (DMA0\_CRn[PW]), otherwise an alignment error will occur.
- 3. Program the count register (DMA0\_CTn) for the number of transfers.
- 4. Clear the channel's status bits in the DMA status register (DMA0\_SR).
- 5. In the channel control register (DMA0\_CRn):
  - a. Optionally enable the DMA buffer, BEN=1.
  - b. Set the source address increment, SAI, and destination address increment, DAI, as desired.
  - c. Set the transfer mode to software-initiated memory-to-memory, TM=0b10.
  - d. Enable the channel, CE=1.

Once the channel is enable the DMA controller transfers data from source to destination until the channel count reaches zero. Note that memory-to-memory transfers initiated by software do not use DMAReqn or DMAAckn.

18-22 PPC405GP User's Manual

# **Chapter 19. Ethernet Media Access Controller**

The PPC405GP Ethernet media access controller (EMAC) is a generic implementation of the Ethernet Media Access Control (MAC) protocol complying with ANSI/IEEE Std 802.3 and IEEE 802.3u supplement. EMAC supports half-duplex (CSMA/CD) and full-duplex operation for both 10-Mbps and 100-Mbps operations.

EMAC provides two on-chip peripheral bus (OPB) slave interfaces. The first OPB interface provides access to EMAC configuration and status registers. The PLB/OPB bridge allows the 405 processor core to access these registers.

The second OPB interface is used to exchange packet information with the memory access layer (MAL). The MAL is a multi-channel, intermediate hardware layer that resides between packetbased communication macros (such as EMAC) and external memory (such as SDRAM or SRAM). The MAL transfers packet information and packet status between the EMAC and external memory separately for each of the three EMAC channels (one receive and two transmit). Software (a device driver) is responsible for maintaining a buffer descriptor ring and a set of data buffers in external memory for each of the channels, and manages the exchange of packet data between the data buffers and the software protocol.

The MAL performs functions such as arbitration between service requests, handling the buffer descriptor memory structure, updating the descriptor status/control fields at the end of packet transfer, and so on. EMAC supports unlimited burst length transactions on the MAL interface.

EMAC utilizes its media independent interface (MII) to communicate with standard physical interface devices (PHYs).

EMAC utilizes independent Receive (RX) and Transmit (TX) FIFOs. Programmable FIFO thresholds minimize overflows and underruns and can launch integrated IEEE 802.3x Pause Packets for flow control.

As part of the Remote Monitoring (RMON) and Management Information Base (MIB) defined in IEEE 802.3z the EMAC contains registers that count the number of octets transmitted and received.

Figure 19-1 illustrates EMAC in a typical Ethernet application.



Figure 19-1. EMAC in a Typical Ethernet Application

**Note:** EMAC is connected to a single OPB, to which both the OPB master and MAL are also connected. The EMAC transmit channels operate independently from the receive channel.

# **19.1 EMAC Features**

The PPC405GP EMAC features:

- Dual speed (10/100 Mbps) CSMA/CD (half-duplex) and full-duplex Ethernet MAC-compliant with ANSI/IEEE Std. 802.3 and IEEE 802.3u supplement.
- Automatic source address insertion or replacement for transmitted packets is a programmable option.
- Automatic stripping of frame padding bytes and frame check sequence (FCS) is a programmable option.

When padding bytes are stripped, the padding and FCS field are removed. FCS stripping removes only the FCS field.

- FCS control for transmit/receive packets.
- · Access to registers with support for burst processing.
- MAL for packet moving having one-cycle MAL slave latency.

- Independent, large (2 KB) transmit and (4 KB) receive FIFOs with programmable thresholds to minimize overruns and underruns.
- Multiple packet handling in transmit and receive FIFOs.
- Unicast, multicast, broadcast, and promiscuous address filtering capabilities.
- Two 64-bit hash filters for unicast and multicast packets.
- · Automatic retransmission of collided packets.
- · Rejection of runt packets before providing them to MAL.
- MII interface for connection to a variety of PHY layer devices.
- · Programmable inter-packet gap to enable tuning for better system performance.
- Compliance with IEEE 802.3x standard packet-based flow control, including self-assembled control
  pause packet transmitting.
- Support for VLAN tag ID in compliance with IEEE Draft 802.3ac/D1.0 standard.
- VLAN tag insertion or replacement for transmit packets is a programmable option.
- Wake On LAN (WOL) handling.
- Programmable internal and external loop-back capabilities.
- Extensive error/status vector generation for each processed packet.
- Power management using a clock and power management (CPM) unit.

# 19.2 EMAC Operation

The EMAC hardware components and its internal structure are illustrated in the block diagram in Figure 19-2.



Figure 19-2. Internal EMAC Structure

The control logic sub-block implements the following functions:

- · OPB slave device
- MAL slave device
- FIFO management logic
- Ethernet address and pause packet match logic
- Register file for FIFOs and Ethernet MAC handler management
- Logic for support of WOL technology

The Ethernet MAC sub-block implements the following functions:

- Transmit MAC Handler (TXMAC)
- Receive MAC Handler (RXMAC)
- MII management function unit (STA)

These functions are described in the following sections.

# 19.2.1 MAL Slave Logic

The MAL slave (MALS) logic controls MAL transactions. MALS transfers TX and RX data between MAL and the OPB on one side, and the EMAC FIFO handlers on the other side. MALS is a dedicated MAL slave.

# 19.2.2 OPB Slave Logic

The OPB slave (OPBS) logic controls all OPB transactions between the processor core and the EMAC configuration and status registers.

# 19.2.3 Ethernet Address Match Logic

Address match logic checks the destination address of received packets against a set of predefined addresses specified by the current address filtering mode. EMAC contains one unicast (individual address) register, two hash tables for filtering individual and group address, and logic for detecting broadcast address (all ones). EMAC supports promiscuous mode and multicast promiscuous mode.

This logic also checks the destination address of the incoming packet against a special multicast address used for control (pause) packet recognition.

All checks for address matching are performed only after the entire destination address field is received (except for promiscuous and multicast promiscuous modes).

# 19.2.4 Configuration and Status Registers

Configuration and status registers define the EMAC configuration and reflect error/status of recent transmitted or received packets.

#### 19.2.5 Wake On LAN Logic

EMAC supports Wake On LAN (WOL) technology, an industry standard in the *Wired for Management* (*WFM*) specification. This technology allows a sleeping or powered-off network node to be awakened with a special packet called a Magic Packet. In the 405GP, with WOL mode enabled, the EMAC

discards all incoming packets and does not request data from the MAL for transmission. When a magic packet is detected, the EMAC generates a UIC interrupt on Interrupt 9, called Ethernet WOL.

#### 19.2.6 Ethernet MAC

The Ethernet MAC logic supports the Media Independent Interface (MII).

#### 19.2.7 EMAC Loop-Back Modes

EMAC supports the external and internal loop-back modes illustrated in Figure 19-3.



Figure 19-3. EMAC Loop-Back Modes

External loop-back mode uses the PHY device. To EMAC, external loop-back is identical to full-duplex operation. Configuring EMAC to operate in a full-duplex mode enables external loop-back. EMAC does not need an external loop-back configuration signal.

In internal loop-back mode, data from the EMAC transmit channel is routed to the EMAC receive channel. This loop-back mode functions correctly with or without a PHY connected to EMAC. In internal loop-back mode, EMAC does not activate (monitor) any MII signals. The transmit channel signals are buffered internally to the receive channel. However, if internal loop-back is used without a PHY, the TX and RX clocks for EMAC must be provided by another means. In internal loop-back mode, the EMAC transmit clock and receive clock must be sourced from a single clock.

#### **19.3 EMAC Transmit Operation**

The transmit part of EMAC is responsible for packet transmission from the MAL device to the MII interface. At the end of the transmission process, EMAC provides a status/error word which allows monitoring the transmission operation.

EMAC implements dual transmit channels with MAL (this means that two transmit channels are allocated within MAL) for efficient utilization of the Transmit FIFO. Both of these channels use the same shared resources inside EMAC. These channels can be configured to independently request packets from MAL and drive them into the TX FIFO or act as a single channel (in dependent mode).

# **19.3.1 Arbitration Between TX Channels**

Because both EMAC transmit channels (referred to as TX Channel 0 and TX Channel 1) drive data into the same FIFO, they cannot request packet data from MAL at the same time. MAL ensures that only one EMAC transmit channel is active at a given time.

# 19.3.2 Independent Mode

In this mode, each EMAC transmit channel independently requests packets from MAL. Each channel can be configured to work in single packet or multiple packet modes.

In single packet mode, EMAC0\_MR1[TR0] = 00 and EMAC0\_MR1[TR1] = 00. The channel requests one packet from MAL and resets EMAC0\_TMR0[GNP0, GNP1] as appropriate. The channel asks for service again only after EMAC0\_TMR0[GNP0] = 1 or EMAC0\_TMR0[GNP1] = 1 (set by the device driver).

In multiple packet mode, EMAC0\_MR1[TR0] = 01 and EMAC0\_MR1[TR1] = 01. After the channel finishes transferring a packet, the channel asks MAL for the next packet as soon as the other channel is in its Idle Phase and there is enough room in the FIFO. The channel continues to request more packets until one of the following events occur:

- The channel receives notification from MAL that the next buffer descriptor is not marked ready for transmission. When this occurs, the channel sets EMAC0\_TMR0[GNP0, GNP1] = 0, as appropriate, and waits for software to reactivate it by setting EMAC0\_TMR0[GNP0] = 1 or EMAC0\_TMR0[GNP1] = 1.
- A transmit error or signal quality error (SQE) occurs and the corresponding interrupt is not masked in the EMAC0\_ISER. After such an error, the channel sets EMAC0\_TMR0[GNP0, GNP1] = 0, as appropriate, and sets EMAC0\_ISR[DB0] = 1 or EMAC0\_ISR[DB1] = 1 (the EMAC0\_ISR field that is set depends on which channel is active) and the corresponding EMAC0\_ISR error. The channel does not request service again until EMAC0\_TMR0[GNP0] = 1 or EMAC0\_TMR0[GNP1] = 1 and EMAC0\_ISR[DB0] = 0 or EMAC0\_ISR[DB1] = 0 (again, depending on channel).

In independent mode, if both channels are configured to work in multiple packet mode and both EMAC0\_TMR0[GNP0] = 1 and EMAC0\_TMR0[GNP1] = 1 at the same time, the channels operate in a sequential repeating manner as long as no errors occur.

# 19.3.3 Dependent Mode

In dependent mode, EMAC0\_MR1[TR0] = 10 and EMAC0\_MR1[TR1] = 10. The two TX channels act as if they were one channel, sharing EMAC0\_TMR0[GNPD]. When EMAC0\_TMR0[GNPD] = 1, the channel specified by EMAC0\_TMR0[FC] starts requesting MAL service. Then, both channels continue to request packets from MAL in an alternating, sequential, repeating manner, until one of the following occurs:

 One of the channels receives notification from MAL that the next buffer descriptor is not marked ready for transmission. When this occurs, EMAC clears EMAC0\_TMR0[GNPD]. At this point, neither channel requests a packet from MAL until EMAC0\_TMR0[GNPD] back to 1. The first channel to request a new packet from MAL when this occurs is the channel that received notification from MAL that no packets were ready to transmit (regardless of the setting of EMAC0\_TMR0[FC]). Further requests continue in an alternating, repeating manner.

- Either a transmit error or an SQE occurs on one of the channels and the corresponding interrupt is not masked in the EMAC0\_ISER. One of the following scenarios can occur.
  - If the other channel has not yet requested MAL service when the channel for which the error occurred receives notification from MAL that the transmit operation has completed,
     EMAC0\_TMR0[GNPD] is cleared (EMAC0\_TMR0[GNPD] = 0) and the EMAC0\_ISR[DBDM] is immediately set (EMAC\_ISR[DBDM]=1).
  - If the other channel was receiving data from MAL, it initiates early termination. If a second
    packet was being transmitted on the media, it is stopped. In these cases, EMAC0\_TMR0[GNPD]
    is cleared (EMAC0\_TMR0[GNPD] = 0) and the EMAC0\_ISR[DBDM] = 1 only after notification
    from MAL that the transmit operation has completed has been received for the second channel.

At this point, neither channel activates a request to MAL until EMAC0\_TMR0[GNPD] = 1 and EMAC0\_ISR[DBDM] = 0. The channel specified by EMAC0\_TMR0[FC] is the first to request service from MAL. Subsequent requests continue in an alternating, sequential manner.

#### 19.3.3.1 MAL TX Descriptor Control/Status Field

For each packet that is transmitted, MAL uses the descriptor control/status field of the buffer descriptor to both provide EMAC with control information (write) and to obtain packet status from EMAC after transmission is complete (read). Software writes the control bits in the buffer descriptor prior to packet transmission, and then reads the status bits from the buffer descriptor after packet transmission has completed. See "Buffer Descriptor Overview" on page 20-7 for more information on the buffer descriptor structure.



Figure 19-4. MAL TX Descriptor Control/Status Field

| Bits                                  | Bit Name              | Bit Description                                                                                                                                                                                                                                                            | Mode |  |  |  |
|---------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|--|
| 05                                    | MAL Usage             | See "TX Status/Control Field Format" on page 20-15.                                                                                                                                                                                                                        | R    |  |  |  |
| TX Control Information (Write Access) |                       |                                                                                                                                                                                                                                                                            |      |  |  |  |
| 6                                     | Generate FCS          | <ul> <li>0 FCS is not generated by EMAC.</li> <li>1 EMAC calculates and adds the FCS field to the packet to be transmitted.</li> </ul>                                                                                                                                     | W    |  |  |  |
| 7                                     | Generate padding      | <ul> <li>0 Padding is not generated by EMAC.</li> <li>1 EMAC adds the padding field to the packet to be<br/>transmitted (only when Generate FCS is also set).</li> </ul>                                                                                                   | w    |  |  |  |
| 8                                     | Insert source address | <ul> <li>0 EMAC will not insert source address.</li> <li>1 EMAC inserts the source address field into the packet to be<br/>transmitted using the content of the Individual Address High<br/>(EMAC0_IAHR) and Individual Address Low<br/>(EMAC0_IALR) Registers.</li> </ul> | W    |  |  |  |

| Bits    | Bit Name                                 | Bit Description                                                                                                                                                                                                                                                                                                                | Mode |
|---------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 9       | Replace source address                   | <ul> <li>EMAC will not replace source address.</li> <li>EMAC replaces the source address field in the packet to be<br/>transmitted using the content of the Individual Address High<br/>(EMAC0_IAHR) and Individual Address Low<br/>(EMAC0_IALR) Registers.</li> </ul>                                                         | W    |
| 10      | Insert VLAN Tag                          | <ul> <li>0 EMAC will not insert a VLAN tag.</li> <li>1 EMAC inserts the VLAN Tag field into the packet to be<br/>transmitted using the content of the VLAN TPID register<br/>(EMAC0_VTPID).</li> </ul>                                                                                                                         | W    |
| 11      | Replace VLAN Tag                         | <ul> <li>0 EMAC will not replace the VLAN tag.</li> <li>1 EMAC replaces the VLAN Tag field in the packet to be<br/>transmitted using the content of the VLAN TPID register<br/>(EMAC0_VTPID).</li> </ul>                                                                                                                       | W    |
| TX Stat | us Information (Read Acce                | ss)                                                                                                                                                                                                                                                                                                                            |      |
| 6       | Bad FCS on transmitted frame             | <ul><li>0 FCS was correct in the transmitted packet.</li><li>1 Indicates that a bad FCS was found in the transmitted packet.</li></ul>                                                                                                                                                                                         | R    |
| 7       | Bad previous packet in<br>dependent mode | <ol> <li>Packet transmission OK.</li> <li>Indicates that a Descriptor Error, Transmit Error, or SQE<br/>Error occurred in the previously transmitted frame. This bit<br/>will only be activated in dependent mode.</li> </ol>                                                                                                  | R    |
|         | Loss of carrier sense                    | <ul> <li>0 No loss of carrier.</li> <li>1 During the transmission of a frame, the PHY_CRS input<br/>was de-asserted after it previously was asserted, or it was<br/>not asserted at all.</li> </ul>                                                                                                                            | R    |
| 9       | Excessive deferral                       | <ul> <li>0 No excessive deferral.</li> <li>1 Indicates that the current frame has been deferred for an excessive period of time. Applicable only in half duplex mode. The value of this period in bit times is calculated in the following ways: For 10/100 Mbps operation it is: 2 x (maxFrameSize x 8) bit times.</li> </ul> | R    |
| 10      | Excessive collisions                     | <ul> <li>0 Less than 16 collisions.</li> <li>1 Indicates that the current frame transmission had ended<br/>with a collision on the 16th consecutive attempt. Applicable<br/>only in half-duplex mode.</li> </ul>                                                                                                               | R    |
| 11      | Late collision                           | <ol> <li>No late collision.</li> <li>Frame collided outside of the collision window. Applicable<br/>only in half-duplex mode.</li> </ol>                                                                                                                                                                                       | R    |
| 12      | Multiple collision                       | <ol> <li>More than 1 but less than 16 collisions did not occur.</li> <li>Transmitted frame collided more than once but less than 16 times. Applicable only in half-duplex mode.</li> </ol>                                                                                                                                     | R    |
| 13      | Single collision                         | <ul> <li>0 Single collision did not occur.</li> <li>1 Activates if transmitted frame collided once. Applicable only<br/>in half-duplex mode.</li> </ul>                                                                                                                                                                        | R    |
| 14      | Underrun                                 | <ul> <li>0 Underrun did not occur.</li> <li>1 Frame transmission was aborted because of underrun;<br/>data from the Transmit FIFO was not valid in time to allow<br/>continuous data transmission on the MII interface.</li> </ul>                                                                                             | R    |

| Bits | Bit Name | Bit Description                                                                                                                                                                                          | Mode |  |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|
| 15   | SQE      | <ul> <li>O Signal Quality Error did not occur.</li> <li>1 Signal Quality Error test failed during packet transmission.<br/>Applicable only in half -duplex mode during 10 Mbps<br/>operation.</li> </ul> | R    |  |

#### 19.3.3.2 Early Packet Termination in Transmit

EMAC can initiate early packet termination during transmit, terminating packet transmission before MAL finishes transferring all packet data from memory to the Transmit FIFO of EMAC. This is typically used when error conditions force the EMAC to abort a transmission.

EMAC performs early termination on the MAL interface if any of the following conditions occur:

- 1. Underrun in the Transmit FIFO.
- 2. Excessive Collisions.
- 3. Excessive Deferral.
- 4. Late Collision.

#### 19.3.3.3 Empty Packets

EMAC treats empty packets as if a normal packet had been written, but without writing data to the FIFO. A status word of all 0s is returned after an empty packet. EMAC expects that for word-aligned packets, MAL activates the related word transfer indication during the last data transfer, rather than providing an empty packet indication.

#### 19.3.3.4 Automatic Retransmission of Collided Packets

EMAC automatically retransmits packets that collide on the MII interface. The Transmit FIFO always preserves the first 64 bytes of the packet until it receives an indication that the collision window has passed. Otherwise, if a collision was detected within the collision window, the packet is retransmitted automatically without a new request from MAL.

#### 19.3.3.5 Inter-Packet Gap (IPG) Tuning

EMAC allows the user to program the length of the IPG using the EMAC0\_IPGVR register, which contains one-third of the IPG value. By changing the content of this register, the user can adjust the fairness or aggressiveness of EMAC on the medium. By programming a lower number (but not less than four), EMAC becomes more aggressive on the media. The aggressive nature can result in EMAC capturing the network by forcing less aggressive nodes to defer. By programming a larger number of bit times, EMAC becomes less aggressive on the network and may defer more often than normal. EMAC performance may decrease as the IPG period is increased from the default value, but the resulting behavior may improve media performance by reducing the occurrence of collisions.

#### 19.3.3.6 Full-Duplex Operation

Full-duplex operation allows simultaneous transmit and receive activity on the MII interface. The software can enable full-duplex mode by setting the EMAC0\_MR1[FDE] = 1. During operation in full-duplex mode, the following changes are made in EMAC functionality.

• Transmission is not deferred while receive is active.

- The IPG counter, which controls transmit deferral during the IPG between back-to-back transmits, is started when transmit activity for the first packet ends, instead of when transmit and carrier activity end.
- SQE test is not performed.
- Collision indication is ignored.

#### 19.3.3.7 Packet Content Configuration Options

EMAC can modify the content of the packet coming from MAL before issuing it to the MII interface. Figure 19-5 illustrates possible changes in the transmit packet format.



The following options can be set for each packet, and can be provided as a part of command write transactions from MAL (see "MAL TX Descriptor Control/Status Field" on page 19-7).

- Perform data padding automatically for short transmit packets. EMAC pads the transmit packet with
  extra bytes between the data and the FCS field to reach a total length of 64 bytes (including FCS).
  This feature is supported only when the packet coming from the Transmit FIFO does not contain
  the FCS. Automatic padding enables software to avoid sending padding as a part of the packet
  data field, and therefore, reduces the amount of data transferred on the system bus during the
  transmission of the short packet.
- Source address insertion. When chosen, EMAC adds the source address (SA) field to the transmitted packet. EMAC uses the content of the Individual Address High and Individual Address Low registers for the source address value. This mode is mutually exclusive with source address replacement mode.

- Source address replacement. When chosen, EMAC replaces the source address received from the Transmit FIFO with the content of the Individual Address High and Individual Address Low registers. This mode is mutually exclusive with the source address insertion mode.
- Add four FCS bytes. EMAC calculates the FCS for the transmitted packet. The FCS is appended to data coming from the Transmit FIFO or padding bytes (if added).
- VLAN Tag insertion. When chosen, EMAC adds the content of the VLAN Tag field to the transmitted packet (see "VLAN Support" on page 19-18). EMAC uses the content of the VLAN TPID and VLAN TCI registers for the VLAN Tag value. This feature is supported only when the packet coming from the Transmit FIFO does not contain an FCS. This mode is mutually exclusive with the VLAN Tag replacement mode.
- VLAN Tag replacement. When chosen, EMAC replaces the content of the VLAN Tag field in the transmitted packet. EMAC uses the content of the VLAN TPID and VLAN TCI registers for the VLAN Tag value. This feature is supported only when the packet coming from the Transmit FIFO does not contain an FCS. This mode is mutually exclusive with the VLAN Tag insertion mode.

Table 19-1 summarizes the possible options of adding FCS and source address to the transmitted packet.

| . Cor        | figuration Option | ons        | EMAC Action |        |            |  |  |
|--------------|-------------------|------------|-------------|--------|------------|--|--|
| Generate FCS | Insert SA         | Replace SA | Add FCS     | Add SA | Replace SA |  |  |
| 0            | Don't care        | Don't care | N           | N      | N          |  |  |
| 1            | 0                 | 0          | Y           | N      | N          |  |  |
| 1            | 0                 | 1          | Y           | N      | Y          |  |  |
| 1            | 1                 | 0          | Y           | Y      | N          |  |  |

Table 19-1. FCS/SA Enable - Possible Configurations

Table 19-2 summarizes the possible options of adding FCS and padding to the transmitted packet.

 Table 19-2.
 FCS/Pad Enable - Possible Configurations

| Configurati  | on Options   | EMAC    | Action  |  |
|--------------|--------------|---------|---------|--|
| Generate FCS | Generate Pad | Add FCS | Add Pad |  |
| 0            | Don't care   | N       | N       |  |
| 1            | 0            | Ŷ       | N       |  |
| 1            | 1            | Υ       | Y       |  |

Table 19-3 summarizes the possible options of adding FCS and VLAN Tag to the transmitted packet.

| Table 19-3. | FCS/VLAN | Tag Enable | - Possible | Configurations |  |
|-------------|----------|------------|------------|----------------|--|
|             |          |            |            |                |  |

| Co           | nfiguration Optio  | ons                 | EMAC Action |                    |                     |  |  |
|--------------|--------------------|---------------------|-------------|--------------------|---------------------|--|--|
| Generate FCS | Insert VLAN<br>Tag | Replace VLAN<br>Tag | Add FCS     | Insert VLAN<br>Tag | Replace VLAN<br>Tag |  |  |
| 0            | Don't care         | Don't care          | N           | N                  | N                   |  |  |
| 1            | 0                  | 0                   | Y           | N                  | N ·                 |  |  |
| 1            | 0                  | 1                   | Y           | N                  | Y                   |  |  |

| Co           | nfiguration Optic  | ons                 | EMAC Action |                    |                     |  |  |
|--------------|--------------------|---------------------|-------------|--------------------|---------------------|--|--|
| Generate FCS | Insert VLAN<br>Tag | Replace VLAN<br>Tag | Add FCS     | Insert VLAN<br>Tag | Replace VLAN<br>Tag |  |  |
| 1            | 1                  | 0                   | Y           | Y                  | N                   |  |  |

#### Table 19-3. FCS/VLAN Tag Enable - Possible Configurations

# **19.4 EMAC Receive Operation**

The receive part of EMAC is responsible for receiving packets coming from the physical layer (PHY) device and forwarding them to the receive channel of the attached MAL. At the end of the reception process, EMAC provides a status/error word which allows software to monitor the receive operation.

# 19.4.1 EMAC – MAL RX Packet Transfer Flow

EMAC initiates request for service from MAL whenever the number of occupied entries in the Receive FIFO reaches the low water mark specified in EMAC0\_RWMR[RLWM].

# 19.4.2 MAL RX Descriptor Status

For each packet that is received, MAL obtains status from EMAC after reception is complete, and writes this information into the buffer descriptor status/control field. Software uses this information to monitor the status of received packets. See "Buffer Descriptor Overview" on page 20-7 for more information on the buffer descriptor structure.



Figure 19-6. MAL RX Descriptor Control/Status Field

| Bits    | Bit Name                | Bit Description                                                                                                                                                                                                       |   |  |  |  |
|---------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|
| 05      | MAL Usage               | See "RX Status/Control Field Format" on page 20-16.                                                                                                                                                                   | R |  |  |  |
| RX Stat | us Information (Read Ad | ccess)                                                                                                                                                                                                                |   |  |  |  |
| 6       | Overrun Error           | <ul> <li>0 No overrun error.</li> <li>1 EMAC detected an overrun error.</li> <li>An overrun error occurs if the flow of received data to the RX<br/>FIFO is corrupted because of insufficient empty space.</li> </ul> | R |  |  |  |
| 7       | Pause Packet            | <ol> <li>Received packet is not a control pause packet.</li> <li>Received packet is a control pause packet.</li> </ol>                                                                                                | R |  |  |  |
| 8       | Bad Packet              | 0 No packet errors.<br>1 Early termination caused by packet error.                                                                                                                                                    | R |  |  |  |
| 9       | Runt Packet             | <ul> <li>0 Duration of PHY_RX_DV signal OK.</li> <li>1 Duration of PHY_RX_DV signal greater than ShortEventMax<br/>Time constant and less than collision windows.</li> </ul>                                          | R |  |  |  |

| Bits | Bit Name           | Bit Description                                                                                                                                                                                                                                                                                                                            | Mode |
|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 10   | Short Event        | <ul> <li>0 Duration of PHY_RX_DV signal OK.</li> <li>1 Duration of PHY_RX_DV signal was less than<br/>ShortEventMaxTime constant.</li> </ul>                                                                                                                                                                                               | R    |
| 11   | Alignment Error    | <ul><li>0 Received packet length OK.</li><li>1 Received packet length not an integral number of octets.</li></ul>                                                                                                                                                                                                                          | R    |
| 12   | Bad FCS            | <ul> <li>0 FCS OK.</li> <li>1 The FCS value does not match the FCS value calculated by<br/>EMAC.</li> </ul>                                                                                                                                                                                                                                | R    |
| 13   | Packet Too Long    | <ul> <li>0 Received packet length OK.</li> <li>1 Received packet length exceeded maximum allowed value.</li> <li>The received packet exceeded the maximum packet length:</li> <li>1518 octets for standard packet</li> <li>1522 octets for VLAN tagged packetData following the maximum packet length is not transferred to MAL</li> </ul> | R    |
| 14   | Out of Range Error | <ul> <li>0 Received packet length field value OK.</li> <li>1 Received packet length field value greater than maximum<br/>allowed LLC data size.</li> <li>The maximum allowed logical link control (LLC) data size is<br/>greater than 1500 and less than 1536.</li> </ul>                                                                  | R    |
| 15   | In Range Error     | Refer to Table 19-4 for a description of conditions for activating this status bit.                                                                                                                                                                                                                                                        | R    |

#### Table 19-4. In Range Length Error Behavior for Various Packet Lengths

| Programmed Length (Bytes)                                                                   | Actual Length                                         | EMAC Action                            |
|---------------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------------------|
| Less than 46<br>(42 if VLAN Tagged packet)                                                  | Differs from 46 (42 in case of VLAN<br>Tagged packet) | In range length error is activated     |
| Less than 46<br>(42 if VLAN Tagged packet)                                                  | 46 (42 in case of VLAN Tagged packet)                 | In range length error is not activated |
| Greater than or equal to 46<br>(42 if VLAN Tagged packet)<br>and less than or equal to 1500 | Equals the length field value                         | In range length error is not activated |
| Greater than or equal to 46<br>(42 if VLAN Tagged packet)<br>and less than or equal to 1500 | Differs from the length field value                   | In range length error is activated     |

#### 19.4.3 Early Packet Termination In Receive

Early packet termination occurs when packet reception is aborted by EMAC before the packet data transfer to MAL is completed.

EMAC performs early termination in the following cases.

- · An overrun occurs in the receive FIFO
- Packet is too long and the Receive Oversize Packet option is not enabled (EMAC0\_RMR[ROP] = 0)

# 19.4.4 Discarding Packets During Receive

Receive packets can be discarded if certain error conditions are detected. EMAC behavior depends on whether the packet to be discarded is already being output to MAL. If the packet containing the error is not being provided to MAL when the discard condition is detected, the packet is flushed from the Receive FIFO. In this case, EMAC does not provide status information to MAL. If the packet containing the error is already being output to MAL, then EMAC initiates an early packet termination procedure, as described in "Early Packet Termination In Receive" on page 19-13.

Each receive discard condition can be individually controlled using appropriate settings, as described in "Receive Mode Register (EMAC0\_RMR)" on page 19-29.

# 19.4.5 WOL Support

WOL logic in EMAC supports WOL technology, an industry standard in the Wired for Management (WFM) Specification. WOL remotely awakens sleeping or powered-off nodes on a network. To wake up a node, a specific packet, called a *magic packet*, is sent to network node. When so configured, EMAC monitors the incoming bit stream for a magic packet.

The magic packet, also called a wake-up packet, contains a unique data field not normally expected in typical LAN traffic. When a WOL-enabled adapter on a powered-off client decodes this data field, a wake-up signal is generated. In the 405GP, with WOL mode enabled, the EMAC discards all incoming packets and does not request data from the MAL for transmission. When a magic packet is detected, the EMAC generates an interrupt on UIC Interrupt 9, called Ethernet WOL.

Figure 19-7 shows the wake-up packet format. The key to the wake-up packet is the MAC address of the target client, which is repeated 16 times. This pattern of 16 addresses in the data field is not expected to occur in any packet except the wake-up packet.



DA - destination address (six bytes) - UAA or Broadcast address SA - source address (six bytes) Length/Type - length of data field (802.3)/type definition (Ethernet) (two bytes) optional - for example, IP header CRC - Cycle Redundancy Check (four bytes)

#### Figure 19-7. Wake-Up Packet Format

The destination address can be a specific address, called the universally administered address (UAA), or a broadcast address. If the destination address is a UAA, the wake-up packet is sent only to the client at that address. However, since the client is powered off and is no longer transmitting, some protocols remove the client MAC address from routing tables and internal caches at other nodes. In this case, wake-up packets addressed to a target client are discarded because nodes and routers do

not know where to send them. The solution to this problem is to use a broadcast address. A directed broadcast has a valid network address and a broadcast host address. Network routers and nodes forward directed broadcasts to the appropriate network, where it is seen as a MAC-level broadcast and detected by the powered-off client.

#### 19.4.5.1 EMAC WOL Support

EMAC enters WOL mode when the wake-up bit in Mode Register 0 is set (EMAC0\_MR0[WKE] = 1).

WOL mode should only be changed while the receive MAC idle bit in Mode Register 0 is set (EMAC0\_MR0[RXI] = 1) and the receive MAC enable bit is reset (EMAC0\_MR0[RXE] = 0). After the wake-up enable bit is set (EMAC0\_MR0[WKE] = 1), the receive MAC enable bit can be set (EMAC0\_MR0[RXE] = 1).

A reset (soft or hard) should be issued before programming EMAC to WOL mode. When programmed to WOL mode, EMAC does not propagate any received packet to MAL. Also, EMAC transmit channels do not request data from MAL.

# 19.5 Flow Control

EMAC implements full-duplex flow control for efficient system performance by handling specific MAC control packets contained in the pause opcode. EMAC supports flow control as defined in the IEEE 802.3x-1997 standard.

#### 19.5.1 MAC Control Packet

The flow control mechanism allows the Receive FIFO control logic to automatically notify the node transmitting packets to suspend its transmission for a defined period of time. The pause control packet has a fixed length defined as follows:

MinFrameSize-32 bits (60 bytes)

MAC control packets have a unique value of 0x8808 in the length/type field, and share the same packet format as normal Ethernet packets, except that the data field consists of an opcode field and a parameter field. The opcode field contains an opcode command and the parameter field contains a value associated with the opcode command (0x0001). The only opcode command defined by IEEE 802.3x is the Pause opcode; the parameter field for the Pause opcode defines the pause time. MAC control packets with the Pause opcode, also called pause packets, can have a destination address equal to a reserved multicast address, or can be the address of the receive station itself. The reserved multicast address is 0x0180C2000001.

Figure 19-8 illustrates the control packet format.

| F | Preamble | SPD | DA | SA | Length/<br>Type | Opcode | Timer Value<br>Field | Reserved | FCS |  |
|---|----------|-----|----|----|-----------------|--------|----------------------|----------|-----|--|
|---|----------|-----|----|----|-----------------|--------|----------------------|----------|-----|--|

Preamble - Alternating zeroes and ones (7 bytes) SPD (Start Of Packet Delimiter), 1 byte DA (Destination Address) = 0x0180C2000001 SA (Source Address) = Universally Administered Address (UAA) Length/Type = 0x8808 Opcode Field = 0x0001 Timer Value Field = PauseValue Reserved = zeroes (42 bytes) FCS = calculated FCS

Figure 19-8. Control Packet Format

The timer value field contains the value of the delay interval in resolution of *pause\_quanta*, defined in IEEE 802.3x as follows: "MAC Control Parameter[s] (pause\_time) is a 2-octet, unsigned integer containing the length of time for which the receiving station is requested to inhibit data packet transmission. The field is transmitted most-significant octet first, and least-significant octet second. The pause\_time is measured in units of pause\_quanta, equal to 512 bit times. The range of possible pause\_time is 0 to 65535 pause\_quanta."

# 19.5.2 Control Packet Transmission

There are two options to initiate the transmission of a pause packet from EMAC. The transmitted pause packet will force the node, with the destination address specified, to temporarily suspend the transmission of packets to EMAC.

Option 1

Software initiated. The packet transferred to EMAC by MAL for transmission is a pause packet created by software. EMAC transmits this as a normal packet.

Option 2

Automatic flow control initiated. The EMAC integrated flow control mechanism detects the need for and then transmits a control (pause) packet automatically. When building the control packet, EMAC obtains the SA (source address) field from the Individual Address Registers (EMACO\_IAHR and EMACO\_IALR), and the timer value from the Pause Timer Register (EMACO\_PTR[TVF]). The contents of the other fields in the packet are represented in Figure 19-8.

# 19.5.3 Integrated Flow Control

To enable integrated flow control in full-duplex mode, set EMAC0\_MR1[EIFC] = 1. When the receive FIFO reaches a predefined threshold level (called a high water mark and specified by EMAC0\_RWMR[RHWM]), an internal request for control (pause) packet transmission is activated. EMAC sends a control (pause) packet when a new packet enters the Receive FIFO and the number of vacant entries in the Receive FIFO is less than the high water mark. When the Receive FIFO reaches another predefined threshold level (the low water mark, specified by

EMACO\_RWMR[RLWM]), a new internal request for a pause packet transmission, with a zero pause timer value, is activated. EMAC sends a pause packet, with a zero pause timer value, only once, and only if a pause packet with a non-zero value in the pause timer was transmitted earlier.



Figure 19-9. Integrated Flow Control Mechanism

#### 19.5.4 Control Packet Reception

In the receive path, EMAC can be configured to respond to pause packets, or ignore them, as specified by the allow pause packet bit in Mode Register 1 (EMAC0\_MR1[APP]). When response to pause packets is enabled and EMAC detects a valid MAC control packet with a Pause opcode, EMAC stores the value of the Timer Value field. The received packet is considered a valid control packet only if no error was detected during the packet reception. If, at the end of packet reception, the packet is considered valid, EMAC launches a pause operation state machine, as specified in the IEEE P802.3x standard. Figure 19-10 on page 19-18 illustrates the pause operation state machine.

If a control (pause) packet is received while another packet is being transmitted, the ongoing transmission process is completed and the transmitter is paused. If other packets are in the Transmit FIFO, their transmission is delayed until the pause timer has expired. EMAC normally does not pass

the MAC control packets to MAL unless the Propagate Pause Packets bit is set in the Receive mode (EMAC0\_RMR[PPP] = 1).



Figure 19-10. Pause Operation State Machine

In the Pause Function state, EMAC decrements its internal pause timer, which was set to the Timer Value field of the received control packet.

- Note 1: The transmission of control (pause) packets is not affected by the reception of a receive control (pause) packet. Received control (pause) packets inhibit only the transmission of regular packets from the Transmit FIFO.
- Note 2: Receipt of a new valid control (pause) packet causes the pause timer of EMAC to be reloaded with the contents of Timer Value field of the recently received packet, regardless of the current pause timer setting. This indicates new pause operations take precedence over earlier pause operations.

# 19.6 VLAN Support

EMAC can handle VLAN tagged packets, as specified in IEEE Draft P802.3ac/D1.0a standard when EMAC0\_MR1[VLE] = 1.

A Tagged MAC Frame is an extension of the standard MAC packet. The extension for VLAN tag support consists of a 4-octet VLAN tag inserted between the end of the Source Address and the beginning of the Length/Type fields of the MAC packet.

The VLAN tag consists of two fields:

- A 2-octet constant Type field value equal to the VLAN Tag Protocol Identifier (0x8100)
- A 2-octet field containing Tag Control Information (TCI)

The MAC Client Data and FCS fields of the basic MAC packet follow the VLAN tag. The length of the packet is extended by four octets by the VLAN tag (up to 1522 bytes). The FCS is calculated over all fields from the Destination Address through the end of the MAC client data or Pad (if present); that is, all fields except the preamble, SPD, and FCS.

Figure 19-11 illustrates the Tagged MAC Frame format.

| Preamble | SPD | DA | SA | Type=TPID | Tag<br>Control | Length/<br>Type | Data | Pad | FCS |  |
|----------|-----|----|----|-----------|----------------|-----------------|------|-----|-----|--|
|----------|-----|----|----|-----------|----------------|-----------------|------|-----|-----|--|

Preamble – Alternating 0s and 1s (7 bytes) SPD (Start Of Packet Delimiter)1 byte

DA (Destination Address) 6 bytes SA (Source Address) 6 bytes TPID (Tag Protocol Identifier, 2 bytes) = 0x8100

TCI (Tag Control Information) 2 bytes

Length/Type 2 bytes Data (42–1500 bytes) Pad (Optional field) FCS – Calculated FCS

#### Figure 19-11. Tagged MAC Packet Format

Figure 19-12 illustrates the structure of the TCI field.



CFI is a Canonical Format Indicator (always 1 for Ethernet media)



# 19.6.1 VLAN Tagged Packet Transmission

When EMAC0\_MR1[VLE] = 1, the following configuration options are available, depending on the content of the appropriate bits in the MAL control word (see section 19.3.3.1, "MAL TX Descriptor Control/Status Field," on page 7):

- The Generate FCS bit (bit 6) is not set or both Insert VLAN Tag and Replace VLAN Tag bits (bits 10
  and 11, respectively) are not set: EMAC transmits the packet without any changes
- Bit 6 is set and bit 10 is also set: EMAC will insert TPID and Tag control information for the transmitting packet using the content of EMAC0\_VTPID and EMAC0\_VTCI, respectively
- Bit 6 is set and bit 11 is also set: EMAC will replace TPID and Tag control information for the transmitting packet using the content of EMAC0\_VTPID and EMAC0\_VTCI, respectively

#### 19.6.2 VLAN Tagged Packet Reception

If EMAC0\_MR1[VLE] = 1, EMAC parses the VLAN Tag unique type/length in the incoming packet during the receive process. If the VLAN Tag is equal to the value stored in the EMAC0\_VTPID, EMAC

continues the receive process and allows the received packet to contain up to 1522 octets. Otherwise, the receive process is continued unless the length is greater than 1518 bytes.

#### 19.6.3 Address Match Mechanism

The address match (or filtering) mechanism is a hardware aid that reduces the average amount of CPU cycles required to determine whether an incoming packet should be accepted.

EMAC uses various address filters for incoming packets by using the following address recognition modes.

- · Individual mode (also referred to as physical)
- Multicast mode (also referred to as group)
- Broadcast mode (an all-ones group address)
- · Promiscuous mode
- Promiscuous multicast mode
- WOL mode

A flowchart for address recognition of received packets is shown in Figure 19-13 on page 19-22. If the least significant bit (LSb) of the first byte of the destination address (DA) is 0, the packet is considered individual. If the first bit received is 1, the packet is considered multicast. When the DA field contains all 1s, the packet is broadcast, a special type of multicast.

#### 19.6.3.1 Non-WOL Mode

When EMAC operates in single individual mode (EMAC0\_RMR[IAE] = 1), the DA of the received packet is compared to the physical address stored in the Individual Address High register (EMAC0\_IAHR) and Individual Address Low (EMAC0\_IALR) register.

When EMAC operates in multiple individual mode (EMAC0\_RMR[MIAE] = 1), EMAC performs a calculation on the contents of the DA field (logical address filter) to determine whether or not to accept the packet.

When EMAC operates in promiscuous mode (EMAC0\_RMR[PME] = 1), all properly formed packets are received, regardless of the content of the DA field.

When EMAC operates in multicast promiscuous mode (EMAC0\_RMR[PMME] = 1), all multicast packets are received, regardless of the content of the DA field.

When EMAC operates in broadcast address mode (EMAC0\_RMR[BAE] = 1), EMAC performs an address compare on received packets with broadcast addresses.

When EMAC operates in multicast address mode (EMAC0\_RMR[MAE] = 1), EMAC performs a calculation on the contents of the DA field (logical address filter) as in multiple individual mode, in order to determine whether or not the packet should be accepted.

The logical address filter hardware is an implementation of a hash code searching technique commonly used by software programmers. The hardware maps the DA of the incoming packet into one of the 64 categories that correspond to 64 bits stored in the EMAC0\_IAHT1-EMAC0\_IAHT4 or EMAC0\_GAHT1-EMAC0\_GAHT4 registers. The hardware accepts or rejects the packet, depending on the state of the corresponding bit in the EMAC0\_IAHT1-EMAC0\_IAHT4 or EMAC0\_GAHT1-EMAC0\_GAHT1-EMAC0\_GAHT1-EMAC0\_IAHT1-EMAC0\_GAHT1-EMAC0\_GAHT1-EMAC0\_IAHT4 or EMAC0\_GAHT4 registers that corresponds to the selected category.

Figure 19-14 on page 19-23 shows the details of the hardware mapping algorithm. The example depicts multiple individual address mode, but with changes can be used for the multicast address mode.

If the most significant bit of an incoming address is a 0, the address is individual and is passed to the individual address filter. If the most significant bit of an incoming address is a 1, the address is multicast and is passed to the multicast address filter. The individual/multicast address filter is a 64-bit mask composed of EMAC0\_IAHT1-EMAC0\_IAHT4 or the EMAC0\_GAHT1-EMAC0\_GAHT4 registers (each register contains 16 bits of a 64-bit mask). The incoming address is sent through the FCS circuit. After the 48 address bits have gone through the FCS circuit, the high-order six bits of the resulting FCS (32-bit CRC) are used to select one of the 64-bit positions in the individual/multicast address filter. If the selected filter bit is a 1, the address is accepted.

**Note:** The individual/multicast address filter ensures only that there is a possibility that the incoming packet belongs to this node. To determine if the packet belongs to the node, the incoming individual/multicast address propagated to the main memory is compared by software to the list of logical addresses to be accepted by this node.

For software, the task of mapping an individual/multicast address to one of 64 bit positions requires a program that uses the same CRC algorithm to calculate the hash.

#### 19.6.3.2 WOL Mode

In WOL mode (EMAC0\_MR0[WKE] = 1), EMAC operates only with the broadcast or individual address in the destination address field.



Figure 19-13. Receive Address Recognition Flowchart

The example in Figure 19-14 shows that the received individual address maps into category 24, and that bit 8 in EMAC0\_IAHT2 is set. The match indication is activated and the packet should be accepted.



Figure 19-14. Ethernet Address Filter Operation

# **19.7 EMAC Registers**

This section describes the EMAC registers. The EMAC registers are accessed through the OPB. Access to the registers should be word-aligned.

| Register Name                       | Address             | Write Access                                     | Power-on<br>Reset Value | Access   | Page  |
|-------------------------------------|---------------------|--------------------------------------------------|-------------------------|----------|-------|
| EMAC0_MR0                           | 0xEF600800          | See description in "Scenario 1"<br>on page 19-45 | 0xC0000000              | R/W      | 19-27 |
| EMAC0_MR1                           | 0xEF600804          | Reset                                            | 0x00000000              | R/W      | 19-25 |
| EMAC0_TMR0                          | 0xEF600808          | See description on page 19-27                    | 0x00000000              | R/W      | 19-27 |
| EMAC0_TMR1                          | 0xEF60080C          | See description on page 19-28                    | 0x380F0000              | R/W      | 19-28 |
| EMAC0_RMR                           | 0xEF600810          | Reset                                            | 0x00000000              | R/W      | 19-29 |
| EMAC0_ISR                           | 0xEF600814          | Always                                           | 0x00000000              | R/W      | 19-30 |
| Note: Refer to "Power-Up<br>column. | and Initialization" | on page 19-44 for definitions of le              | tters in the Wri        | e Access | Mode  |

Table 19-5. EMAC Register Summary

| Register Name | Address    | Write Access                  | Power-on<br>Reset Value | Access | Ра |
|---------------|------------|-------------------------------|-------------------------|--------|----|
| EMACO_ISER    | 0xEF600818 | Reset                         | 0x00000000              | R/W    | 19 |
| EMAC0_IAHR    | 0xEF60081C | Reset, R, T                   | 0x00000000              | R/W    | 19 |
| EMAC0_IALR    | 0xEF600820 | Reset, R, T                   | 0x00000000              | R/W    | 19 |
| EMAC0_VTPID   | 0xEF600824 | Reset, R, T                   | 0x00008808              | R/W    | 19 |
| EMAC0_VTCI    | 0xEF600828 | Reset, R, T                   | 0x00000000              | R/W    | 19 |
| EMAC0_PTR     | 0xEF60082C | Reset, T                      | 0x0000FFFF              | R/W    | 19 |
| EMAC0_IAHT1   | 0xEF600830 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_IAHT2   | 0xEF600834 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_IAHT3   | 0xEF600838 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_IAHT4   | 0xEF60083C | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_GAHT1   | 0xEF600840 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_GAHT2   | 0xEF600844 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_GAHT3   | 0xEF600848 | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_GAHT4   | 0xEF60084C | Reset, R                      | 0x00000000              | R/W    | 19 |
| EMAC0_LSAH    | 0xEF600850 | Not applicable                | 0x00000000              | R      | 19 |
| EMAC0_LSAL    | 0xEF600854 | Not applicable                | 0x00000000              | R      | 19 |
| EMAC0_IPGVR   | 0xEF600858 | Reset, T                      | 0x00000004              | R/W    | 19 |
| EMAC0_STACR   | 0xEF60085C | See description on page 19-39 | 0x00008000              | R/W    | 19 |
| EMAC0_TRTR    | 0xEF600860 | See description on page 19-40 | 0x00000000              | R/W    | 19 |
| EMAC0_RWMR    | 0xEF600864 | Reset                         | 0x04001000              | R/W    | 19 |
| EMAC0_OCTX    | 0xEF600868 | Not applicable                | 0x00000000              | R      | 19 |
| EMAC0_OCRX    | 0xEF60086C | Not applicable                | 0x00000000              | R      | 19 |

 Table 19-5.
 EMAC Register Summary (continued)

-

# 19.7.1 Mode Register 0 (EMAC0\_MR0)

EMAC0\_MR0 defines the operating modes of the EMAC that can be changed at any time during EMAC operation.



| 0    | RXI  | Receive MAC Idle<br>0 RX MAC processing packet<br>1 RX MAC idle; RX packet processing<br>complete                               | Read-only                                                                                                                 |
|------|------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| 1    | ТХІ  | Transmit MAC Idle<br>0 TX MAC processing packet<br>1 TX MAC idle; TX packet processing<br>complete                              | Read-only                                                                                                                 |
| 2    | SRST | Soft Reset<br>0 No effect<br>1 Soft reset in progress                                                                           | If EMAC0_MR0[SRST] = 1, writing to any<br>EMAC register, and reading any other bit in<br>this register, is not supported. |
| 3    | TXE  | Transmit MAC Enable<br>0 TX MAC is disabled<br>1 TX MAC is enabled                                                              |                                                                                                                           |
| 4    | RXE  | Receive MAC Enable<br>0 RX MAC is disabled<br>1 RX MAC is enabled                                                               |                                                                                                                           |
| 5    | WKE  | Wake-Up Enable<br>0 Incoming packets are not examined for<br>wake-up packet<br>1 Examine incoming packets for wake-up<br>packet | Software can change EMAC0_MR0[WKE]<br>only while EMAC0_MR0[RXI] = 1 and<br>EMAC0_MR0[RXE] = 0.                            |
| 6:31 |      | Reserved                                                                                                                        |                                                                                                                           |

Figure 19-15. Mode Register 0 (EMAC0\_MR0)

# 19.7.2 Mode Register 1 (EMAC0\_MR1)

EMAC0\_MR1 defines the EMAC operating modes that can be changed only after a reset.

Software can use EMAC0\_MR1[FDE] and proper programming of the attached PHY to activate external loop-back mode.

When EMAC0\_MR1[FDE, ILE] = 1, EMAC wraps transmitted packets back to the receive FIFO without accessing the MII interface.





|       |      |                                                                                                                                                                            | -                                                                                                             |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 0     | FDE  | <ul> <li>Full-Duplex Enable</li> <li>0 Disable simultaneous transmit and receive</li> <li>1 Enable simultaneous transmit and receive</li> </ul>                            |                                                                                                               |
| 1     | ILE  | Internal Loop-back Enable<br>0 No wrap back<br>1 Transmitted packets wrapped back to<br>receive FIFO                                                                       | Full Duplex must also be set<br>(EMAC0_MRI[FDE]=1).                                                           |
| 2     | VLE  | VLAN Enable<br>0 Disable processing of VLAN Tags<br>1 Enable processing of VLAN Tags                                                                                       |                                                                                                               |
| 3     | EIFC | <ul> <li>Enable Integrated Flow Control</li> <li>0 Disable integrated flow control<br/>mechanism</li> <li>1 Enable integrated flow control<br/>mechanism</li> </ul>        | Refer to "Flow Control" on page 19-15 for<br>more details.<br>Set EMAC0_MR1[EIFC] = 0 in half-duplex<br>mode. |
| 4     | APP  | Allow Pause Packet<br>0 Disables processing of incoming control<br>(pause) packets<br>1 Enables processing of incoming control<br>(pause) packets                          |                                                                                                               |
| 5:6   |      | Reserved                                                                                                                                                                   | Always zero                                                                                                   |
| 7     | IST  | Ignore SQE test<br>0 Wait for end of SQE test period before<br>activation of valid signal<br>1 Do not wait for end of SQE test period<br>before activation of valid signal | EMAC0_MR1[IST] = 0 only during half-<br>duplex operation on 10 Mbps media.                                    |
| 8:9   | MF   | Medium Frequency<br>00 10 Mbps (Ethernet mode)<br>01 100 Mbps (Fast Ethernet mode)<br>10 Reserved<br>11 Reserved                                                           | Defines the possible operational frequency on the MII interface.                                              |
| 10:11 | RFS  | Receive (RX) FIFO Size<br>00 512 bytes<br>01 1 KB<br>10 2 KB<br>11 4 KB                                                                                                    |                                                                                                               |
|       |      |                                                                                                                                                                            |                                                                                                               |

| 12:13 | TFS | Transmit (TX) FIFO Size<br>00 Reserved<br>01 1 KB<br>10 2 KB<br>11 Reserved                                                                     |                                                                   |
|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| 14    |     | Reserved                                                                                                                                        | Always zero                                                       |
| 15:16 | TR0 | Transmit Request 0<br>00 Single packet<br>01 Multiple packets<br>10 Dependent mode (bits 17:18 must also<br>be programmed to 10)<br>11 Reserved | Defines the different modes for using transmit channel 0 of EMAC. |
| 17:18 | TR1 | Transmit Request 1<br>00 Single packet<br>01 Multiple packets<br>10 Dependent mode (bits 15:16 must also<br>be programmed to 10)<br>11 Reserved | Defines the different modes for using transmit channel 1 of EMAC. |
| 19:31 |     | Reserved                                                                                                                                        |                                                                   |

# 19.7.3 Transmit Mode Register 0 (EMAC0\_TMR0)

EMAC0\_TMR0 defines EMAC operating modes during transmit operations (see "EMAC Transmit Operation" on page 19-5).

EMAC0\_TMR0[GNP0, GNP1, GNPD] are self-clearing. Writing 0 to these fields has no effect.



| 0 | GNP0 | Get New Packet 0<br>0 Writing 0 has no effect.<br>1 Packet ready for transmission on TX<br>Channel 0                               | EMAC0_TMR0[GNP0] = 0 if EMAC is<br>programmed in dependent mode.                                                                                    |
|---|------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | GNP1 | Get New Packet 1<br>0 Writing 0 has no effect.<br>1 Packet ready for transmission on TX<br>Channel 1                               | EMAC0_TMR0[GNP1] = 0 if EMAC is<br>programmed in dependent mode.                                                                                    |
| 2 | GNPD | Get New Packet for Dependent Mode<br>0 Writing 0 to this bit has no effect<br>1 Packet ready for transmission in<br>dependent mode | EMAC0_TMR0[GNPD] = 0 if EMAC is not<br>programmed in dependent mode.<br>EMAC0_TMR0[GNPD] = 1 activates the<br>EMAC transmit path in dependent mode. |

| 3    | FC | First Channel<br>0 Activate TX Channel 0 first when GNPD<br>is 1<br>1 Activate TX Channel 1 first when GNPD<br>is 1 | EMAC0_TMR0[FC] is only meaningful in<br>dependent mode, after resetting<br>EMAC0_ISR[DBDM].<br>EMAC0_TMR0[FC] = 0 if EMAC is not<br>programmed in dependent mode. |
|------|----|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:31 |    | Reserved                                                                                                            | ······································                                                                                                                            |

# 19.7.4 Transmit Mode Register 1 (EMAC0\_TMR1)

EMAC0\_TMR1 defines conditions for activation of MAL service requests during transmit operations (see "EMAC Transmit Operation" on page 19-5).

### 19.7.4.1 Low-Priority Requests

EMAC requests low priority service from MAL when the number of vacant entries in the TX FIFO exceeds the decimal TLR value.

EMAC0\_TMR1[TRL] must at least equal ((MAL Burst Limit / 2)-1). For example, if MAL supports 16-word bursts, the decimal TLR value should be at least 7.

Note: In the 405GP, all MAL channels are capable of 16 word bursts.

To avoid a deadlock, the sum of EMAC0\_TMR1[TRL] and EMAC0\_TRTR[TRT] must be at least 4 smaller than the transmit FIFO size specified by EMAC0\_MR1[TFS].

#### 19.7.4.2 Urgent-Priority Requests

EMAC requests urgent priority service from MAL if the following conditions occur:

- EMAC begins transmitting the packet to the media before the entire packet is placed in the TX FIFO
- The number of vacant entries for the currently transmitting packet exceeds the decimal TUR value

Software must coordinate the value of EMAC0\_TMR1[TUR] with the value of EMAC0\_MR1[TFS]. The value of EMAC0\_TMR1[TUR] must be smaller than that of EMAC0\_MR1[TFS] so that the array address encoded in EMAC0\_TMR1[TUR] can access the full 66-bit wide array.

The binary value of EMAC0\_TMR1[TUR] must be greater than that of EMAC0\_TMR1[TLR].

The EMAC0\_TMR1 contents can be changed only when EMAC0\_TMR0[GNP0, GNP1, GNPD] = 0.



| 0:4  | TLR | Transmit Low Request    |   | · · · · · · · · · · · · · · · · · · · |
|------|-----|-------------------------|---|---------------------------------------|
| 5:7  |     | Reserved                | • |                                       |
| 8:15 | TUR | Transmit Urgent Request |   |                                       |

#### Figure 19-18. Transmit Mode Register 1 (EMAC0\_TMR1)

16:31 Reserved

# 19.7.5 Receive Mode Register (EMAC0\_RMR)

The EMAC0\_RMR defines EMAC operating modes during receive operations.



| Figure 19-19. Receive Mode Re | aister (EMAC0 RMR) |
|-------------------------------|--------------------|
|-------------------------------|--------------------|

| 0 | SP   | <ul> <li>Strip Padding</li> <li>0 Do not strip pad bytes from the received packet.</li> <li>1 Strip pad/FCS bytes from the received packet.</li> </ul>                                   |
|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | SFCS | <ul> <li>Strip FCS</li> <li>0 Do not strip FCS bytes from the received packet.</li> <li>1 Strip FCS bytes from the received packet.</li> </ul>                                           |
| 2 | RRP  | <ul> <li>Receive Runt Packets</li> <li>0 Discard packets less than 64 bytes in length.</li> <li>1 Receive packets less than 64 bytes in length.</li> </ul>                               |
| 3 | RFP  | Allow Receive Packets with a FCS Error<br>0 Discard packets containing a FCS error.<br>1 Receive packets containing a FCS error.                                                         |
| 4 | ROP  | Receive Oversize Packet<br>0 Discard packets that activate Packet Is<br>Too Long error.<br>1 Receive packets that activate Packet Is<br>Too Long error.                                  |
| 5 | RPIR | Receive Packets with In Range Error<br>0 Discard packets that activate In Range<br>Error.<br>1 Receive packets that activate In Range<br>Error.                                          |
| 6 | PPP  | <ul> <li>Propagate Pause Packet</li> <li>0 Do not propagate incoming pause packet<br/>to MAL; remove packet from FIFO.</li> <li>1 Propagate incoming pause packet to<br/>MAL.</li> </ul> |

| 7     | PME  | Promiscuous Mode Enable<br>0 Do not enable promiscuous mode.<br>1 Accept all packets.                                                                                                                                                                        |
|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8     | PMME | Promiscuous Multicast Mode Enable<br>0 Do not accept all multicast packets.<br>1 Accept all multicast packets.                                                                                                                                               |
| 9     | IAE  | <ul> <li>Individual Address Enable</li> <li>0 Do not compare address of received<br/>packets with content of individual<br/>address register.</li> <li>1 Compare address of received packets<br/>with content of individual address<br/>register.</li> </ul> |
| 10    | MIAE | Multiple Individual Address Enable<br>0 Do not compare address of received<br>packets with hash table of individual<br>addresses.<br>1 Compare address of received packets<br>with hash table of individual addresses.                                       |
| 11    | BAE  | <ul> <li>Broadcast Address Enable</li> <li>0 Do not compare address of received<br/>packets with broadcast addresses.</li> <li>1 Compare address of received packets<br/>with broadcast addresses.</li> </ul>                                                |
| 12    | MAE  | Multicast Address Enable<br>0 Do not compare address of received<br>packets with multicast addresses.<br>1 Compare address of received packets<br>with multicast addresses.                                                                                  |
| 13:31 |      | Reserved                                                                                                                                                                                                                                                     |

# 19.7.6 Interrupt Status Register (EMAC0\_ISR)

EMAC generates one distinct interrupt event indication. The event indication is driven out of the EMAC to the UIC Interrupt 15. This interrupt is generated from the content of the EMAC0\_ISR. The content of the EMAC0\_ISR is first ANDed with the corresponding mask bits in the EMAC0\_ISER; the resulting bits are then logically ORed to produce the interrupt signal. Thus, if any of the resulting bits is a 1, an interrupt is generated.

**Note:** EMAC activates its interrupt signal only after an indication that status for the current packet was accepted by MAL (with the exception of "MMA Operation Succeed/MMA Operation Failed," which causes unconditional activation of interrupt, if it is not masked).

The interrupt indication is cleared by writing 1 to the related bit in the EMAC0\_ISR; writing 0 has no effect.

The Event Indication Signal is cleared when all non-masked event indication bits are cleared.





| 0:5 |      | Reserved                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | OVR  | Overrun<br>0 No overrun error<br>1 Overrun error during reception of recent<br>packet                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7   | PP   | Pause Packet<br>0 Received packet is not a control pause<br>packet<br>1 Received packet is a control pause<br>packet            |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8   | BP   | <ul><li>Bad Packet</li><li>0 Receive operation OK</li><li>1 Early termination was initiated because of a packet error</li></ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9   | RP   | Runt Packet<br>0 No Runt packets received<br>1 Runt packet received                                                             | Set when EMAC0_RMR[RRP] = 1 and the duration of PHY_RX_DV signal was greater than ShortEventMaxTime constant and less than the collision window.                                                                                                                                                                                                                                                                                                    |
| 10  | SE   | Short Event<br>0 No short events<br>1 Duration of PHY_RX_DV signal less than<br>ShortEventMaxTime constant                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11  | ALE  | Alignment Error<br>0 No alignment error in received packet<br>1 Alignment error in received packet                              | The packet contained an odd number of nibbles (4 bits).                                                                                                                                                                                                                                                                                                                                                                                             |
| 12  | BFCS | Bad FCS<br>0 No FCS error in received packet<br>1 Packet with an FCS error received                                             | Set if EMAC0_RMR[RFP] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13  | PTLE | Packet Too Long Error<br>0 No oversized packets received<br>1 Oversized packet received                                         | <ul> <li>Set if EMAC0_RMR[ROP] = 1 and the received packet length exceeded the maximum allowed value:</li> <li>1518 octets for standard packet (checked only if the length/type field of the transmitted packet contained length value and jumbo support is disabled)</li> <li>1522 octets for VLAN tagged packet (checked only if the length/type field of the transmitted packet contained length value and jumbo support is disabled)</li> </ul> |

| 14    | ORE  | Out Of Range Error<br>0 Received packet length field value OK<br>1 Received packet length field value<br>greater than the maximum allowed LLC<br>data size                            | Indicates that received packet has a length<br>field value greater than the maximum<br>allowed Logical Link Control (LLC) data<br>size (greater than 1500 and less than<br>1536).                                                                                |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | IRE  | In Range Error<br>0 Received packet does not contain an In<br>Range Error<br>1 Received packet contains an In Range<br>Error                                                          |                                                                                                                                                                                                                                                                  |
| 16:21 |      | Reserved                                                                                                                                                                              |                                                                                                                                                                                                                                                                  |
| 22    | DBDM | Dead Bit Dependent Mode<br>0 No transmit error or SQE in dependent<br>mode<br>1 Transmit error or SQE has occurred<br>while in dependent mode                                         | If EMAC0_ISR[DBDM] = 1, EMAC does<br>not request MAL service, even if<br>EMAC0_TMR0[GNPD] = 1.<br>EMAC0_ISR[DBDM] does not affect<br>EMC_INT.                                                                                                                    |
| 23    | DB0  | Dead Bit 0<br>0 No transmit error or SQE for TX Channel<br>0 while not in dependent mode<br>1 Transmit error or SQE has occurred for<br>TX Channel 0 while not in dependent<br>mode   | If EMAC0_ISR[DB0] = 1, EMAC does not<br>request service for TX Channel 0 from<br>MAL, even if EMAC0_TMR0[GNP0] = 1.<br>EMAC0_ISR[DB0] does not affect<br>EMC_INT.                                                                                                |
| 24    | SE0  | SQE Error 0<br>0 No SQEs on TX Channel 0<br>1 SQE test failure during transmission of a<br>packet from TX Channel 0                                                                   | Applicable only in half-duplex mode during<br>10 Mbps operations; 0 in all other modes.                                                                                                                                                                          |
| 25    | TEO  | Transmit Error 0<br>0 TX Channel 0 transmission OK<br>1 TX Channel 0 transmission aborted                                                                                             | <ul> <li>EMAC aborts the transmitted packet if one of the following events takes place:</li> <li>Late collision detection</li> <li>Excessive collision detection</li> <li>Excessive deferral</li> <li>TX FIFO underrun</li> <li>Loss of carrier sense</li> </ul> |
| 26    | DB1  | Dead Bit 1<br>0 No transmit error or SQE for TX Channel<br>1 while not in dependent mode<br>1 Transmit error or a SQE has occurred for<br>TX Channel 1 while not in dependent<br>mode | If this bit is set, EMAC does not request<br>MAL service for TX Channel 1 even if<br>EMAC0_TMR1[GNP1] = 1.<br>EMAC0_ISR[DB1] does not affect<br>EMC_INT.                                                                                                         |
| 27    | SE1  | SQE Error 1<br>0 No Signal Quality Errors on TX Channel<br>1<br>1 Signal Quality Error test failure during<br>transmission of a packet from TX<br>Channel 1                           | Applicable only in half-duplex mode during 10 Mbps operations; 0 in all other modes.                                                                                                                                                                             |

.

| 28 | TE1                                                                                                             | Transmit Error 1<br>0 TX Channel 1 transmission OK<br>1 TX Channel 1 transmission aborted     | EMAC aborts the transmitted packet if one<br>of the following events takes place:<br>• Late collision detection<br>• Excessive collision detection<br>• Excessive deferral<br>• TX FIFO underrun<br>• Loss of carrier sense |
|----|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29 | a de compañía de la compañía de la compañía de la compañía de la compañía de la compañía de la compañía de la c | Reserved                                                                                      | Always 0                                                                                                                                                                                                                    |
| 30 | MOS                                                                                                             | MMA Operation Succeeded<br>0 MMA_CONTROL addressed on the OPB<br>1 PHY transfer valid         | The device driver should poll assertion of<br>EMAC0_ISR[MOS] or EMAC0_ISR[MOF]<br>before issuing a new command or before<br>using data read from the PHY.                                                                   |
| 31 | MOF                                                                                                             | MMA Operation Failed<br>0 MMA_CONTROL addressed on the OPB<br>1 PHY transfer <i>not</i> valid | The device driver should poll assertion of<br>EMAC0_ISR[MOF] or EMAC0_ISR[MOS]<br>before issuing a new command or before<br>using data read from the PHY.                                                                   |

# 19.7.7 Interrupt Status Enable Register (EMAC0\_ISER)

The EMAC0\_ISER indicates which conditions in the EMAC0\_ISR can generate an interrupt.

Each masking bit in the EMAC0\_ISER corresponds to a related bit in the EMAC0\_ISR. If a mask bit is set to 1, the corresponding status bit, when set, causes an interrupt to be generated. Setting a mask bit to 0 suppresses interrupt generation for the associated condition.

Mask bits for reserved bits in the EMAC0\_ISR are not implemented, have no effect on write, and return 0 on read.



| Figure 19-21. I | Interrupt Statu | s Register | (EMACO | _ISER) |
|-----------------|-----------------|------------|--------|--------|
|-----------------|-----------------|------------|--------|--------|

| 0:5 |     | Reserved                                                                                                                                             |
|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | OVR | Overrun<br>0 Overrun error will not generate an<br>interrupt.<br>1 Overrun error will generate an interrupt.                                         |
| 7   | PP  | Pause Packet<br>0 Received control pause packet will not<br>generate an interrupt.<br>1 Received control pause packet will<br>generate an interrupt. |

| 8     | BP . | Bad Packet<br>0 Early termination on received packet will                                                                                                                                           |   |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |      | not generate an interrupt.<br>1 Early termination on received packet will<br>generate an interrupt.                                                                                                 |   |
| 9     | RP   | <ul> <li>Runt Packet</li> <li>Received runt packet will not generate an interrupt.</li> <li>Received runt packet will generate an interrupt.</li> </ul>                                             |   |
| 10    | SE   | <ul><li>Short Event</li><li>O Short event during receive will not<br/>generate an interrupt.</li><li>1 Short event during receive will generate<br/>an interrupt.</li></ul>                         |   |
| 11    | ALE  | <ul> <li>Alignment Error</li> <li>O Alignment error in received packet will<br/>not generate an interrupt.</li> <li>1 Alignment error in received packet will<br/>generate an interrupt.</li> </ul> |   |
| 12    | BFCS | <ul> <li>Bad FCS</li> <li>0 FCS error in received packet will not<br/>generate an interrupt.</li> <li>1 FCS error in received packet will<br/>generate an interrupt.</li> </ul>                     |   |
| 13    | PTLE | <ul> <li>Packet Too Long Error</li> <li>Oversized packets received will not<br/>generate an interrupt.</li> <li>1 Oversized packet received will generate<br/>an interrupt.</li> </ul>              | • |
| 14    | ORE  | Out Of Range Error<br>0 Out of range error on received packet will<br>not generate an interrupt.<br>1 Out of range error on received packet will<br>generate an interrupt.                          |   |
| 15    | IRE  | <ul> <li>In Range Error</li> <li>0 In range error on received packet will not<br/>generate an interrupt.</li> <li>1 In range error on received packet will<br/>generate an interrupt.</li> </ul>    |   |
| 16:23 |      | Reserved                                                                                                                                                                                            |   |
| 24    | SE0  | <ul> <li>SQE Error 0</li> <li>0 SQE error on TX Channel 0 will not<br/>generate an interrupt.</li> <li>1 SQE error on TX Channel 0 will generate<br/>an interrupt.</li> </ul>                       |   |

| 25 | TEO | <ul> <li>Transmit Error 0</li> <li>0 TX error on TX Channel 0 will not<br/>generate an interrupt.</li> <li>1 TX error on TX Channel 0 will generate<br/>an interrupt.</li> </ul>                           | • |
|----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 26 |     | Reserved                                                                                                                                                                                                   |   |
| 27 | SE1 | <ul> <li>SQE Error 1</li> <li>O SQE error on TX Channel 1 will not<br/>generate an interrupt.</li> <li>1 SQE error on TX Channel 1 will generate<br/>an interrupt.</li> </ul>                              |   |
| 28 | TE1 | <ul> <li>Transmit Error 1</li> <li>TX error on TX Channel 1 will not<br/>generate an interrupt.</li> <li>TX error on TX Channel 1 will generate<br/>an interrupt.</li> </ul>                               | • |
| 29 |     | Reserved                                                                                                                                                                                                   |   |
| 30 | MOS | <ul> <li>MMA Operation Succeeded</li> <li>Successful MMA Operation with a PHY<br/>will not generate an interrupt.</li> <li>Successful MMA Operation with a PHY<br/>will generate an interrupt.</li> </ul>  |   |
| 31 | MOF | <ul> <li>MMA Operation Failed</li> <li>Unsuccessful MMA Operation with a<br/>PHY will not generate an interrupt.</li> <li>Unsuccessful MMA Operation with a<br/>PHY will generate an interrupt.</li> </ul> |   |

# 19.7.8 Individual Address High (EMAC0\_IAHR)

EMAC0\_IAHR contains the high-order halfword of the station unique individual address.

During packet reception, if EMAC is programmed in individual address match mode (EMAC0\_RMR[IAE] = 1), the contents of EMAC0\_IAHR are concatenated with the content of EMAC0\_IALR to form a composite address that is compared with the destination address of the received packet. If addresses match, the packet is transferred to MAL.

During packet transmission, EMACO\_IAHR is used in source address inclusion/replacement and as the source address field in the self-assembled control (pause) packet.

| 0 15 16 31 |
|------------|
|------------|

| Figure 19-22. | Individual | Address Hia | h Register | (EMACO | IAHR) |
|---------------|------------|-------------|------------|--------|-------|
|               |            |             |            |        |       |

| 0:15  | Reserved                                                     |                                                                                               |
|-------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| 16:31 | High-order halfword of the station unique individual address | This field contains bits 0:15 of the destination address (bit 0 is the most significant bit). |

# 19.7.9 Individual Address Low (EMAC0\_IALR)

EMAC0\_IALR contains the low-order word of the station unique individual address.

During packet reception, EMAC0\_IALR is compared with the corresponding address bits of the received packet.

During packet transmission, EMAC0\_IALR is used in source address inclusion/replacement and as the source address field in the self-assembled control (pause) packet.

| <br> | <br> | <br> |
|------|------|------|
|      |      | 311  |
|      |      |      |
|      | <br> | <br> |

#### Figure 19-23. Individual Address Low Register (EMAC0\_IALR)

|   |      | •                                    |
|---|------|--------------------------------------|
| Ì | 0:31 | Low-order bits of Receive Individual |
|   |      | Address or Transmit Source Address   |

# 19.7.10 VLAN TPID Register (EMAC0\_VTPID)

EMAC0\_VTPID contains the value of the VLAN TPID (Tag Protocol Identifier) field.

During packet reception, packet bytes 13 and 14 are compared to the content of this register to check whether the packet is tagged with a VLAN ID.

During packet transmission, EMAC uses EMAC0\_VTPID when VLAN Tag replacement or VLAN Tag inclusion mode is chosen.

The value of this register must be a Type field (8100).



#### Figure 19-24. VLAN TPID Register (EMAC0\_VTPID)

| 0:15  |      | Reserved    |  |  |   |  |  |
|-------|------|-------------|--|--|---|--|--|
| 16:31 | VIDT | VLAN ID tag |  |  | - |  |  |

### 19.7.11 VLAN TCI Register (EMAC0\_VTCI)

EMAC0\_VTCI contains the value of the VLAN TCI (Tag Control Information) field.

During packet transmission, EMAC uses EMAC0\_VTCI when VLAN Tag replacement or VLAN Tag inclusion mode is chosen.

|                                                                                                                 | VTCI |    |
|-----------------------------------------------------------------------------------------------------------------|------|----|
|                                                                                                                 | 1    |    |
| 0 mailes en elles anticipation de la companya de la companya de la companya de la companya de la companya de la |      | 31 |

#### Figure 19-25. VLAN TCI Register (EMAC0\_VTCI)

| 0:15  |      | Reserved     |
|-------|------|--------------|
| 16:31 | VTCI | VLAN TCI tag |

#### 19.7.12 Pause Timer Register (EMAC0\_PTR)

The EMAC0\_PTR defines the time period for which the pause function is enabled. EMAC uses EMAC0\_PTR[TVR] as the timer value field of control (pause) packets (see "Control Packet Transmission" on page 19-16). Each bit corresponds to 512 bit times.

|   |    | TVF |
|---|----|-----|
|   |    | Ļ   |
| 0 | 16 | 31  |

#### Figure 19-26. Pause Timer Register (EMAC0\_PTR)

| 0:15  |     | Reserved          |
|-------|-----|-------------------|
| 16:31 | TVF | Timer Value Field |

#### 19.7.13 Individual Address Hash Tables 1–4 (EMAC0\_IAHT1–EMAC0\_IAHT4)

These registers are used in the hash table function of the multiple individual addressing mode.

See "Address Match Mechanism" on page 19-20 for more information. See Figure 19-14 on page 19-23 for bit mapping information.

| 0.0000000000000000000000000000000000000 |  |       |  |  |
|-----------------------------------------|--|-------|--|--|
|                                         |  | 15/16 |  |  |
|                                         |  |       |  |  |
|                                         |  |       |  |  |
|                                         |  |       |  |  |

#### Figure 19-27. Individual Address Hash Tables 1–4 (EMAC0\_IAHT1-EMAC0\_IAHT4)

| 0:15  | Reserved                       |
|-------|--------------------------------|
| 16:31 | Individual Address Hash Number |

#### 19.7.14 Group Address Hash Tables 1–4 (EMAC0\_GAHT1–EMAC0\_GAHT4)

These registers are used in the hash table function of the group addressing mode.

See "Address Match Mechanism" on page 19-20 for more information. See Figure 19-14 on page 19-23 for bit mapping information.

#### Figure 19-28. Group Address Hash Tables 1–4 (EMAC0\_GAHT1–EMAC0\_GAHT4)

| 0:15  | Reserved                  |
|-------|---------------------------|
| 16:31 | Group Address Hash Number |

### 19.7.15 Last Source Address High (EMAC0\_LSAH)

EMAC0\_LSAH contains the high-order halfword of the source address of the last "good" received packet. The packet is considered to be "good" if EMAC is programmed to provide this packet to MAL.

| 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      | 041      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 110  | 311      |
| O and state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the | 2 10 | <u> </u> |

### Figure 19-29. Last Source Address High Register (EMAC0\_LSAH)

| 0:15  | Reserved                                |
|-------|-----------------------------------------|
| 16:31 | Last Source Address High-Order Halfword |

### 19.7.16 Last Source Address Low (EMAC0\_LSAL)

EMAC0\_LSAL contains the low-order word of the source address of the last "good" received packet. The packet is considered "good" if EMAC is programmed to provide this packet to MAL.

#### Figure 19-30. Last Source Address Low Register (EMAC0\_LSAL)

| • | 0:31 | Last | Source | Addre | ess Lov | w-Order Wor | d | <br>_ |  |  |  |
|---|------|------|--------|-------|---------|-------------|---|-------|--|--|--|
|   |      |      |        |       |         |             |   |       |  |  |  |

### 19.7.17 Inter-Packet Gap Value Register (EMAC0\_IPGVR)

EMAC0\_IPGVR contains the value of one-third of the inter-packet gap (IPG) for the next packet to be transmitted. ("Frame" is synonymous with "packet.")

The resolution of each bit is 8-bit times. The minimum value in the register is four, causing a minimum IPG period of 96-bit times).

| 0 | 25 26 | 31 |
|---|-------|----|
|   |       |    |

Figure 19-31. inter-Packet Gap Value Register (EMAC0\_IPGVR)

| 0:25  | Reserved         |
|-------|------------------|
| 26:31 | Inter-Packet Gap |

### 19.7.18 STA Control Register (EMAC0\_STACR)

The EMAC0\_STACR controls the MII Management interface. The software must follow the following steps during access to the EMAC0\_STACR:

1. Software polls EMAC0\_STACR[OC], waiting for it to be set by EMAC.

EMAC sets EMAC0\_STACR[OC] = 0 when the EMAC0\_STACR is written to.

EMAC then sets EMAC0\_STACR[OC] = 1 to indicate that the data has been written to the PHY, or the data read from the PHY is valid. The device driver should poll for EMAC0\_STACR[OC] = 1 before issuing a new command, or before using data read from the PHY.

- 2. The software can perform read/write access to the EMAC0\_STACR.
- EMAC clears EMAC0\_STACR[OC] (sets EMAC0\_STACR[OC] = 0) and starts activity on the MII management interface.
- 4. Return to step 1.



|       |      |                                                                                     | · · ·                                                                                                              |
|-------|------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| 0:15  | PHYD | PHY data                                                                            | Data to be sent to the PHY if the command<br>is a write, or data is read from the PHY if<br>the command is a read. |
| 16    | OC   | Operation Complete<br>0 EMAC0_STACR is addressed<br>1 PHY data transfer complete    |                                                                                                                    |
| 17    | PHYE | PHY Error<br>0 Successful read transaction<br>1 Read transaction was not successful | EMAC0_STACR[PHYE] = 0 when a read is successful.                                                                   |
| 18:19 | STAC | STA Command<br>00 Reserved<br>01 Read<br>10 Write<br>11 Reserved                    | EMAC sets EMAC0_STACR[STAC] = 0 when the command is completed.                                                     |

#### Figure 19-32. STA Control Register (EMAC0\_STACR)

| 20:21 | OPBC | OPB Bus Clock Frequency<br>00 50 MHz<br>01 66 MHz<br>10 83 MHz<br>11 100 MHz | EMAC0_STACR[OPBC] is used to<br>generate the Management Data Clock<br>(EMCMDCIk.<br>When the operational frequency differs<br>from those in the list, then the next greater<br>frequency should be chosen. |
|-------|------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:26 | PCDA | PHY Command Destination Address                                              |                                                                                                                                                                                                            |
| 27:31 | PRA  | PHY Register Address                                                         |                                                                                                                                                                                                            |

# 19.7.19 Transmit Request Threshold Register (EMAC0\_TRTR)

The EMAC0\_TRTR defines the conditions that cause EMAC to initiate transmission to the Ethernet MAC sub-block, and for requesting service from MAL.

EMAC0\_TRTR[TRT] defines the number of occupied entries in the Transmit FIFO that should be written before the Transmit FIFO control logic initiates a transmit request to the Ethernet MAC subblock.

If an entire packet is already located in the Transmit FIFO, then EMAC initiates a transmit regardless of the programmed value.

The software must coordinate the value of EMAC0\_TRTR[TRT] with the Transmit FIFO size specified in EMAC0\_MR1[TFS].

To avoid deadlock, the sum of the Transmit Low Request (Figure 19-18 on page 19-28, bits 0:4) and EMAC0\_TRTR[TRT] must be smaller, by at least four, than the chosen size of the Transmit FIFO specified in EMAC0\_MR1[TFS].

To avoid an underrun, program this threshold to a high enough value.

In half-duplex mode, in case of collision, to allow packet re-transmission without involving MAL, EMAC preserves the necessary space in the Transmit FIFO unless it gets an indication that the collision window has elapsed.

The EMAC0\_TRTR may only be written to while EMAC0\_MR0[TXI] = 1.





| 0:4  | TRT | Transmit Request Threshold                                                  |
|------|-----|-----------------------------------------------------------------------------|
|      |     | The following number of bytes must be<br>placed in the Transmit FIFO before |
|      |     | initiating a transmit request.                                              |
|      |     | 00000 64 bytes                                                              |
|      |     | 00001 128 bytes                                                             |
| 1    |     | 00010 192 bytes                                                             |
|      |     | 00011 256 bytes                                                             |
|      |     | •                                                                           |
|      |     |                                                                             |
|      |     |                                                                             |
|      |     | 11111 2048 bytes                                                            |
| 5:31 |     | Reserved                                                                    |

### 19.7.20 Receive Low/High Water Mark Register (EMAC0\_RWMR)

The EMAC0\_RWMR defines the conditions that cause EMAC to activate a low or urgent priority MAL request, and that manage flow control.

EMAC activates a low priority request if the number of occupied entries in the Receive FIFO is greater than or equal to the content of EMAC0\_RWMR[RLWM] (the receive low water mark is reached). A request for a pause packet with a pause\_value of 0 is also issued when the receive low water mark is reached.

Software must coordinate the value of EMAC0\_RWMR[RLWM] with the value of EMAC0\_MR1[RFS]. EMAC0\_RWMR[RLWM] should be smaller than EMAC0\_MR1[RFS] and larger than the MAL burst length.

Note: In the 405GP, the MAL burst length is 16 words for all channels.

If the entire packet is already in the Receive FIFO, EMAC initiates a low priority request regardless of the programmed value.

EMAC activates an urgent priority request if the number of occupied entries in the Receive FIFO is greater than or equal to EMAC0\_RWMR[RHWM] (the receive high water mark is reached). A request for a pause packet is also issued when the receive high water mark is reached.

Software must coordinate the value of EMAC0\_RWMR[RHWM] with the value of EMAC0\_MR1[RFS]. EMAC0\_RWMR[RHWM] should be greater than the value of EMAC0\_RWMR[RLWM] and less then the size of the Receive FIFO.

19-41

|   | RLWM |           | RHWM                                  |       |
|---|------|-----------|---------------------------------------|-------|
|   | Ļ    |           | l l l l l l l l l l l l l l l l l l l |       |
| 0 |      | 8 9 15 16 | 24                                    | 25 31 |

Figure 19-34. Receive Low/High Water Mark Register (EMAC0\_RWMR)

| 0:8   | RLWM | Receive Low Water Mark  |
|-------|------|-------------------------|
| 9:15  |      | Reserved                |
| 16:24 | RHWM | Receive High Water Mark |
| 25:31 |      | Reserved                |

# 19.7.21 Number of Octets Transmitted (EMAC0\_OCTX)

| Figure 19-35. Nu | umber of Octets Transmitte | (EMACO OCTX) |
|------------------|----------------------------|--------------|
|------------------|----------------------------|--------------|

| 0:31 | остх | Number of octets (bytes) transmitted. | This field is Read-Only. |  |
|------|------|---------------------------------------|--------------------------|--|
|      |      |                                       |                          |  |

# 19.7.22 Number of Octets Received (EMAC0\_OCRX)

#### Figure 19-36. Number of Octets Received (EMAC0\_OCRX)

| 0:31 | OCRX | Number of octets (bytes) received. | This field is Read-Only. |  |
|------|------|------------------------------------|--------------------------|--|
|      |      |                                    |                          |  |

# 19.8 MII Interface

EMAC implements all MII interface functionality in accordance with Clause 22 in the IEEE Std. 802.3u.

The MII interface is a Reconciliation Sublayer interface which allows a variety of PHYs to be attached to the EMAC Ethernet MAC without future upgrade problems.

# 19.8.1 MII Station Management Interface

The EMAC MII station management unit (STA) implements a specific protocol and a special packet format to exchange management packets with the registers of the attached PHY device. EMAC

automatically generates MII management packets, which conform to Clause 22 in IEEE Std. 802.3u. EMAC uses the EMAC0\_STACR for generation of the management packet.



Figure 19-37. Management Interface with PHY

#### 19.8.2 EMAC – MII Interface

See PPC405GP Data Sheet for information.

### **19.9 MAL – EMAC Packet Transfer Flow**

The packet transfer flow consists of three phases. These three phases are used to define the details of the EMAC-MAL protocol.

- Packet phase EMAC initiates a packet transfer operation. The packet transfer is started by a command write. During command write MAL provides control information for EMAC on a perpacket basis. Following the command write, MAL begins the data transfer, during which MAL transfers data between the buffers located in the system's memory and EMAC. In transmit, the data is transferred from the system's memory to EMAC, while in receive, the data is transferred from EMAC to the system's memory buffers.
  - EMAC remains in the packet phase until the data transfer has been completed or a ready status can be returned to MAL. The packet phase ends when EMAC deasserts the FRAME signal associated with the related channel (receive/transmit).
  - The packet phase is defined by activity of an appropriate FRAME signal.
- Status phase This is the second phase of the packet transfer. Following the de-assertion of the FRAME signal, EMAC switches to the status phase. At this stage, EMAC uses an appropriate signal as a request for service which is interpreted by MAL as a request for status read.
- 3. Idle phase EMAC moves into the idle phase following a reset or after status was transferred (end of status phase). During the idle phase, EMAC cannot send any signals to MAL, nor can MAL send any active signals to EMAC. EMAC exits the idle phase by asserting the FRAME signal (and entering the packet phase described above). Idle phase can be skipped when EMAC operates in multiple transfer mode.

Figure 19-38 illustrates the different phases in the EMAC-MAL communication.



Figure 19-38. EMAC-MAL Communication Phases

During the packet and status phases EMAC signals a request for service by driving its arbitration level signal to a non-idle level.

# **19.10 Programming Notes**

Certain combinations in device drivers are not allowed when writing to EMAC registers. When creating device drivers, ensure that the following guidelines are used:

- In dependent mode, EMAC0\_MR1[TR0] must be equal EMAC0\_MR1[TR1]
- When internal loopback is enabled (EMAC0\_MR1[ILE] = 1), EMAC must be configured in fullduplex mode (EMAC0\_MR1[FDE] =1)
- EMAC0\_MR1[IST] =0 only when EMAC0\_MR1[MF] = 10 and EMAC0\_MR1[FDE] =0
- In dependent mode, EMAC0\_ISER<sub>24,25</sub> must equal EMAC0\_ISER<sub>27,28</sub>
- EMAC0\_MR1[EIFC] =0 if EMAC0\_MR1[FDE] =0
- EMAC0\_TMR1[TLR] must be greater than the MAL burst size in entities (6 for MAL)
- EMAC0\_TMR1[TUR] must be greater or equal to EMAC0\_TMR1[TLR] and less than the Transmit FIFO size in entries (EMAC0\_MR1[TFS])
- To avoid deadlock, the sum of EMAC0\_TMR1[TLR] and the EMAC0\_TRTR[TRT] must be at least four less than the Transmit FIFO size specified in EMAC0\_MR1[TFS]
- EMAC0\_RWMR[RLWM] must be greater than the MAL burst size in entities (six for MAL)
- EMAC0\_RWMR[RHWM] must be greater than EMAC0\_RWMR[RLWM]
- EMAC0\_RWMR[RHWM] must be less than the Receive FIFO size in entities (EMAC0\_MR1[RFS])

### **19.10.1 Power-Up and Initialization**

### 19.10.1.1 Reset Options

The EMAC must be reset before performing configuration changes. The following types of reset operations can be applied to EMAC.

- Hard Reset. When RESET input is asserted, EMAC aborts all on-going activities unconditionally, initializes all internal state machines, counters, registers, and flushes transmit and receive FIFOs. To be recognized, the reset signal must be asserted for at least two cycles of the slowest clock domain inside EMAC (indicating that the hard reset must be at least 800 ns).
- Soft Reset. Software first should reset the appropriate MAL channels and then begin a soft reset by setting EMAC0\_MR0[SRST] = 1. In response to the soft reset, EMAC aborts all on-going activities unconditionally, initializes all internal state machines, counters, registers, and flushes transmit and receive FIFOs. After EMAC finishes all activities related to the soft reset processing, EMAC0\_MR0[SRST] = 0.
- Smart Reset. The software initializes smart reset mode by writing 0 to EMAC0\_MR0[TXE] or EMAC0\_MR0[RXE], or to both. In this case, the Ethernet MAC sub-block completes on-going activity (receive, transmit, or both) and then goes to the related Idle state (indicated by setting either EMAC0\_MR0[TXI] = 1 or EMAC0\_MR0[RXI] = 1, or both). In this case, the control logic subblock of EMAC is still accessible for OPB and MAL transactions.

Before performing the necessary configuration changes in EMAC, the software must follow one of the following scenarios. Then the EMAC can be properly configured.

### 19.10.1.2 Scenario 1

- Hard/soft reset was activated.
- During hard/soft reset, EMAC0\_MR0[TXE] and EMAC0\_MR0[RXE] are reset.
- Software detects that the EMAC0\_MR0[SRST] is reset (after soft reset only).
- Software keeps EMAC0\_TMR0[GNP0, GNP1] = 0.
- The software can change one or more fields in registers marked with a Reset write access mode in Table 19-5, "EMAC Register Summary," on page 19-23 (actually, all EMAC registers are accessible in this scenario).
- The software initializes EMAC0\_TMR0[GNP0, GNP1] as appropriate.
- The software configures EMAC0\_MR0[TXE, RXE].

### 19.10.1.3 Scenario 2

- Software sets EMAC0\_MR0[TXE] = 0.
- The TXMAC component of the Ethernet MAC sub-block completes on-going activity and then sets EMAC0\_MR0[TXI] = 1 to enter the related Idle state.
- Software detects EMAC0\_MR0[TXI] = 1.
- Software performs the necessary EMAC configuration, keeping EMAC0\_MR0[TXE] = 0. The software can access only part of the EMAC registers marked with write access mode T in Table 19-5, "EMAC Register Summary," on page 19-23.
- After all configuration is done, software can set EMAC0\_MR0[TXE] = 1.
- Note: When Scenario 2 occurs, EMAC can still receive packets if EMAC0\_MR0[RXE] = 1. Scenarios 2 and 3 can occur simultaneously.

### 19.10.1.4 Scenario 3

t

- Software sets EMAC0\_MR0[RXE] = 0.
- The RXMAC component of the Ethernet MAC sub-block completes on-going activity and then sets EMAC0\_MR0[RXI] = 1 to enter the related Idle state.
- Software detects EMAC0\_MR0[RXI] = 1.
- Software performs the necessary EMAC configuration, keeping EMAC0\_MR0[RXE] = 0. The software can access only part of EMAC registers marked with write access mode R in Table 19-5, "EMAC Register Summary," on page 19-23.
- After all configuration is done, software can set EMAC0\_MR0[RXE] = 1.
- Note: When Scenario 3 occurs, EMAC can still transmit packets if EMAC0\_MR0[TXE] = 1. Scenarios 2 and 3 can occur simultaneously.

# **Chapter 20. Memory Access Layer**

The Memory Access Layer (MAL) is a hardware core that manages data transfers between packetoriented communications cores, also known as COMMACs (communications media access controllers), and memory. In the PPC405GP, MAL manages the transfer of packets between the Ethernet Media Access Controller (EMAC) and memory attached to the PPC405GP (SDRAM or SRAM). The primary function of MAL is to move packets directly between memory and a COMMAC core to minimize involvement of the processor core.

MAL is comprised of multiple transmit (TX) and receive (RX) channels, each of which is dedicated to a specific COMMAC in the chip. In the PPC405GP, the EMAC utilizes MAL TX channels 0 and 1, and MAL RX channel 0.

To communicate with software device drivers, MAL utilizes a buffer descriptor ring structure in memory. A software device driver uses the buffer descriptor structure to inform MAL about buffer locations and packet or buffer status. MAL uses the buffer descriptors to convey packet transfer status from the COMMAC core back to the software device driver. Each MAL channel requires its own buffer descriptor table ring structure in memory.

MAL provides software device drivers a generic interface for control of:

- Configuration sequence
- Activation commands
- Deactivation commands
- Memory status handling

# 20.1 MAL Features

- · No restrictions on buffer alignment
- · Aligned bus accesses to enable burst operation with external memories
- · Configurable receive buffer size (configurable per channel)
- · No minimum transmit buffer size
- Maximum buffer sizes of 4095 bytes (TX) and 4080 bytes (RX)
- Up to 256 descriptors in the buffer descriptor table per channel
- · Configures COMMAC according to commands specified in the descriptor status/control field
- Updates the descriptor status/control field at the end of packet transfer according to the status received from COMMAC
- Buffer-based interrupt capabilities for each channel
- Concurrent operation of RX and TX channels
- Configuration using Device Control Registers (DCRs)
- Programmable PLB arbitration priority
- PLB/OPB error detection

Figure 20-1 illustrates a general system structure overview of an embedded PowerPC processor core integrated with a packet oriented communication core. For the PPC405GP, the sole COMMAC is EMAC.



Figure 20-1. General PPC405GP Structure (Overview)

COMMACs are configured and controlled by the processor core using the OPB without MAL intervention. Packet data to be transmitted and received are stored in buffers in external memory. The MAL processes buffer descriptors and provides all data access facilities to the COMMACs.

The MAL is not aware of COMMACs such as EMAC as an entity. It is only aware of the COMMAC's channels. In the PPC405GP, EMAC contains two TX channels and one RX channel. Transmit and receive operations can be performed simultaneously by MAL (full duplex). When a channel wins arbitration, MAL transfers data between system memory and the COMMAC. MAL and the software driver maintain separate, dedicated buffer descriptor tables for each channel to maintain channel, packet, and buffer status. Packets can be constructed from one data buffer, or several data buffers (known as buffer chaining).

# 20.1.1 MAL – Internal Structure

Figure 20-2 illustrates the MAL internal structure.



Figure 20-2. MAL Internal Structure

### 20.1.1.1 PLB Master

The PLB Master performs PLB transactions for MAL, and is used to transfer data between a COMMAC and memory, fetch buffer descriptors, and communicate status regarding data transfer.

#### 20.1.1.2 OPB Master

The OPB Master performs OPB transactions for MAL, and is used to transfer data between a COMMAC and memory.

#### 20.1.1.3 TX Channel Handler

The TX channel handler is a dedicated section for each TX channel. It keeps a record of the descriptor information and the current state of each channel.

#### 20.1.1.4 RX Channel Handler

The RX channel handler is a dedicated section for each RX channel. It keeps a record of the descriptor information and the current state of each channel.

### 20.1.1.5 TX Channel Arbiter

The TX channel arbiter, connected to request lines from each TX channel, arbitrates between the TX channels and decides which channel gains access to the TX common channel logic.

#### 20.1.1.6 RX Channel Arbiter

The RX channel arbiter, connected to request lines from each RX channel, arbitrates between the RX channels and decides which channel gains access to the RX common channel logic.

#### 20.1.1.7 TX Common Channel Logic

The TX common channel logic is shared by all TX channels. It services a single TX channel at a time (selected by the TX arbiter). This logic activates the PLB and OPB masters for data and buffer descriptor transactions.

#### 20.1.1.8 RX Common Channel Logic

The RX common channel logic is shared by all RX channels. It services a single RX channel at a time (selected by the RX arbiter). This logic activates the PLB and OPB masters for data and buffer descriptor transactions.

#### 20.1.1.9 Register Map File

The register map file is used to configure MAL and read its status registers. Software accesses the MAL register file using the **mtdcr** and **mfdcr** instructions.

# 20.2 Transmit and Receive Operations

The device driver is responsible for configuring MAL before a COMMAC can begin requesting MAL to process packets of data. The device driver should ensure that channels are not enabled during reconfiguration; otherwise, fatal errors may occur.

For more information about the MAL software interface, see "MAL Programming Notes" on page 20-18.

Figure 20-3 describes the software and hardware operations involved in a typical transmit operation.



The numbered steps are described as follows:

- 1. The protocol stack (high-level software layer) initiates a packet transmit.
- 2. Software device driver parses the protocol stack buffer into descriptor table entries and buffers.
- 3. Software device driver instructs the COMMAC to process a new transmit packet.
- 4. The COMMAC channel requests MAL to process a new packet.
- 5. MAL fetches descriptor information.
- 6. MAL writes control information into the COMMAC and initiates the data move.
- 7. Packet data is transferred from memory into the COMMAC (the COMMAC controls the pace of the data transfer).
- 8. The packet is transmitted on the media (steps 7 and 8 can overlap).
- 9. The COMMAC requests that MAL read the packet status.
- 10. The status read by MAL is written back into a buffer descriptor.
- 11. Software is interrupted (if interrupt conditions are met) by the COMMAC or by the MAL end-of-buffer interrupt.
- 12. Software clears the interrupt status bits in the COMMAC and in MAL.
- 13. Software informs the protocol stack that transmission is complete.

#### Figure 20-3. Transmit Operation

Ś

Figure 20-4 describes the software and hardware operations when receiving a typical packet.



The numbered steps are described as follows:

- 1. Software device driver initializes the receive buffer descriptors.
- 2. Software device driver enables the COMMAC to process a new packet.
- 3. A packet is received from the network (steps 2 and 3 can change in order).
- 4. The COMMAC channel requests that MAL process a new packet.
- 5. MAL fetches receive buffer information from the descriptor table.
- 6. MAL writes the control word from the descriptor to the COMMAC and initiates the data transfer.
- 7. The COMMAC channel fills its FIFO storage.
- 8. MAL stores the packet in system memory buffers pointed to by the descriptors.
- 9. MAL reads status information from the COMMAC and writes it to the buffer descriptors.
- 10. Software device driver is interrupted (if interrupt conditions are met) by the COMMAC or by the MAL end-of-buffer interrupt.
- 11. The receive packet is passed to the protocol stack.
- 12. Software clears the receive buffer descriptor positions allowing them to be used again.

#### Figure 20-4. Receive Operation

**Note:** The description in Figure 20-4 is the general scheme for MAL operation in the software environment. The device driver should follow recommendations from "MAL Programming Notes" on page 20-18.

# 20.3 Buffer Descriptor Overview

The software interface for buffer descriptor (BD) processing consists of a set of registers within MAL and a set of circular queues in memory. Each transmit and receive COMMAC channel has a descriptor table that contains buffer location and status information allocated to the channel.

**Note:** Since MAL uses a flat addressing scheme on the PLB, the physical memory that holds descriptor tables and buffers can be allocated anywhere in the address space where memory is possible. Also, it is not necessary to place buffer descriptor tables and buffers in the same physical memory.

During its operation, MAL is able to modify the contents of memory directly without processor core knowledge. If the processor core does not provide hardware enforced data cache coherency or data cache snooping (the PPC405 CPU core does not), data cache coherency is the responsibility of the software device driver. To simplify device driver software, the MAL buffer descriptor tables should be placed in non-cached memory when possible. If this is not possible, the software driver must maintain cache coherency of the buffer descriptor tables by performing data cache flushes or invalidates when appropriate. When descriptors are in cached memory, the driver software must be aware that multiple descriptors are present in a single cache line and that cache invalidate or flush operations will be performed on multiple descriptor from the data cache to physical memory could corrupt another descriptor that occupies the same data cache line and is simultaneously being updated in physical memory by MAL.

Data buffers, in contrast, should be placed in cachable memory if possible. The software driver can easily maintain cache coherency of data buffers if:

- All buffers are aligned on a data cache line boundary
- All buffers are a multiple of a data cache line in size

Note: The data cache line size and alignment in the PPC405GP is 32 bytes.

Before using a received packet, the software driver must invalidate the memory occupied by the buffer in the data cache for the length specified in the RX buffer descriptor data length field. Before transmitting a packet the software driver must flush the data buffer from the data cache before setting the Ready bit in the TX buffer descriptor.

The software device driver fills the buffers pointed to by transmit buffer descriptors with packets to be transmitted, and/or provides empty buffers pointed to by receive buffer descriptors to be filled with received packets. Meanwhile, the hardware processes the descriptors, transfers the packet data to/from the COMMAC, and updates the status fields of the descriptors.

Each individual transmit or receive channel has its own buffer descriptor table. They are managed independently of each other. This section describes the individual transmit and receive interfaces.

Packet data associated with each transmit or receive channel is stored in buffers. Each buffer has an entry dedicated to it in one of the channel's buffer descriptor tables. MAL has a Channel Table Pointer Register for each of its channels. The COMMAC (EMAC in the PPC405GP) device driver sets the contents of these registers to point to the starting address of the buffer descriptor table for the associated channel.

Note: Buffer descriptor tables must start on a 4-KB boundary.

The buffer descriptor table forms a circular queue with a programmable length. The last descriptor in the table is defined by setting the Wrap bit in the status/control field (see "Status/Control Field Format" on page 20-14). If there is no Wrap bit set in the table, then MAL automatically wraps after processing 256 descriptors (the maximum number of descriptors allow per channel).

The format of the buffer descriptor (see Figure 20-5) is the same for all COMMACs, and has the same structure for both transmit and receive. The most significant halfword in each buffer descriptor contains a status/control halfword. This field contains two parts: the first part (6 bits) is BD handling information used by the MAL for descriptor processing, the second field (10 bits) is content specific for each COMMAC. The second halfword determines the data length referenced in this buffer descriptor. The second word in the buffer descriptor contains a 32 bit data buffer pointer that points to the actual data buffer in memory. It is suggested that each data buffer start on a cache line boundary and be a multiple of a cache line in size if it resides in cachable memory. (The cache line size in the PPC405 processor core is 32 bytes.)



#### Figure 20-5. Buffer Descriptor Structure

A packet may reside in as many buffers as necessary (transmit or receive). Each buffer has a maximum length of (4KB - 16) bytes. In TX channels, the buffer descriptor length field is written by the device driver and defines the number of bytes in the data buffer that is identified by the data buffer pointer. In RX channels, the buffer descriptor length field is written by MAL and defines the number of bytes written by MAL to the buffer that is identified by the data buffer pointer (see "Receive Software Interface" on page 20-12).

When processing a packet, MAL does not assume that all buffers of the current packet are already valid. It expects the buffers to be ready in due time to be transmitted or received. Failure of the software to provide the descriptors in due time may result in an error.

Figure 20-6 describes the structure of the packet in memory.



\* W=1 means the wrap bit is set for this descriptor

Figure 20-6. Packet Memory Structure

# 20.4 Transmit Software Interface

Once a channel is enabled in MAL (this is done by setting the appropriate bit in the Channel Active Register), a channel may request service from MAL. When the first transmit request comes in from a COMMAC TX channel, MAL finds the starting address of the buffer descriptor table for the channel by looking in the corresponding Transmit Channel Table Pointer Register. If the first descriptor is marked as ready, MAL will start processing the associated buffer.

When MAL begins processing a packet, it writes the contents of the descriptor status/control field into the COMMAC. This information, (depending on communication core implementation), may be used by the communication core to configure each packet transfer.

Once all data from the current buffer has been transferred to the communication core on the channel, MAL moves on to the next buffer descriptor in the table.

If a given buffer descriptor indicates that it contains the last section of the current packet, MAL informs the channel that the last data transferred to the channel completed the transfer of a data packet. At this point, the COMMAC asks MAL to read the packet status. MAL then writes this information back into the status/control field of the last buffer descriptor of the packet.

The COMMAC channel may request that MAL process the next buffer descriptor and the same packet handling process will be initiated. The first descriptor in the next packet follows the descriptor marked "last" in the previous packet.

# 20.4.1 Wrapping the BD Table for Transmit

When MAL processes a buffer descriptor (while handling a packet for a COMMAC channel), it may encounter a Wrap indication within a buffer descriptor control field. This causes MAL to go back to the beginning of the buffer descriptor table for the next descriptor table entry. (This will also happen when MAL reaches the maximum number of descriptors.) The wrapping of the BD table, like all other BD table handling processes, is transparent to the COMMAC.

# 20.4.2 Continuous Mode for Transmit

After transmitting the data pointed to by a buffer descriptor, MAL clears the Ready bit in the buffer descriptor control/status field. In this way, MAL will not process the same buffer descriptor again until software has filled the buffer with valid data and set the Ready bit in the descriptor again. While the Continuous Mode (CM) bit is set in the status/control field, MAL will not clear the Ready bit. The Continuous Mode allows re-transmission of the current data buffer without software intervention. This mode is generally used by protocols in which frequent re-transmission is an integral part of the protocol itself. In such cases, re-transmission can be performed without software intervention.

# 20.4.3 Back Up a Packet for Transmit

MAL is capable of re-transmitting the last packet ("back up a packet") following a request from a COMMAC. If re-transmission is requested by the COMMAC, it must be assured that all the buffers of the re-transmitted packet are available and were not re-processed by the device driver. In regular operation, MAL resets the Ready bit of each buffer descriptor when finished processing the descriptor. When MAL is requested by the COMMAC to retransmit the last packet (the Back Up a Packet bit in the COMMAC TX channel Status Halfword is set), MAL doesn't reset the READY bit in the last processed buffer descriptor, activate the end of packet interrupt, or write the status back to the descriptor in the memory. MAL also doesn't consider this as an end of packet event.

On the next service request from the same channel, MAL will start transmitting the packet again, starting from the first descriptor.

**Note:** The last processed buffer descriptor can be either the last descriptor of the packet or, in case of early packet termination, the buffer descriptor that was being processed when the transmit channel initiated the early packet termination. MAL will retransmit the backed-up packet regardless of the Ready bit value.

During retransmission of a backed-up packet, MAL may use descriptors on which the Ready bit was already cleared. Therefore, the device driver should not reuse descriptors before the Ready bit of the last descriptor is cleared.

**Note:** In the case of descriptor not valid, which is the first one in TX channel, COMMAC is not allowed to return a status that contains a Back-Up a Packet request.

# 20.4.4 Descriptor Not Valid for Transmit

When MAL accesses a buffer descriptor, it checks whether or not the Ready bit is set. If the Ready bit is not set, two cases apply (special treatment of the READY bit is performed in the case of Back-up a packet):

For the case when the READY bit is not set:

- If the descriptor is the first descriptor of the packet MAL informs the channel that data is currently
  unavailable. Further handling of this scenario is COMMAC-specific. The channel might either
  instruct MAL to access the same buffer descriptor periodically (by keeping its service request to
  MAL active) until it becomes ready, or 'give up' on the descriptor, completing the end-of-packet
  protocol with MAL. The channel might also indicate the buffer descriptor status to the device driver
  via an interrupt. However, in this case the COMMAC should eventually complete the packet transfer
  protocol with MAL. Following a descriptor not valid indication, MAL's BD pointer continues pointing
  to the same location in the BD table. The next time a descriptor read is initiated by the COMMAC,
  MAL will search for the buffer in the same location.
- If the descriptor is not the first descriptor of the packet, it is considered a descriptor error. MAL deactivates the channel and from its point of view, the processing of the current packet has ended. Software may learn about this situation from one of two MAL interrupts (or from both). The first one is a nonmaskable interrupt that indicates the number of the TX channel, in which the descriptor error had occurred (interrupt bit for each TX channel, see "MAL Interrupt Enable Register (MAL0\_IER)" on page 20-31). The second one is a maskable interrupt which indicates a descriptor error event, regardless the channel number (one interrupt bit for all the channels, see "MAL Error Status Register (MAL0\_ESR)" on page 20-29). For more information about error handling, see "Error Handling" on page 20-19.

For the case of a back-up packet:

 When the current transmitted packet is a backed-up packet, all descriptors except the last, are valid even if the READY bit is not set. In this case, (not the last descriptor) MAL processes the packet descriptors regardless the READY bit value. If the READY bit of the last descriptor in the backed-up packet is not set, MAL treats it as a descriptor error. MAL handles the descriptor error as described above for the case when the packet isn't a backed-up packet.

### 20.4.5 Scroll Descriptors for Transmit

MAL may be configured by software, in the case of early packet termination, to scroll in the buffer descriptor table to the first descriptor of the next packet.

When a multiple-buffer packet is terminated early by the COMMAC, while MAL is processing a buffer which is not the last buffer in the packet, MAL can operate in one of the following ways:

The MAL Scroll Descriptor in the configuration register is set:

 In this case MAL will read the status word from the COMMAC channel. Then MAL will reset the READY bit in all the remaining buffer descriptors of the current packet. In addition, MAL will write the status to all the buffer descriptors. On the next service of this channel, MAL will fetch the first descriptor of the next packet. The MAL Scroll Descriptor in the configuration register is clear:

In this case MAL will read the Status word from the COMMAC channel. Then MAL will terminate
the current channel service by resetting the READY bit of the last processed buffer descriptor (the
one in which there was an early termination) and will write the status only to this descriptor. On the
next service of this channel, MAL will fetch the next descriptor in the current packet. In this case,
the software is responsible to monitor the MAL location in the buffer descriptor table.

In the case that the COMMAC requests a re-transmit of the early terminated packet (when the "backup" bit in the COMMAC status is set), MAL will re-transmit the packet regardless of the MAL Scroll Descriptor bit.

# 20.5 Receive Software Interface

MAL uses the RX channel buffer descriptors in a manner similar to that used for transmission. Once an RX COMMAC channel requests that a new packet be processed, MAL starts processing the channel's next buffer descriptor in the table. Once a channel is enabled in MAL, the channel may request MAL service. When it does, MAL accesses the first buffer descriptor (in that channel's buffer descriptor table) that is pointed to by the COMMAC channel table pointer register. If that descriptor is ready (empty for RX), MAL will start processing the buffer.

When it begins processing each packet, MAL writes the contents of the status/control field into the COMMAC. This information (defined by COMMAC's implementation) can be used by the COMMAC for a per-packet configuration.

Once data is received from the memory, MAL moves the data from the RX channel FIFO into the data buffer pointed to by the first buffer descriptor. The current buffer descriptor may be closed for two reasons: there is no more room left in the buffer, or the COMMAC channel indicated that the packet reception ended. If additional buffering space is needed for the current packet, MAL moves on to the next buffer descriptor. As each buffer descriptor is closed, MAL updates the length field with the actual amount of bytes written into the buffer. The maximal length of the buffers for each channel is defined by a configuration register. The maximal receive buffer length is defined per channel.

Once the COMMAC channel indicates that the packet reception has ended, it is expected to request that MAL update the received packet status in the BD status/control field. MAL updates the packet status and notifies the COMMAC. At this point the packet is considered received and the COMMAC may request that MAL begin the process of receiving a new packet. The first buffer of the next packet is the buffer in the BD table that followed the last descriptor of the previous packet.

# 20.5.1 Wrapping the BD Table for Receive

When MAL processes the buffer descriptor, it may encounter a Wrap indication within a buffer descriptor control field. This causes MAL to go back to the head of the channel's buffer descriptor for the next buffer descriptor. This also happens when MAL reaches the maximal number of descriptors.

# 20.5.2 Continuous Mode for Receive

After using a buffer descriptor, MAL sets the buffer descriptor control to the Not-Empty state. In this way, MAL will not use the same buffer descriptor a second time until the software has processed the not-empty buffer descriptor and set it to Empty again. MAL will not clear the Empty bit while the Continuous Mode (CM) bit is set in the status/control field. The Continuous Mode is generally used by

protocols where frequent collisions are an integral part of the protocol itself (forcing the COMMAC to abort a reception process and restart). In such cases, re-reception can be performed without software intervention.

# 20.5.3 Descriptor Not Valid for Receive

When MAL accesses a buffer descriptor it may find that the Empty bit is not set. In the case of an RX channel descriptor, this situation is considered as a descriptor error. MAL deactivates the channel and from its point of view, the processing of the current packet has ended. Software may learn about this situation from one of two MAL interrupts (or from both):

- An RXDE interrupt with the MAL0\_RXDEIR indicating which channel caused the interrupt
- An SERR interrupt (system error) with one interrupt bit for all channels in the MAL0\_ESR

For more about error handling, see "Error Handling" on page 20-19.

# 20.5.4 Buffer Length for Receive

The maximum length of an RX buffer descriptor is predetermined for all RX descriptors in each channel. The data-length value is programmable through a set of MAL registers (see "MAL Registers" on page 20-24). The actual data length field within the RX buffer descriptor is written by MAL. If the buffer is completely filled up, the value written will match the value programmed into the matching RX-Channel-Descriptor data-length register. If the buffer is only partially filled up (for example, when the RX packet ended before running out of buffer space), the actual amount of space filled is written into the length field.

# 20.6 Descriptor Buffer Status/Control Fields

The following sections details the status/control field bits. The information fields within the status/control field can be divided as follows:

- Information from a software device driver directed to MAL and COMMAC
- Information from MAL and COMMAC directed to software
- Status/control field handling
- Status/control field format
- TX status/control field format
- RX status/control field format

### 20.6.1 Information from a Software Device Driver Directed To MAL and COMMAC

- MAL-related buffer descriptor processing information:
  - Buffer Ready/Not Ready (determines the buffer's validity).
  - Wrap to top of table or continue to next descriptor.
  - In a transmit buffer descriptor Is the current buffer the last one in the packet?
  - Continuous or normal mode; that is, should MAL change the Ready/Not Ready value?

- COMMAC channel configuration information:
  - Should the channel generate an interrupt following the end of packet processing.
  - Protocol specific configuration.

### 20.6.2 Information from MAL and COMMAC Directed to Software

- MAL generated status information:
  - Buffer Ready/Not Ready (passes the buffer handling to software).
  - In receive buffer descriptor Is the current buffer the first one in the packet?
  - In receive buffer descriptor Is the current buffer the last one in the packet?
- · COMMAC channel generated status information:
  - Protocol specific error and status information (transmit and receive).

# 20.6.3 Status/Control Field Handling

When MAL accesses a new buffer descriptor, the status/control word is written to the COMMAC channel. This allows the channel to configure itself for the current packet.

For all "intermediate" buffer descriptors (all descriptors that do not contain the packet's ending), the status/control field is written by MAL (rather than the COMMAC). In this case, the status/control field indicates that the current buffer is not the last one in the current packet.

As MAL finishes processing the last buffer descriptor in a given packet, it reads the channel's status (via an OPB transaction) and writes it into the buffer descriptor's status/control field.

In effect, since all of the various control and status fields do not overlap, the status/control halfword is read/written as a whole. Each agent (MAL, COMMAC channel, and software) reads the entire status/control halfword, relates to specific fields of interest, and updates another subset of fields within the same halfword. While an agent modifies its related fields, all other fields remain unchanged.

# 20.6.4 Status/Control Field Format

The status/control halfword is divided into COMMAC channel data and MAL related data. As explained above, the MAL related fields are either aimed at controlling MAL or written by MAL for use by the software. The MAL fields are of no interest to the COMMAC (except the Ready and Empty bits).

The same applies to the COMMAC channel fields. The COMMAC related fields are either aimed at controlling the COMMAC or written by COMMAC for use by the software. These fields are of no interest to MAL.

MAL will not manipulate the COMMAC related fields, and COMMAC is not allowed to manipulate the MAL related fields.

### 20.6.5 TX Status/Control Field Format



\* - COMMAC specific control or status fields

#### Figure 20-7. TX Status/Control Field

**Note:** The bit numbering in Figure 20-7 relates to the Buffer Descriptor's fullword which contains both the status/control and the length fields.

#### 20.6.5.1 Bit 0 – R – Ready

This bit is set by the device driver and is cleared by MAL.

The device driver sets this bit after preparing the buffer for transmission.

MAL clears this bit when finish processing the buffer descriptor. MAL doesn't clear the Ready bit in the case of backing-up a packet request and in case of continuous mode (see "Back Up a Packet for Transmit" on page 20-10 and "Continuous Mode for Transmit" on page 20-10.

#### 20.6.5.2 Bit 1 – W – Wrap

0 – This is not the last data buffer descriptor in the buffer descriptor table.

1 – This is the last data buffer descriptor in the buffer descriptor table. After this buffer has been used, MAL will transmit data from the first descriptor buffer in the table.

This bit is controlled by software only. It controls MAL activities, and does not affect the COMMAC channel.

#### 20.6.5.3 Bit 2 – CM – Continuous Mode

0 – Normal Operation

1 – Continuous Operation. After this buffer descriptor is closed, the R-bit is not cleared by MAL. This ensures that the data buffer is ready for transmission when MAL next accesses this buffer descriptor. However, the R-bit is cleared if an error occurs during transmission.

This bit is controlled by software only. It controls MAL activities and does not affect the COMMAC channel.

### 20.6.5.4 Bit 3 – L – Last

0 - This is not the last buffer in the current packet.

1 - This is the last buffer in the current packet.

This bit is controlled by software only. It controls MAL activities, and does not affect the COMMAC channel.

### 20.6.5.5 Bit 4 - Reserved

This bit is reserved. It is assumed that this bit is set to zero by the software.

#### 20.6.5.6 Bit 5 – I – Interrupt

1 – After finishing processing the current buffer, if this bit is 1, the end of buffer field in the End of Buffer Interrupt Status Register is set and the end of buffer interrupt is asserted.

0 - There is no action taken by MAL once it reaches the end of the current buffer.

MAL asserts the end of buffer interrupt after it updates the buffer descriptor's status field.

This bit is controlled by software only. It controls the MAL activities and does not affect the COMMAC.

#### 20.6.5.7 Bits 6 to 15

These bits are COMMAC specific and may contain control fields generated by the software in order to control the COMMAC channel. They may also contain status fields, generated by the COMMAC channel, that will be processed by software.

#### 20.6.6 RX Status/Control Field Format



MAL related data \* - COMMAC specific control or status fields COMMAC channel related data

#### Figure 20-8. RX Status/Control Field

**Note:** The bit numbering in Figure 20-8 relates to the buffer descriptor's fullword which contains both the status/control and the length fields.

#### 20.6.6.1 Bit 0 – E – Empty

0 - The data buffer associated with this buffer descriptor has been filled with received data, or data reception has been aborted due to an error condition. Software is free to examine or write to any fields of this buffer descriptor. While this bit is set to Not Empty, MAL will not use this buffer descriptor again.

1 – The data buffer associated with this buffer descriptor is empty, or reception is currently in progress. This buffer descriptor and its associated receive buffer are owned by MAL. Once the E-bit is set, software should not write to any fields of this RX buffer descriptor.

MAL clears this bit after the buffer has been filled with received data **or** after an error is encountered. Software sets this bit to Empty after preparing the buffer for reception. This bit controls MAL and software activities. See "Bit 2 - CM - Continuous Mode" on page 20-17.

### 20.6.6.2 Bit 1 – W – Wrap

0 - This is not the last data buffer descriptor in the buffer descriptor table.

1 – This is the last data buffer descriptor in the buffer descriptor table. After this buffer has been used, MAL will transfer data to the first buffer descriptor in the table.

This bit is controlled by software only. It controls MAL activities and does not affect the COMMAC channel.

### 20.6.6.3 Bit 2 - CM - Continuous Mode

#### 0 - Normal Operation

1 – Continuous Operation. After this buffer descriptor is closed, the E-bit is not cleared by MAL. This ensures that the data buffer is ready to receive data when MAL next accesses its buffer descriptor. However, the E-bit is cleared if an error occurs during reception.

This bit is controlled by software only. It controls MAL activities and does not affect the COMMAC channel.

#### 20.6.6.4 Bit 3 – L – Last

0 – This is not the last buffer in the current packet.

1 - This is the last buffer in the current packet.

This bit is updated by MAL following the activity of the channel.

#### 20.6.6.5 Bit 4 - F - First

0 - This is not the first buffer in the current packet.

1 - This is the first buffer in the current packet.

This bit is updated by MAL following the activity of the channel.

#### 20.6.6.6 Bit 5 – I – Interrupt

1 – After finish processing the current buffer, if this bit is 1, the end of buffer field in the End of Buffer Interrupt Status Register is set and the end of buffer interrupt is asserted.

0 – No action is taken by MAL at the end of the current buffer.

MAL asserts the end of buffer interrupt after updating the buffer descriptor's status field.

This bit is controlled by software only. It controls MAL activities and does not affect the COMMAC.

#### 20.6.6.7 Bits 6 to 15

These bits are COMMAC-specific and they may contain control fields generated by the software in order to control the COMMAC channel. They may also contain status fields generated by the COMMAC channel to be processed by software.

## 20.7 MAL Programming Notes

The following sections contain information about programming the MAL.

## 20.7.1 MAL Initialization

MAL initialization includes two parts: configuration and channel activation.

Configuration involves two steps:

- MAL configuration This step is done only after a power on reset or after a MAL soft reset. The following registers are involved:
  - Configuration Register (MAL0\_CFG). This register defines MAL operation on the PLB and OPB.
  - Interrupt Enable Register (MAL0\_IER). This register is used to enable interrupts for various MAL error conditions.
- Channel specific configuration This information may be changed only when the associated channel is not active. (The bit for the channel in the TX or RX Channel Active Set Register, is cleared.) The following registers are involved:
  - MAL0\_RCBSx RX Buffer Size (one register for each RX channel). This register defines the length of the RX buffers in memory.
  - MAL0\_TXCTPxR or MAL0\_RXCTPxR Channel Table Pointer Register (one register for each channel). This register is programmed with the memory address of the first buffer descriptor table entry for the channel.

Setting the channel specific configuration can be done as part of MAL initialization or as part of the COMMAC initialization process. In order to activate a channel, the following actions should be taken:

- The channel has to be configured in MAL
- The related bit in Channel Active Set Register (MAL0\_TXCASR or MAL0\_RXCASR) has to be set
- The channel operation must be enabled (COMMAC configuration)

#### 20.7.2 Interrupts

MAL has five interrupt lines (in the PPC405GP, all are connected to the UIC). Two interrupt lines, one for TX and one for RX, are used for interrupt events during packet transfer. An additional two interrupt lines, one for TX and one for RX, are used to report descriptor errors on a per-channel basis. The fifth interrupt is used to report MAL errors.

- TXEOB interrupt line is used to report end of buffer or end of packet for a specific TX channel. A bit for the related channel is set in the MAL0\_TXEOBISR. See "End of Buffer Interrupt Status Registers" on page 20-28.
- RXEOB interrupt line is used to report end of buffer or end of packet for a specific RX channel. A bit for the related channel is set in the MAL0\_RXEOBISR. See "End of Buffer Interrupt Status Registers" on page 20-28.
- TXDE interrupt line is used to indicate a descriptor error event in a specific TX channel descriptor table. A bit for the related channel is asserted in the MAL0\_TXDEIR. See "Descriptor Error Interrupt Registers (MAL0\_TXDEIR, MAL0\_RXDEIR)" on page 20-32.

- RXDE interrupt line is used to indicate a descriptor error event in a specific RX channel descriptor table. A bit for the related channel is asserted in the MAL0\_RXDEIR. See "Descriptor Error Interrupt Registers (MAL0\_TXDEIR, MAL0\_RXDEIR)" on page 20-32.
- SERR interrupt is used to report a system error indicated by MAL. For more information on handling the SERR interrupts, see "Error Handling" on page 20-19 and "Error Registers" on page 20-29.

## 20.7.3 Error Handling

MAL handles errors on a per-channel basis. Within a COMMAC channel, errors may arise from the COMMAC (detected as an OPB error), or from the memory access operations involved in MAL activity (detected as a PLB/descriptor error).

When a bus error occurs, MAL is notified by an OPB or PLB error signal. OPB errors are related to a specific channel and therefore channel operation is stopped. In the case of a PLB error, MAL cannot identify which channel is involved, therefore channel operation is not stopped. When a descriptor error occurs, MAL can again identify the channel involved, so channel operation is stopped. MAL stops channel operation by clearing the associated bit in the MAL0\_TXCASR or MAL0\_RSCASR register.

MAL keeps a record of the channels that experience errors and are made inactive. It also keeps a record of the characteristics of the first (or last) error detected (see "End of Buffer Interrupt Status Registers" on page 20-28).

### 20.7.3.1 Error Detection

The MAL communication, both with COMMACs and with memory, is carried out via the OPB or PLB. As long as this bus communication is error-free and no descriptor errors are detected, MAL maintains normal activity with the channels set by the processor as active in the Channel Active Registers.

When an error is detected while performing a transfer for a channel, MAL asserts a maskable interrupt signal. If the identity of the channel is known (as is the case for OPB errors or descriptor errors) then MAL immediately halts the dialogue with the channel. No further transactions are made, and that channel is registered by MAL as a nonactive channel. MAL resets the channel by resetting its active bit in the Channel Active Register. Software must access the Channel Active Register in order to reactivate the channel.

If the identity of the channel that caused the error is not known (as is the case for PLB errors) then MAL continues to work normally. Error resolution and channel de-activation are the responsibility of the software.

#### 20.7.3.2 Indicated Errors

Error description is stored in the Error Status Register (MAL0\_ESR), (see "MAL Error Status Register (MAL0\_ESR)" on page 20-29).

Descriptor Error

A descriptor error is a data error recognized during access to the descriptor table. The error can occur during TX or RX transmission.

For RX channels, a descriptor error occurs when MAL accesses a descriptor in which the Empty bit is cleared.

For TX channels, a descriptor error occurs when MAL accesses a descriptor in which the Ready bit is cleared. The following cases are exceptions.

- On access to the first buffer descriptor in a TX packet.
- On access to a buffer descriptor that is not the last descriptor in a backed-up packet.

As a result of this error, the following actions are taken by MAL:

- The Active bit of the related channel is reset and the channel activity is halted until software reactivates channel activity.
- The associated bit in the TX Descriptor Interrupt Error Register (MAL0\_TXDEIR) or RX Descriptor Error Register (MAL0\_RXDEIR) is set, causing a nonmaskable TXDE interrupt or RXDE interrupt respectively.
- When the channel is reactivated, MAL points to the descriptor at the head of the BD table.
- OPB Non-Fullword Error

This error indicates that a non-fullword acknowledge was asserted by a slave.

Following this error, the active bit of the associated channel is reset and channel activity is halted until it is reactivated by software. When the channel is reactivated, MAL points to the descriptor at the head of the BD table.

OPB Time-Out Error

This error indicates that an OPB time-out error was reported by the OPB arbiter.

Following this error, the active bit of the associated channel is reset and channel activity is halted until reactivated by software. When the channel is reactivated, MAL points to the descriptor at the head of the BD table.

OPB Error

This error indicates that an OPB error was detected.

Following this error, the active bit of the associated channel is reset and channel activity is halted until reactivated by software. When the channel is reactivated, MAL points to the descriptor at the head of the BD table.

PLB Error

This error indicates that a PLB error was detected (from the PLB slave).

In this case, MAL cannot determine which channel caused the error. Therefore, operation is not halted for any of the channels.

#### 20.7.3.3 Error Handling Registers

MAL error handling logic includes two registers.

Error Status Register (ESR)

This register holds information about the error that occurred and the interrupt status. The register includes the following fields:

Error status – This field holds the error information. The information includes the number of the channel on which the error occurred (if known) and the type of the error. The error can be either the last detected error or a locked error if "Locked error mode" is active. See "Operational Error Modes" on page 20-21 for description of the Locked error mode.

The error status field includes an "Error Valid" bit which indicates whether there is valid error information in the error status field or not. The error status field is not valid when the "Error Valid" bit is cleared (by writing 1 to this bit).

Interrupt status – Every error detected by MAL sets a related bit in the interrupt status field. Software can clear an interrupt status bit by writing 1 to the bit to be cleared. The bits in this field are accumulative which allows more than one interrupt to be indicated in the register.



#### Figure 20-9. Error Status Register Field

#### 20.7.3.4 Operational Error Modes

MAL can operate in two different error handling modes:

- Locked Error Mode: Information about the error is written to the Error Status Register, and the Valid bit in that register is set. Information in the Error Status field of the register stays locked until software unlocks it by resetting the error Valid bit. The Interrupt Status bits of the Error Status Register are not locked in this mode, so software can find out if more errors occur. However, the Error Status field applies only to the first error that is locked.
- Non-Locked Error Mode: Information about the error is written in the Error Status Register, and the
  error Valid bit is set. Each new error will be overwritten, so the information in the Error Status Field
  is valid only for the last error that occurred.

In both modes, each error written in the error description field will set the error Valid bit, and it is the responsibility of software to reset this bit.

The error handling mode is programmed in the MAL Configuration Register (see "MAL Configuration Register (MAL0\_CFG)" on page 20-25).

#### 20.7.3.5 Resolution of an Error Situation

When MAL encounters an error, it reacts as follows:

- Writes information about the error in the Error Status Register (ESR). This information includes the channel ID of the channel which caused the error (if known), the bus on which the error occurred, and the kind of error that occurred.
- Resets the channel that caused the error (if known) in the Channel Active Register.
- Updates the Interrupt Status bits in the MAL0\_ESR. Then, depending on the mask defined in MAL0\_IER (Interrupt Enable Register), it may send an interrupt to software (in PPC405GP, it sends it to the Universal Interrupt Controller).

After receiving an interrupt from MAL, software can analyze the error information read from the Error Status Register. Software can restart channel activity by setting the associated bit in the Channel Active Register.

When a channel is stopped and restarted, MAL starts processing descriptors from the first descriptor in the channel descriptor table. Therefore, software may also update the value of the other channel related registers (see "Channel Table Pointer Registers (MAL0\_TXCTPxR, MAL0\_RXCTP0R)" on page 20-33) in order to continue from the same buffer in memory.

In the case of PLB errors, MAL does not know which channel caused the error. It is the responsibility of the software to analyze the MAL error registers and the PLB slave error registers to determine which channel caused the error. Software should reset the channel within MAL, resolve the problem, and then reactivate the channel.

See Figure 20-10 on page 20-23 for a flow chart illustrating the steps MAL performs when resolving an error situation.

#### 20.7.3.6 Interrupts To Software



Figure 20-10. MAL Error Processing

Figure 20-10 on page 20-23 describes MAL actions once an error is detected. Note that the actual decisions MAL makes may be in a different order than represented by this figure. In any case, the device driver should consider that all of the MAL actions are performed at the same time.

## 20.8 MAL Registers

Access to MAL registers is through the DCR interface.

- Unless otherwise specified, all register fields are initialized at chip reset to 0.
- Reserved fields are read as undefined and must be written as 0s.

| Register      | DCR Number | Access  | Description                                 |
|---------------|------------|---------|---------------------------------------------|
| MAL0_CFG      | 0x180      | R/W     | Configuration Register                      |
| MAL0_ESR      | 0x181      | R/Clear | Error Status Register                       |
| MAL0_IER      | 0x182      | R/W     | Interrupt Enable Register                   |
| MALDBR        | 0x183      | R       | Debug Register                              |
| MAL0_TXCASR   | 0x184      | R/W     | TX Channel Active Set Register              |
| MAL0_TXCARR   | 0x185      | R/W     | TX Channel Active Reset Register            |
| MAL0_TXEOBISR | 0x186      | R/Clear | Tx End of Buffer Interrupt Status Register  |
| MAL0_TXDEIR   | 0x187      | R/Clear | Tx Descriptor Error Interrupt Register      |
| MAL0_RXCASR   | 0x190      | R/W     | RX Channel Active Set Register              |
| MAL0_RXCARR   | 0x191      | R/W     | RX Channel Active Reset Register            |
| MAL0_RXEOBISR | 0x192      | R/Clear | Rx End of Buffer Interrupt Status Register  |
| MAL0_RXDEIR   | 0x193      | R/Clear | Rx Descriptor Error Interrupt Register      |
| MALO_TXCTPOR  | 0x1A0      | R/W     | Channel Tx 0 Channel Table Pointer Register |
| MAL0_TXCTP1R  | 0x1A1      | R/W     | Channel Tx 1 Channel Table Pointer Register |
| MAL0_RXCTP0R  | 0x1C0      | R/W     | Channel Rx 0 Channel Table Pointer Register |
| MAL0_RCBS0    | 0x1E0      | R/W     | Channel RX 0 Channel Buffer Size Register   |

Table 20-1. MAL Registers

## 20.8.1 MAL Configuration Register (MAL0\_CFG)

This register defines the operational mode of MAL. Unless a configuration change is required during system operation, the configuration register needs to be set only during system initialization.



| 0     | SR               | MAL Software Reset<br>0 MAL reset is complete<br>1 Reset the MAL                                                       | This bit is used to generate a general reset to MAL<br>through a software command.<br>After setting this bit, MAL hardware (registers,<br>interface and internal state machines) returns to the<br>power-on reset value.<br>The software writes 1 to this bit in order to drive<br>MAL to the reset state. The bit is cleared by the<br>hardware when the reset is completed (one system |
|-------|------------------|------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:7   | Na mumbroga agai | Reserved                                                                                                               | clock).                                                                                                                                                                                                                                                                                                                                                                                  |
|       |                  |                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                          |
| 8:9   | PLBP             | PLB Priority<br>00 Lowest<br>01<br>10<br>11 Highest                                                                    | Determines the priority of MAL requests on the PLB.                                                                                                                                                                                                                                                                                                                                      |
| . 10  | GA               | Guarded Active<br>0 GUARDED signal not<br>applied to the PLB slave<br>1 GUARDED signal applied<br>to the PLB slave     | When this bit is set, MAL applies the GUARDED<br>signal to the PLB slave when it is the initiator on the<br>bus.<br>When set, the slave can access all the memory in<br>the current page as well as the subsequent page.                                                                                                                                                                 |
| 11    | OA               | Ordered Active<br>0 ORDERED signal not<br>applied to the PLB slave<br>1 ORDERED signal applied<br>to the PLB slave     | When this bit is set, MAL applies the ORDERED<br>signal to the PLB slave when it is initiator on the bus<br>during data write transactions.<br>Note that the ORDERED signal is always driven<br>active during status write transactions.                                                                                                                                                 |
| 12    | PLBLE            | PLB Lock Error<br>0 LOCKERROR signal not<br>applied to the PLB slave<br>1 LOCKERROR signal<br>applied to the PLB slave | When this bit is set, MAL applies the LOCKERROR signal to the PLB slave when it is the initiator during PLB transactions.                                                                                                                                                                                                                                                                |
| 13:16 | PLBLT            | PLB Latency Timer                                                                                                      | Determines the number of cycles allowed for burst transactions on the PLB.                                                                                                                                                                                                                                                                                                               |
|       | PLBB             | PLB Burst<br>0 Burst transactions not<br>allowed<br>1 Burst transactions allowed                                       | When this bit is reset, MAL is not allowed to perform burst transactions.                                                                                                                                                                                                                                                                                                                |

Figure 20-11. MAL Configuration Register (MAL0\_CFG)

| 24    | OPBBL | OPB Bus Lock<br>0 OPB not locked<br>1 OPB locked                                                                                                                             | When this bit is set, MAL locks the OPB during data transfers to and from the COMMACs.                                                                                                                                                                                                                                                                                            |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:28 |       | Reserved                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                   |
| 29    | EOPIE | End of Packet Interrupt<br>Enable<br>0 Generate interrupt on every<br>end-of-packet only if the<br>buffers I bit is set<br>1 Generate interrupt is on<br>every end-of-packet | <ul> <li>When this bit is set, an interrupt is generated on<br/>every end of packet (both transmit and receive).</li> <li>When clear, end of packet/buffer interrupt is<br/>generated only if the buffers I bit is set (1).</li> <li>Note: An interrupt is generated for every descriptor<br/>on which the I bit is set, regardless of the<br/>state of the EOPIE bit.</li> </ul> |
| 30    | LEA   | Locked Error Active<br>0 Handle errors in a non-<br>locked mode<br>1 Handle errors in locked<br>mode                                                                         | Determines MAL's error handling mode. When this<br>bit is set, MAL will handle errors in the locked mode,<br>otherwise it will handle errors in a non-locked mode.                                                                                                                                                                                                                |
| 31    | SD    | MAL Scroll Descriptor<br>0 Do not scroll to the first<br>descriptor of the next<br>packet<br>1 Scroll to the first descriptor<br>of the next packet                          | Determines whether or not MAL should scroll to the<br>first descriptor of the next packet, following an early<br>packet termination initiated by the related<br>COMMAC. When set, Scrolling mode is active.                                                                                                                                                                       |

## 20.8.2 Channel Active Set and Reset Registers

For the Channel Active Set/Reset Registers (MAL0\_TXCASR, MAL0\_TXCARR, MAL0\_RXCASR, MAL0\_RXCARR), each bit represents its associated channel (bit 0 for channel 0, etc.). When a bit is equal to 1, the channel has been enabled for operation. When a bit is equal to 0, the channel is disabled (MAL ignores any requests for service). If a channel is active when its enable bit is cleared, MAL stops processing the current packet. After the channel's enable bit is cleared, MAL goes back to the top of the channel descriptor table (pointed to by the Channel Table Pointer Register).

- To enable a channel:
  - Write a 1 to its corresponding bit in the Channel Active Set Register (CASR).
  - Multiple channels can be enabled with a single CASR register write.
- To stop and reset a channel:
  - Write a 1 to its corresponding bit in the Channel Active Reset Register (CARR).
  - Writing a 0 to bits in the CARR registers has no effect on the channels.
  - Multiple channels can be reset with a single CARR register write.

MAL also clears the enable bit of a channel following an indication of an error on the channel. The CASR or CARR register(s) can be read to determine which channels are currently active. The following figures describe these registers.

| • |    |   |               | <br>                  |    |
|---|----|---|---------------|-----------------------|----|
| l | 01 | 2 | 맛, 영양 방송 문화 말 | 요즘 아직 방법을 가려면 가지 않는다. | 31 |
|   |    |   |               |                       |    |

## Figure 20-12. TX Channel\_Active Set Register (MAL0\_TXCASR)

| 0:1  | Transmit Channel Active Set | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>When 1 is written to the bit, channel<br>operation is enabled.<br>There are only two TX channels in the<br>PPC405GP. |
|------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:31 | Reserved                    |                                                                                                                                                                                                 |

| 0 | 1 2 | 31 |
|---|-----|----|

## Figure 20-13. TX Channel\_Active Reset Register (MAL0\_TXCARR)

| 0:1  | Transmit Channel Active Reset | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>When 1 is written to the bit, channel<br>operation is disabled.<br>There are only two TX channels in the<br>PPC405GP. |
|------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:31 | Reserved                      |                                                                                                                                                                                                  |

0 1 31

## Figure 20-14. RX Channel\_Active Set Register (MAL0\_RXCASR)

| 0    | Receive Channel Active Set | Each bit represents its related<br>channel (bit 0 for channel 0 etc.).<br>When 1 is written to the bit, channel<br>operation is enabled.<br>There is only one RX channel in the<br>PPC405GP. |
|------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:31 | Reserved                   |                                                                                                                                                                                              |

0 1 31

#### Figure 20-15. RX Channel\_Active Reset Register (MAL0\_RXCARR)

| 0    | Receive Channel Active Reset | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>When 0 is written to the bit, channel<br>operation is disabled.<br>There is only one RX channel in the<br>PPC405GP. |
|------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:31 | Reserved                     |                                                                                                                                                                                                |

### 20.8.2.1 End of Buffer Interrupt Status Registers

Each bit in the TX End-of-Buffer Interrupt Status and RX End-of-Buffer Interrupt Status registers is related to a channel's descriptor buffer table.

The TX End-of-Buffer Interrupt Status register contains the End-of-Buffer Status bits for each TX channel. The RX End-of-Buffer Interrupt Status register contains the End-of-Buffer Status bits for the RX channels. The mechanism (as described below) for both RX and TX registers is the same.

MAL sets a channel's bit in one of the following conditions:

- When MAL finishes the processing of a buffer (writes back the status to the current descriptor), the related bit in this register is set if the I bit in the descriptor status is set.
- When MAL finishes the processing of a packet (writes back the status of the packet's last buffer) and MAL0\_MCR[EOPIE] is set.
- **Note:** In case MAL finishes the processing of a packet which is backed up, MAL doesn't consider it as an end of packet. Therefore, MAL will not set the appropriate channel bit in the End-of-Buffer Register.
- When the Bad Packet bit is set in the COMMAC channel Status halfword.

The device driver resets the interrupt by writing a 1 to the related bit. Writing a 0 has no effect.

0 1 2 31

#### Figure 20-16. TX End of Buffer Interrupt Status Register (MAL0\_TXEOBISR)

| 0:1  | Transmit Channel End-of-Buffer Interrupt | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>Writing 1 to a bit resets it.<br>There are only two TX channels in the<br>PPC405GP. |
|------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:31 | Reserved                                 |                                                                                                                                                                |

| 0 | <u>,</u> 1 | 2022299 | SE SECTION | 916363 |  |  |  |  | 519183 | gián ( | 3 |
|---|------------|---------|------------|--------|--|--|--|--|--------|--------|---|

| Figure 20-17. | RX End of Buffer | <b>Interrupt Status</b> | Register (MALC | _RXEOBISR) |
|---------------|------------------|-------------------------|----------------|------------|
|               |                  |                         |                |            |

| 0    | Receive Channel End-of-Buffer Interrupt | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>Writing 1 to a bit resets it.<br>There is only one RX channel in the<br>PPC405GP. |
|------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:31 | Reserved                                |                                                                                                                                                              |

## 20.9 Error Registers

The following paragraphs describe MAL error registers. For more information about MAL errors see "Error Handling" on page 20-19.

#### 20.9.1 MAL Error Status Register (MAL0\_ESR)

This register holds the information about the error that occurred and the interrupts status. The register includes the following fields:

 Error status bits – This field holds the error information. The information includes the number of the channel on which the error occurred (if known) and the type of the error. The error can be either the last detected error or a locked error if "Locked error mode" is active. (See "Operational Error Modes" on page 20-21 for description of the Locked error mode.)

The error status field includes an "Error Valid" bit which indicates whether there is an error information in the error status field or not. The error status bits are not valid when the "Error Valid" bit is cleared (by writing 1 to this bit).

- Interrupt status bits Every error detected by MAL sets a related bit in the interrupt status field. The interrupt status bits may be cleared by software by writing 1 to the bit to be cleared. The bits in this field are accumulative (more than one interrupt may be indicated here). These bits are masked by the IER (Interrupt Enable Register) to create a maskable interrupt, which is implemented by the MAL\_SERR\_INT signal (connected to the UIC on the PPC405GP).
- **Note:** In order to reset the interrupt bits and the Error valid bit in the Error Status register, 1 must be written to the related bit. Writing 0 has no effect.

More than one bit can be cleared at a time and only R/W bits can be reset.





|      |      | Tigure 20-10. MAL EITOI Status Reg                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | EVB  | <ul> <li>Error Valid Bit</li> <li>0 Bit 1:15 are available for latching new error information.</li> <li>1 Bits 1:15 contain last error. A new error cannot be latched.</li> </ul> | When this bit is set, bits 1-6 include the ID<br>of the erroneous channel (in case of OPB<br>errors). Bits 11-15 indicate the type of<br>error.<br>In non-locked mode, the error indication<br>describes the last error that had occurred.<br>In locked mode, the error is the first one<br>that had occurred after this bit was<br>cleared.<br>This bit is set when an error occurs and<br>remains set until reset by the software. In<br>locked mode, new errors cannot be<br>latched in the error lock indication fields if<br>this bit is set |
| 1:6  | CID  | Channel ID                                                                                                                                                                        | This field contains the number of the<br>channel which caused the locked error.<br>Bit 1 indicates whether the channel ID<br>represents an RX channel (1) or a TX<br>channel (0).<br>Bits 2:6 indicates the number of the<br>channel that caused the error.<br>Note: An error on the PLB cannot be<br>related to a channel. The error<br>condition may be resolved by using<br>the error information optionally<br>locked in the PLB slave.                                                                                                       |
| 7:10 |      | Reserved                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11   | DE   | Descriptor Error<br>0 No error<br>1 Non-valid descriptor                                                                                                                          | Indicates that the error is a non-valid descriptor, which is <i>not</i> the first descriptor in a TX packet.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12   | ONE  | OPB Non-fullword Error<br>0 No error<br>1 Non-fullword asserted                                                                                                                   | Indicates that the error is a non-fullword acknowledge asserted by an OPB slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13   | OTE  | OPB Timeout Error<br>0 No error<br>1 OPB timeout                                                                                                                                  | Indicates the error is an OPB timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14   | OSE  | OPB Slave Error<br>0 No error<br>1 OPB slave error                                                                                                                                | Indicates the error is an error indication asserted by an OPB slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15   | PEIN | PLB Bus Error Indication<br>0 No error<br>1 PLB bus error                                                                                                                         | When this bit is set, the detected error is a PLB error. There is no meaning to the Channel ID field in this case.                                                                                                                                                                                                                                                                                                                                                                                                                                |

| 16:26 |      | Reserved                                                                                        |                                                                                                                                                                                                                                                                                               |
|-------|------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | DEI  | Descriptor Error Interrupt<br>0 No error<br>1 Descriptor data error recognized                  | A descriptor data error is recognized<br>during access to the descriptor table.<br>This error indication is asserted when a<br>non-valid descriptor is accessed, which is<br><i>not</i> the first descriptor in a TX packet. Set<br>condition for this bit generates a maskable<br>interrupt. |
| 28    | ONEI | OPB Non-fullword Error Interrupt<br>0 No error<br>1 Non-fullword acknowledgment from a<br>slave | This bit is set following a non-fullword<br>acknowledgment coming from a slave. Set<br>condition for this bit generates a maskable<br>interrupt.                                                                                                                                              |
| 29    | OTEI | OPB Timeout Error Interrupt<br>0 No error<br>1 OPB time-out                                     | This bit is set following an OPB time out<br>error indication. Set condition for this bit<br>generates a maskable interrupt.                                                                                                                                                                  |
| 30    | OSEI | OPB Slave Error Interrupt<br>0 No error<br>1 OPB error from a slave                             | This bit is set following an OPB error<br>indicated by the slave. Set condition for<br>this bit generates a maskable interrupt.                                                                                                                                                               |
| 31    | PBEI | PLB Bus Error Interrupt<br>0 No error<br>1 PLB error indication                                 | This bit is set following a PLB error<br>indication (from the PLB slave). Set<br>condition for this bit generates a maskable<br>interrupt.                                                                                                                                                    |

## 20.9.2 MAL Interrupt Enable Register (MAL0\_IER)

Each bit in the following register, when it is set, enables assertion of the interrupt signal (MAL\_SERR\_INT) when the related bit in the MAL0\_ESR (interrupt bit) is set.



|      |                             | Figure 20-19. MAL Interrupt                                             | Enable Register (MAL0_IER)                                                        |  |  |
|------|-----------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|
| 0:26 |                             | Reserved                                                                |                                                                                   |  |  |
| 27   | DE                          | Descriptor Error                                                        | When set, this bit enables the descriptor error (descriptor not valid) interrupt. |  |  |
| 28   | 28 NWE Non_W_Err_Int_Enable |                                                                         | When set, this bit enables OPB non-word transfer error interrupt.                 |  |  |
| 29   | то                          | O Time_Out_Int_Enable When set, this bit enables OPB time or interrupt. |                                                                                   |  |  |
| 30   | OPB                         | OPB_Err_Int_Enable                                                      | When set, this bit enables the OPB Slave error interrupt.                         |  |  |
| 31   | PLB                         | PLB_Err_Int_Enable                                                      | When set, this bit enables the PLB error interrupt.                               |  |  |

## 20.9.3 Descriptor Error Interrupt Registers (MAL0\_TXDEIR, MAL0\_RXDEIR)

Each bit in the following registers is related to a channel descriptor buffer table. Each bit indicates a descriptor data error related to a certain channel.

The TX Descriptor Error register contains the Descriptor errors bits of the TX channels. The RX Descriptor Error register contains the Descriptor errors bits of the RX channels. The mechanism (as described below) for both RX and TX registers is the same.

MAL sets a channel's bit when a descriptor data error was recognized during access to the descriptor table of a specific channel (see "Descriptor Error" on page 20-19).

The device driver resets the interrupt by writing a 1 to the related bit. Writing a 0 has no effect. When one or more of the TX Descriptor Error Interrupt bits is set, then the MAL\_TX\_DESC\_ERR\_INT bit is set. When one or more of the RX Descriptor Error Interrupt bits is set, then the MAL\_RX\_DESC\_ERR\_INT signal is set (attached to UIC on the PPC405GP).

0 1 2

| Figure 20-20   | TX Descriptor Error | r Interrunt Register | (MALO TXDEIR) |
|----------------|---------------------|----------------------|---------------|
| I Iguie 20-20. |                     | interrupt negister   |               |

| 0:1  | Transmit Descriptor Error Interrupt | Each bit represents its related<br>channel (bit 0 for channel 0, etc.).<br>When one or more bits are set,<br>MAL_DESC_ERR_INT is set. Writing 1 to<br>a bit resets it.<br>There are only two TX channels in the<br>PPC405GP. |
|------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:31 | Reserved                            |                                                                                                                                                                                                                              |

0 1 31

#### Figure 20-21. RX Descriptor Error Interrupt Register (MAL0\_RXDEIR)

| 0    | Receive Descriptor Error Interrupt | Each bit represents its related<br>channel (bit 0 for channel 0 etc.).<br>When one or more bits are set,<br>MAL_DESC_ERR_INT is set. Writing 1 to<br>a bit resets it.<br>There is only one RX channel in the<br>PPC405GP. |
|------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:31 | Reserved                           |                                                                                                                                                                                                                           |

## 20.9.4 Channel Table Pointer Registers (MAL0\_TXCTPxR, MAL0\_RXCTP0R)

MAL uses RX Channel table pointer registers, one for each RX channel, and TX Channel table pointer registers, one for each TX channel. The Channel Table Pointer Registers point to the base address, in memory, of the descriptor buffer table used by each channel.

- Note 1: Bits 0 to 12 of all the TXCTPxR registers are mapped to the same physical register. Writing into any of these registers overwrites the value of bits 0 to 12 in all the TXCTPxR registers. Read operation has no effect. Bits 0 to 12 of all the RXCTPxR registers are mapped to the same physical register. Writing into any of these registers overwrites the value of bits 0 to 12 in all the RXCTPxR registers. The all the RXCTPxR registers are mapped to the same physical register. Writing into any of these registers overwrites the value of bits 0 to 12 in all the RXCTPxR registers.
- Note 2: When changing the value of either of the MAL0\_TXCTPxR registers, both TX channels must be idle. To verify a channel is idle, check the device's Transmit Idle bit. Another way to assure that the channels are idle is to disable the channels before changing the MAL0\_TXCTPxR register, and then re-enable them once the MAL0\_TXCTPxR register is set to its new value.

The TX and RX Channel Table Pointer Registers have an identical format as shown in Figure 20-22 and Figure 20-23. There are two TX registers (0 and 1), and one RX register (0) in PPC405GP.

0 31

|      | -                     |                                                                                                                                                                                                                                                                                                                                                          |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0:31 | Channel Table Pointer | Pointer to the base address in memory of<br>the buffer descriptor table used by the<br>channel. The value entered should be a<br>pointer to a location in memory<br>accommodating an aligned double fullword<br>(this requires the three least significant bits<br>of this pointer must be 000).<br>There are two transmit channels ( $x = 0$<br>and 1). |
|      |                       |                                                                                                                                                                                                                                                                                                                                                          |

#### Figure 20-22. TX Channel Table Pointer x Register (MAL0\_TXCTPxR)

0 31

#### Figure 20-23. RX Channel Table Pointer x Register (MAL0\_RXCTPxR)

| 0:31 | Channel Table Pointer | Pointer to the base address in memory of<br>the buffer descriptor table used by the<br>channel. The value entered should be a<br>pointer to a location in memory<br>accommodating an aligned double fullword<br>(this requires the three least significant bits<br>of this pointer must be 000)<br>There is one receive channel ( $x = 0$ ). |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

The Table Pointer Registers retain their value following Soft Reset or Channel Reset.

20-34 PPC405GP User's Manual

# **Chapter 21. Serial Port Operations**

The PPC405GP contains two universal asynchronous receiver/transmitters (UARTs) which provide two full-duplex serial interfaces to support communications with serial peripheral devices. Each UART is compatible with the National Semiconductor (NS) 16550 chip, and includes a 16-byte send and a 16-byte receive FIFO.

Features of the UART include:

- · Compatible with the NS 16550
- 16-byte send FIFO, 16-byte receive FIFO
- Full duplex operation
- Programmable baud rate generator
- Supports 5- to 8-bit word size, 1 or 2 stop bits, even, odd, or no parity
- One 8-wire interface (UART0) and one 4-wire interface (UART1)

The UART performs serial-to-parallel conversion on data characters received from a peripheral device, and parallel-to-serial conversion on data characters received from the processor. The processor can read the complete status of the UART at any time during the functional operation. Status information reported includes the type and condition of the transfer operations being performed by the UART, as well as any error conditions, such as parity, overrun, framing, and break interrupt.

This UART is functionally identical to NS16450 in character mode (on power up it will be in this mode), and can be put into FIFO mode to relieve the processor of excessive software overhead. Here, internal FIFOs are activated allowing 16 bytes (plus 3 bits per byte of error data in the RCVR FIFO) to be stored in both receive and transmit modes.

The source of the UART serial clock input is selected in Chip Control Register 0 (CPC0\_CR0[U0EC:U1EC]) bits 24 and 25. Either the internal serial clock or an external serial clock can be selected. A programmable baud rate generator is included that is capable of dividing the UART serial clock input by a divisor of 1 to  $(2^{16} - 1)$  and producing the 16× clock required for driving the UART internal transmitter/receiver logic. The internal serial clock input is derived from the CPU clock by a divisor specified in CPC0\_CR0[UDIV].

The UART has an interrupt system that can be programmed to the user's requirements, helping to minimize the computing required to handle the communications link. UART interrupts are capable of triggering an interrupt request to the PPC405GP interrupt controller.

## 21.1 Functional Description

- Runs NS 16550 software
- · Registers are identical to the NS16550 register set
- After reset, all registers are identical to the NS16450 register set
- Complete status reporting capability
- Transmitter and receiver are each buffered with 16-byte FIFOs when FIFO mode selected

- Can add/delete standard asynchronous communication bits such as start, stop, and parity to/from the serial data
- When in character mode, holding and shift registers eliminate the need for precise synchronization between the processor and serial data
- Full prioritized interrupt system controls
- · Independently controlled transmit, receive, line status, and data set interrupts
- Programmable baud rate generator divides the UART serial clock input by 1 to (2<sup>16</sup>-1) and generates the 16x clock:

Baud rate (bps) = (Serial Clock Input) / (16 x Decimal Divisor)

- Receiver uses 5-way oversampling as follows: it samples each serial bit five times, and if at least three of the samples are 1's, the bit is determined to be a 1, otherwise it is a 0
- Fully programmable serial-interface characteristics:
  - 5-, 6-, 7-, or 8-bit characters
  - Even, odd, or no parity bit generation and detection
  - 1-,1.5-, or 2-stop bit generation
  - Variable baud rate
- Line break generation and detection, and false start bit detection
- · Internal diagnostic capability:
  - Loopback controls for communications link fault isolation
  - Break, parity, overrun, framing error simulation

## 21.2 Serial Input Clocking

The two PPC405GP UARTs can be clocked individually from an external serial clock or from an internally generated serial clock. The internally generated serial clock is derived from the CPU clock, and is CPU/n, where n ranges from 1 to 32. The divisor n is programmed by setting a value of 0 to 31 in CPC0\_CR0[UDIV] (see Chapter 7, "Clocking").

The choice of serial clock frequency affects the serial communications error rate. If an external clock of 1.8432 MHz (or some multiple of this frequency) is used, the error rate approaches zero. However, when using the internally generated clock only certain clock frequencies are possible, which results in a small, non-zero error rate in all cases, unless SysClk is chosen as an integer multiple of 1.8432 MHz.

The optimum serial clock frequency is determined from the following relationship:

#### Serial Clock = Baud Rate × 16 × UART Divisor

Acceptable baud rates are always integral multiples of 300 (for example,  $1200 = 4 \times 300$ ). Table 21-1 shows optimum UART divisor and CPU divide ratios for a range of possible baud rates. This information is provided for four different CPU clock frequencies. The UART divisor is programmed in

UARTx\_DLM and UARTx\_DLL (see "Divisor Latch LSB and MSB Registers (UARTx\_DLL, UARTx\_DLM)" on page 21-14). The value range is 1 to (2^16-1)=65535.

| Desired Baud  | CPU:UART     | Serial Clock    |                   | Actual Baud   |           |
|---------------|--------------|-----------------|-------------------|---------------|-----------|
| Rate (bps)    | Divide Ratio | Frequency (MHz) | UART Divisor      | Rate (bps)    | Error (%) |
| CPU Clock = 1 | 50MHz        |                 |                   |               |           |
| 1200          | 13           | 11.5380         | 601               | 1199.923205   | 0.0063996 |
| 2400          | 21           | 7.1429          | 186               | 2400.153610   | 0.0064004 |
| 4800          | 21           | 7.1429          | 93                | 4800.307220   | 0.0064004 |
| 9600          | 16           | 9.3750          | 61                | 9605.532787   | 0.0576332 |
| 19200         | 14           | 10.7140         | 35                | 19132.653061  | 0.3507653 |
| 28800         | 13           | 11.5380         | 25                | 28846.153846  | 0.1602564 |
| 33600         | 9            | 16.6670         | 31                | 33602.150538  | 0.0064004 |
| 38400         | 9            | 16.6670         | 27                | 38580.246914  | 0.4693930 |
| 57600         | 18           | 8.3333          | 9                 | 57870.370370  | 0.4693930 |
| 115200        | 9            | 16.6670         | 9                 | 115740.740741 | 0.4693930 |
| 307200        | 30           | 5.0000          | 1                 | 312500.000000 | 1.7252604 |
| CPU Clock = 1 | 66.66 MHz    |                 | • · · · · · · · · |               |           |
| 1200          | 31           | 5.3763          | 280               | 1200.076800   | 0.0064000 |
| 2400          | 31           | 5.3763          | 140               | 2400.153600   | 0.0064000 |
| 4800          | 31           | 5.3763          | 70                | 4800.307200   | 0.0064000 |
| 9600          | 31           | 5.3763          | 35                | 9600.614401   | 0.0064000 |
| 19200         | 32           | 5.2083          | 17                | 19148.284237  | 0.2693529 |
| 28800         | 19           | 8.7719          | 19                | 28855.032202  | 0.1910840 |
| . 33600       | 31           | 5.3763          | 10                | 33602.150403  | 0.0064000 |
| 38400         | 17           | 9.8039          | 16                | 38296.568474  | 0.2693529 |
| 57600         | 30           | 5.5556          | 6                 | 57870.370139  | 0.4693926 |
| 115200        | 30           | 5.5556          | 3                 | 115740.740278 | 0.4693926 |
| 307200        | 17           | 9.8039          | 2                 | 306372.547794 | 0.2693529 |
| CPU Clock = 2 | 00MHz        |                 |                   |               |           |
| 1200          | 11           | 18.1820         | 947               | 1199.961601   | 0.0031999 |
| 2400          | 28           | 7.1429          | 186               | 2400.153610   | 0.0064004 |
| 4800          | 28           | 7.1429          | 93                | 4800.307220   | 0.0064004 |
| 9600          | 14           | 14.2860         | 93                | 9600.614439   | 0.0064004 |
| 19200         | 31           | 6.4516          | 21                | 19201.228879  | 0.0064004 |
| 28800         | 31           | 6.4516          | 14                | 28801.843318  | 0.0064004 |
| 33600         | 31           | 6.4516          | 12                | 33602.150538  | 0.0064004 |
| 38400         | 25           | 8.0000          | 13                | 38461.538462  | 0.1602564 |
| 57600         | 31           | 6.4516          | 7                 | 57603.686636  | 0.0064004 |
| 115200        | 12           | 16.6670         | 9                 | 115740.740741 | 0.4693930 |
| 307200        | 20           | 10.0000         | 2                 | 312500.000000 | 1.7252604 |

Table 21-1. Baud Rate Settings

## 21.3 UART Registers

UART registers are accessed via memory locations 0xEF60\_0XYY where X=3 for UART 0 and X=4 for UART 1.

| UART Config Register | Address                                                              | R/W | Description                              | Reset     |
|----------------------|----------------------------------------------------------------------|-----|------------------------------------------|-----------|
| UARTX_RBR            | EF60_0X00 <sup>1</sup>                                               | R   | UART x Receiver Buffer Register          |           |
| UARTx_THR            | RTx_THR EF60_0X00 <sup>1</sup> W UART x Transmitter Holding Register |     |                                          |           |
| UARTx_IER            | EF60_0X01 <sup>1</sup>                                               | R/W | UART x Interrupt Enable Register         | 0000 0000 |
| UARTx_IIR            | EF60_0X02                                                            | R   | UART x Interrupt Identification Register | 0000 0001 |
| UARTx_FCR            | EF60_0X02                                                            | w   | UART x FIFO Control Register             | 0000 0000 |
| UARTx_LCR            | EF60_0X03                                                            | R/W | UART x Line Control Register             | 0000 0000 |
| UARTx_MCR            | EF60_0X04                                                            | R/W | UART x Modem Control Register            | 0000 0000 |
| UARTx_LSR            | EF60_0X05                                                            | R/W | UART x Line Status Register              | 0110 0000 |
| UARTx_MSR            | EF60_0X06                                                            | R/W | UART x Modem Status Register             | xxxx 0000 |
| UARTx_SCR            | EF60_0X07                                                            | R/W | UART x Scratch Register                  |           |
| UARTx_DLL            | EF60_0X00 <sup>1</sup>                                               | R/W | UART x Divisor Latch (LSB)               |           |
| UARTx_DLM            | EF60_0X01 <sup>1</sup>                                               | R/W | UART x Divisor Latch (MSB)               |           |

Table 21-2. UART Configuration Registers

1. UARTx\_LCR[DLAB] controls the function accessed through registers EF60\_0X00 and EF60\_0X01. When UARTx\_LCR[DLAB] is 0, access is enabled to the Receiver/Transmitter registers and the Interrupt Enable register. When UARTx\_LCR[DLAB] is a 1, access is enabled to the Divisor Latch registers.

The system programmer may access any of the UART registers via the processor. These registers control all UART operations including transmission and reception of data. In PPC405GP there are two UARTs, designated 0 (8-wire interface) and 1 (4-wire interface). In the following sections, the registers are specified with a generic name where x represents 0 or 1. For example, the Line Control Register appears as a UARTx\_LCR.

For UART1, two of the four wires are TX and RX. The remaining two wires can be programmed as a combination of DTR and DSR, or CTS and RTS in CPC0\_CR0(DCS:RDS). DCD and RI are not available on the 4-wire interface.

## 21.3.1 Receiver Buffer Registers (UARTx\_RBR)

0 7

Figure 21-1. UART Receiver Buffer Registers (UARTx\_RBR)

|   | 0:7 | Data bit | <br>- |      |      | <br> |  |
|---|-----|----------|-------|------|------|------|--|
| L |     | <br>     |       | <br> | <br> | <br> |  |

Note: UARTx\_RBR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.2 Transmitter Holding Registers (UARTx\_THR)



#### Figure 21-2. UART Transmitter Holding Registers (UARTx\_THR)

| 0:7 | <br>Data bit |
|-----|--------------|
|     |              |

Note: UARTX\_THR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.3 Interrupt Enable Registers (UARTx\_IER)

Five UART interrupts on four priority levels are enabled via the Interrupt Enable Register, UARTx\_IER. Any of the five interrupts can be used to surface a UART interrupt to the PPC405GP interrupt controller. Each interrupt can be enabled by setting its appropriate bit. Resetting UARTx\_IER[4:7] totally disables the UART interrupt system. Disabling an interrupt prevents it from being shown as active in the UARTx\_IIR and prevents it from signaling a UART interrupt to the PPC405GP interrupt controller. See Table 21-3, "Interrupt Priority Level," on page 21-6.



| Figure 21-3. | UART Interrupt | Enable Registers | (UARTx IER) |
|--------------|----------------|------------------|-------------|
|              |                |                  |             |

| 0:3 |       | Reserved                                                                                                                     | Always 0. |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------|-----------|
| 4   | EDSSI | Enable Modem Status Interrupt                                                                                                |           |
| 5   | ELSI  | Receiver Line Status Interrupt enable<br>0 Enable receiver line status interrupt<br>1 Disable receiver line status interrupt |           |

| 6 | ETBEI | <ul> <li>Transmitter Holding Register Empty</li> <li>Interrupt enable</li> <li>0 Enable transmitter holding register empty<br/>interrupt</li> <li>1 Disable transmitter holding register<br/>empty interrupt</li> </ul> |                                                                            |
|---|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 7 | ERBFI | Received Data Available Interrupt enable<br>0 Disable received data available interrupt<br>1 Enable received data available interrupt                                                                                   | In FIFO mode, timeout interrupts follow the enable/disable state of ERBFI. |

Note: UARTx\_IER is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.4 Interrupt Identification Registers (UARTx\_IIR)

The UART prioritizes interrupts into four levels which are recorded in the Interrupt Identification Register. The interrupt types in the order of their priority are as follows:

- 1. Receiver line status
- 2. Received data available and character timeout indication
- 3. Transmitter holding register empty
- 4. Modem status

Table 21-3 lists the interrupt priority levels.

| IIR<br>Bit 4 | IIR<br>Bit 5 | IIR<br>Bit 6 | Priority<br>Level | Interrupt Type                        | Interrupt Source                                                                                                                                                                   | Interrupt Reset Control                         |
|--------------|--------------|--------------|-------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| 0            | 1            | 1            | 1                 | Receiver Line Status                  | Overrun, Parity or Framing<br>Error, or Break Interrupt.                                                                                                                           | Read LSR.                                       |
| 0            | 1            | 0            | 2                 | Received Data<br>Available            | Receiver data available or trigger level reached.                                                                                                                                  | Read RBR, or FIFO<br>drops below trigger level. |
| 1            | 1            | 0            | 2                 | Character Timeout<br>Indication       | No characters have been<br>removed from or input to<br>the receiver FIFO during<br>the last four character<br>times and it contains at<br>least one character during<br>this time. | Read RBR.                                       |
| 0            | 0            | 1            | 3                 | Transmitter Holding<br>Register Empty | Transmitter Holding<br>Register Empty.                                                                                                                                             | Read IIR (if source of interrupt) or write THR. |
| 0            | 0            | 0            | 4                 | Modem Status                          | Clear to Send, Data Set<br>Ready, Ring Indicator or<br>Data Carrier Detect.                                                                                                        | Read MSR.                                       |

| Table | 01 0  | Interrupt | Delouite |       |
|-------|-------|-----------|----------|-------|
| lable | 21-0. | Interrupt | FIIUIII  | Level |

When the processor accesses UARTx\_IIR, the UART records new interrupts, but does not change its current contents until the access by the processor is complete. The UART indicates the highest priority interrupt pending to the PPC405GP interrupt controller via the IIR.



| 0:1 | FCI | FIFO Control Indicator<br>00 FIFOs disabled (UARTx_FCR[FC] = 0)<br>01 Reserved<br>10 Reserved<br>11 FIFOs enabled (UARTx_FCR[FC] = 1)                                                            |                                                                                                          |
|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| 2:3 |     | Reserved                                                                                                                                                                                         |                                                                                                          |
| 4:6 | IPL | Interrupt Priority Level<br>000 Priority level 4<br>001 Priority level 3<br>010 Priority level 2<br>011 Priority level 1<br>100 Reserved<br>101 Reserved<br>110 Priority level 2<br>111 Reserved | See Table 21-3.<br>Note: Priority 1 is highest priority.                                                 |
| 7   | IP  | Interrupt Pending<br>0 Interrupt is pending<br>1 No interrupt pending                                                                                                                            | When set to 0, IIR contents can be used as<br>a pointer to the appropriate interrupt<br>service routine. |

| Figure 21-4. | UART Interrupt Identification Regis | sters (UARTx IIR) |
|--------------|-------------------------------------|-------------------|
|              |                                     |                   |

Note: UARTx\_IIR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

### 21.3.5 FIFO Control Registers (UARTx\_FCR)

The FIFO control register has the same address as the IIR and is a write-only register. This register is used to perform FIFO control operations such as selecting the type of DMA signaling, setting the receiver FIFO trigger levels, clearing the FIFOs, and enabling the FIFO.





| 0:1 | RFTL | Receiver FIFO Trigger Level<br>00 1 byte<br>01 4 bytes<br>10 8 bytes<br>11 14 bytes |                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:3 |      | Reserved                                                                            |                                                                                                                                                                                                                                                                                                                     |
| 4   | DMS  | DMA Mode Select<br>0 Mode 0 = single transfer<br>1 Mode 1 = multiple transfers      | Select single or multiple transfer mode if UARTx_FCR[7] = 1.                                                                                                                                                                                                                                                        |
| 5   | TFR  | Transmitter FIFO Reset<br>0 Operation complete<br>1 Reset the transmitter FIFO      | A 1 written to this bit clears all bytes in the<br>transmitter FIFO and resets all of its<br>counter logic to 0. The transmitter shift<br>register is not cleared. This bit is self-<br>clearing.                                                                                                                   |
| 6   | RFR  | Receiver FIFO Reset<br>0 Operation complete<br>1 Reset the receiver FIFO            | A 1 written to this bit clears all bytes in the receiver FIFO and resets all of its counter logic to 0. The receiver shift register is not cleared. This bit is self-clearing.                                                                                                                                      |
| 7   | FE   | FIFO Enable<br>0 Disable FIFOs<br>1 Enable FIFOs                                    | When set to 1, both the receiver and<br>transmitter FIFOs are enabled. When set<br>to 0, both receiver and transmitter FIFOs<br>are reset. Data is automatically cleared<br>from both FIFOs when changing to and<br>from FIFO and 16450 modes.<br>Programming other bits will be ignored if<br>this bit is not a 1. |

Note: UARTX\_FCR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

### 21.3.6 Line Control Registers (UARTx\_LCR)

The system programmer uses the line control register (LCR) to specify the format of the asynchronous data communications exchange and to set the Divisor Latch Access bit. The contents of the LCR can also be read by the processor. The read capability simplifies system programming, and eliminates the need for separate storage of the line characteristics in system memory.



Figure 21-6. UART Line Control Registers (UARTx\_LCR)

|     |               | <b>J</b>                                                                                                                                                                      |                                                                                                                                                                                                                                        |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | DLAB          | Divisor Latch Access Bit<br>0 Address RBR, THR and IER with<br>LTADR2-0 for read or write operation<br>1 Address Divisor Latches with LTADR2-0<br>for read or write operation |                                                                                                                                                                                                                                        |
| 1   | SB            | Set Break<br>0 Disable Break<br>1 Enable Break                                                                                                                                | Causes a break condition to be transmitted<br>to the UART when the core is receiving.<br>SOUT is forced to the spacing state (0).<br>This bit acts only on SOUT and has no<br>effect on the transmitter logic.                         |
| 2   | SP            | Sticky Parity<br>0 Disable sticky parity<br>1 Enable sticky parity                                                                                                            | If UARTx_LCR[EPS] = 1 and<br>UARTx_LCR[PE] = 1, the parity bit is<br>transmitted and checked as 0. If<br>UARTx_LCR [EPS] = 0 and<br>UARTx_LCR[PE] = 1,the parity bit is<br>transmitted and checked as 1.                               |
| 3   | EPS           | Even Parity Select<br>0 Generate odd parity<br>1 Generate even parity                                                                                                         | This bit is significant only if<br>UARTx_LCR[PE] = 1.                                                                                                                                                                                  |
| 4   | PEN           | Parity Enable<br>0 Disable parity checking<br>1 Enable parity checking                                                                                                        |                                                                                                                                                                                                                                        |
| 5   | SBS           | Stop Bit Select<br>0 Characters have 1 stop bit<br>1 Characters have 1.5 or 2 stop bits                                                                                       | If UARTx_LCR[CL] = 00, characters have<br>1.5 stop bits. For any other value of<br>UARTx_LCR[CL], characters have 2 stop<br>bits.<br>The receiver checks the first stop bit only,<br>regardless of how many stop bits are<br>selected. |
| 6:7 | WLS0,<br>WLS1 | Word Length Select Bits 0,1<br>00 Use 5-bit characters<br>01 Use 6-bit characters<br>10 Use 7-bit characters<br>11 Use 8-bit characters                                       |                                                                                                                                                                                                                                        |

Note: UARTx\_LCR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

21-9

## 21.3.7 Modem Control Registers (UARTx\_MCR)

The interface between the modem, data set, or peripheral device emulating a modem, and the UART, is controlled by the Modem Control Register (UARTx\_MCR).



| 0:2 |      | Reserved                                                      | Always 0.                                                                                                                                                                                                                                                                                                      |
|-----|------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | LM   | Loopback Mode<br>0 Disabled                                   | Provides a local loopback feature for diagnostic testing of the UART. The following occurs:                                                                                                                                                                                                                    |
|     |      | 1 Enabled                                                     | <ol> <li>SOUT is set to the marking state (logic 1) SIN is<br/>disconnected.</li> </ol>                                                                                                                                                                                                                        |
|     |      |                                                               | 2. The output of the transmitter shift register feeds the input of the receiver shift register.                                                                                                                                                                                                                |
|     |      |                                                               | 3. The four modem control inputs DSR, CTS, RI, and DCD are disconnected.                                                                                                                                                                                                                                       |
|     |      |                                                               | <ol> <li>The four modem control outputs DTR, RTS,<br/>OUT1, and OUT2 are set to a logic 1 (their<br/>inactive state).</li> </ol>                                                                                                                                                                               |
|     |      |                                                               | <ol><li>The four modem control outputs are connected<br/>internally to the four modem control inputs.</li></ol>                                                                                                                                                                                                |
|     |      |                                                               | Transmitted data is immediately received to verify the UART transmit and receive data paths.                                                                                                                                                                                                                   |
|     |      |                                                               | Receiver and transmitter interrupts are operational.<br>Their sources are external to the UART. Also<br>operational are the modem control interrupts, but<br>their source is the low-order 4 bits of UARTX_MCR<br>instead of the modem control inputs to the UART.<br>UARTX_IER still controls the interrupts. |
| 4   | OUT2 | User Output 2<br>0 OUT2 inactive (1)<br>1 OUT2 active (0)     | Auxiliary user designated output.                                                                                                                                                                                                                                                                              |
| 5   | OUT1 | User Output 1<br>0 OUT1 inactive (1)<br>1 OUT1 active (0)     | Auxiliary user designated output.                                                                                                                                                                                                                                                                              |
| 6   | RTS  | Request To Send<br>0 RTS inactive (1)<br>1 RTS active (0)     |                                                                                                                                                                                                                                                                                                                |
| 7   | DTR  | Data Terminal Ready<br>0 DTR inactive (1)<br>1 DTR active (0) |                                                                                                                                                                                                                                                                                                                |

Note: UARTx\_MCR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.8 Line Status Registers (UARTx\_LSR)

Information concerning the data transfer is held for the processor in this register. Bits 3 through 6 are conditions that produce a receiver line status interrupt whenever the condition corresponding to the active bit is detected and the interrupt is enabled. This register is intended for read operations only and writing is not recommended.



#### Figure 21-8. UART Line Status Registers (UARTx\_LSR)

| 0 | RFE  | <ul> <li>Receiver FIFO Error Indicator</li> <li>0 In FIFO mode, reset to 0 when the processor reads the UARTx_LSR, provided there are no subsequent errors in the FIFO.</li> <li>1 There are one or more instances of parity error, framing error or break indication in the FIFO.</li> </ul>                                                                                                                                                                   | Always 0 in 16450 mode.                                                                                                                                                                                       |
|---|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | TEMT | <ul> <li>Transmitter Empty Indicator</li> <li>0 Reset to 0 whenever the THR or the transmitter shift register contain a character. In FIFO mode, it is reset to 0 whenever the transmitter FIFO or the transmitter shift register contain a character.</li> <li>1 Set to 1 when the THR and the Transmitter shift register are both empty. In FIFO mode, it is set to 1 when the transmitter FIFO and the transmitter shift register are both empty.</li> </ul> |                                                                                                                                                                                                               |
| 2 | THRE | <ul> <li>Transmitter Holding Register Empty<br/>Indicator</li> <li>O Concurrent reset to 0 with the loading of<br/>the THR by the processor. In FIFO mode<br/>it is reset to 0 when at least one byte is<br/>written to the transmitter FIFO.</li> <li>1 Set to 1 when the UART is ready to<br/>accept a new character for transmission.<br/>In FIFO mode, this bit is set when the<br/>transmitter FIFO is empty.</li> </ul>                                   | When UARTx_IER[THRE] = 1, the UART<br>issues an interrupt to the PPC405GP<br>interrupt controller. This bit is set to 1 when<br>a character is transferred from the THR to<br>the transmitter shift register. |

| 3 | BI | Break Interrupt Indicator.                                                                                                                                                                                                                                                                                                 | The full word transmission time is the time                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 |    | <ul> <li>0 Reset to 0 whenever processor reads<br/>Line Status Register (LSR).</li> <li>1 Set to 1 whenever the received data<br/>input is held at the spacing level (0) for<br/>longer than a full word transmission time.</li> </ul>                                                                                     | required for the start bit, data bits (can be<br>5–8 bits), parity and stop bits. In FIFO<br>mode, this error is revealed to the<br>processor when the character this error is<br>associated with is at the top of the FIFO.<br>Only one 0 character is loaded into the<br>receiver FIFO when a break occurs. After<br>the next valid start bit is received and has<br>gone into the marking state, the next<br>character transfer is enabled. Error causes<br>a Receiver Line Status Interrupt. |
| 4 | FE | Framing Error Indicator.<br>0 Reset to 0 whenever processor reads<br>LSR.<br>Error causes a Receiver Line Status<br>Interrupt.                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|   |    | <ol> <li>Set to 1 whenever stop bit following the<br/>last data bit or parity bit is detected as 0<br/>(spacing level).Indicates that a valid stop<br/>bit was not found in the received<br/>character.</li> </ol>                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5 | PE | <ul> <li>Parity Error Indicator.</li> <li>0 Reset to 0 whenever processor reads<br/>UARTx_LSR.</li> <li>1 Indicates that the received data<br/>character does not have the correct<br/>parity as determined by the even parity<br/>select bit (UARTx_LCR.[EPS]). Set to 1<br/>upon detection of a parity error.</li> </ul> | In FIFO mode, this error is revealed to the<br>processor when the character this error is<br>associated with is at the top of the FIFO.<br>Error causes a Receiver Line Status<br>Interrupt.                                                                                                                                                                                                                                                                                                     |
| 6 | OE | <ul> <li>Overrun Error Indicator.</li> <li>0 Reset to 0 whenever processor reads<br/>UARTx_LSR.</li> <li>1 Data in the RBR was read by the<br/>processor before the next character was<br/>transferred into the UARTx_RBR, hence<br/>the original data was lost.</li> </ul>                                                | In FIFO mode, if the incoming data<br>continues to fill the FIFO beyond the trigger<br>level, an OE occurs only after the FIFO is<br>completely full and the entire next<br>character has been received in the receiver<br>shift register. The processor is informed of<br>the OE immediately upon occurrence. The<br>character in the shift register will be<br>overwritten and will not be transferred to<br>the FIFO. Error causes a Receiver Line<br>Status Interrupt.                       |
| 7 | DR | <ul> <li>Receiver Data Ready Indicator.</li> <li>Reset to 0 when all data has been read<br/>from the receiver FIFO or the<br/>UARTx_RBR.</li> <li>An entire incoming character has been<br/>received into the UARTx_RBR or<br/>receiver FIFO.</li> </ul>                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Note: UARTx\_LSR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.9 Modem Status Registers (UARTx\_MSR)

The processor can monitor the present state of the modem (or peripheral device) control lines by reading the Modem Status Register (UARTx\_MSR). In addition, the UARTx\_MSR has four bits to indicate if any of the modem (or peripheral device) control lines have changed state.



| 0 | DCD  | Data Carrier Detect                                                                                                          | In loopback mode (UARTx_MCR[LB] is 1),<br>it is equivalent to UARTx_MCR[OUT2].                                                                                                           |
|---|------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | CRI  | Complement of Ring Indicator                                                                                                 | In loopback mode (UARTx_MCR[LB] is 1), it is equivalent to UARTx_MCR[OUT1].                                                                                                              |
| 2 | CDSR | Complement of Data Set Ready In loopback mode (UARTx_MCR[L]<br>it is equivalent to UARTx_MCR[DT                              |                                                                                                                                                                                          |
| 3 | CCTS | Complement of Clear To Send                                                                                                  | In loopback mode (UARTx_MCR[LB] is 1),<br>it is equivalent to UARTx_MCR[RTS].                                                                                                            |
| 4 | DDCD | Delta Data Carrier Detect<br>0 Set when processor reads the Modem<br>Status Register<br>1 DCD input changed state            | Indicates that the DCD input to the UART<br>has changed state since the processor last<br>read the Modem Status Register. A modem<br>status interrupt is generated.                      |
| 5 | TERI | Trailing Edge of Ring Indicator<br>0 Set when processor reads the Modem<br>Status Register<br>1 RI input changed from 0 to 1 | Indicates that the $\overline{\text{RI}}$ input to the UART<br>changed from 0 to 1 since the processor<br>last read the Modem Status Register. A<br>modem status interrupt is generated. |
| 6 | DDSR | Delta Data Set Ready<br>0 Set when processor reads the Modem<br>Status Register<br>1 DSR input changed state                 | Indicates that the DSR input to the UART<br>has changed state since the processor last<br>read the Modem Status Register. A modem<br>status interrupt is generated.                      |
| 7 | DCTS | Delta Clear To Send<br>0 Set when processor reads the Modem<br>Status Register<br>1 CTS input changed state                  | Indicates that the $\overline{\text{CTS}}$ input to the UART has changed state since the processor last read the Modem Status Register. A modem status interrupt is generated.           |

Figure 21-9. UART Modem Status Registers (UARTx\_MSR)

Note: UARTX\_MSR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.10 Scratchpad Registers (UARTx\_SCR)

A scratchpad register intended for use by the programmer as a temporary data location is provided in this UART. It does not control the UART operation in any way.

| 0 7                                            |  |
|------------------------------------------------|--|
| Figure 21-10. Scratchpad Registers (UARTx_SCR) |  |

| 0:7 | Data bits |  |
|-----|-----------|--|
|     |           |  |

Note: UARTx\_SCR is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

## 21.3.11 Divisor Latch LSB and MSB Registers (UARTx\_DLL, UARTx\_DLM)

The divisor latches are used to program the UART divisor used in generating the baud clock. A 16-bit divisor may be programmed through these registers. Access to these registers is provided by setting UARTx\_LCR[DLAB] = 1. These registers have a power-on reset value of 0.



#### Figure 21-11. UART Baud-Rate Divisor Latch (MSB) Registers (UARTx\_DLM)

|     | <br>      |  |
|-----|-----------|--|
| 0.7 | Data hita |  |
| 0.7 | Data Dits |  |
|     |           |  |

Note: UARTx\_DLM is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

| 8 | 15] |
|---|-----|
| 8 | 15  |

#### Figure 21-12. UART Baud-Rate Divisor Latch (LSB) Registers (UARTx\_DLL)

| 8:15 Data bits |  |
|----------------|--|

Note: UARTx\_DLL is shown in standard PowerPC bit notation, where 0 is the MSb and 7 is the LSb.

The UART divisor is calculated using the following formula:

UART Divisor = Serial Input Clock/(16 x Baud Rate)

For example, if the serial input clock= 11.0592MHz and a baud rate of 9600bps is required:

UART Divisor = Serial Input Clock/(16 x Baud Rate)

= 11,059,200/(16x9600)

= 72 = 0x48

For this example, UARTx\_DLM should be programmed to 0 and UARTx\_DLL register should be programmed to 0x48. Due to the error introduced by rounding, some baud rates cannot be generated at certain serial input clock frequencies. Table 21-4 lists some common baud rates and their corresponding Divisor Latch register values with a serial input clock of 11.0592MHz.

| Baud Rate (bps) | Divisor Latch MSB | Divisor Latch LSB |
|-----------------|-------------------|-------------------|
| 9600            | 0x00              | 0x48              |
| 19200           | 0x00              | 0x24              |
| 28800           | 0x00              | 0x18              |
| 38400           | 0x00              | 0x12              |
| 57600           | 0x00              | 0x0C              |

 Table 21-4. Divisor Latch Settings for Certain Baud Rates

## 21.4 FIFO Operation

#### 21.4.1 Interrupt Mode

#### 21.4.1.1 Receiver

Receiver interrupts occur as described below when the receiver FIFO and receiver interrupts are enabled by setting UARTx\_FCR[FE] = 1 and UARTx\_IER[ERBFI] = 1.

The received data available interrupt is issued when the number of characters in the FIFO has reached the trigger level programmed into UARTx\_FCR. This interrupt is reset to 0 when the FIFO character count drops below this trigger level.

The received data available indicator is issued when the number of characters in the FIFO has reached the trigger level programmed into UARTx\_FCR. This indicator is reset to 0 when the FIFO character count drops below this trigger level.

The receiver line status interrupt (UARTx\_IIR = 0xC6) is a top priority interrupt, whereas the received data available interrupt (UARTx\_IIR = 0xC4) is a second priority interrupt.

Data Ready (UARTx\_LSR[DR]) is set as soon as a character is transferred from the shift register to the receiver FIFO. This bit is reset when the FIFO is empty.

Receiver timeout interrupts will occur as described below when the receiver FIFO and receiver interrupts are enabled by setting UARTx\_FCR[FE] = 1 and UARTx\_IER[ERBFI] = 1.

A FIFO timeout will occur when:

At least one character is in the receiver FIFO, no serial characters have been received for four serial character time periods, and the processor has not read the FIFO for four serial character time periods. A serial character time period is as follows:

1/(baud rate) x (# start bits + word length + # parity bits + # stop bits)

For example, the serial character time period for an 8-bit word with one parity bit, two stop bits at 56K baud is as follows:

Preliminary

 $1/(56000) \times (1 + 8 + 1 + 2) = 214.3 \mu s$ 

So the timeout would occur after 857.1 µs, if the above conditions hold.

When a timeout interrupt has occurred, it is cleared and the timer is reset when the processor reads one character from the receiver FIFO.

When a timeout interrupt has not occurred, the timer is reset after a new serial character is received or the processor reads the receiver FIFO.

#### 21.4.1.2 Transmitter

Transmitter interrupts occur, as described below, when the transmitter FIFO and transmitter interrupts are enabled by setting UARTx\_FCR[FE] = 1 and UARTx\_IER[ETBEI] = 1.

The transmitter holding register interrupt (UARTx\_IIR = 0xC2) occurs when transmit FIFO is empty, and is cleared as soon as the transmitter holding register is written to or the IIR is read. One to 16 characters may be written to the transmitter FIFO while servicing this interrupt.

The transmitter FIFO empty indications are delayed by one character time minus the last stop bit time whenever the following event occurs: UARTx\_LSR[THRE] = 1 and there were less than two bytes simultaneously present in the transmit FIFO since the last UARTx\_LSR[THRE] = 1. If UARTx\_FCR[FE] = 1 (FIFOs enabled), the first transmitter interrupt after changing UARTx\_FCR[FE] is immediate.

Receiver FIFO trigger level interrupts, received data available interrupts, and character timeouts all have equivalent second interrupt priority. Current transmitter holding register empty interrupt and Transmit FIFO empty have equivalent third interrupt priority.

#### 21.4.2 Polled Mode

When UARTx\_FCR[FE] = 1 (FIFOs enabled), and UARTx\_IER[5:7] are all set to 0 (interrupts disabled), the UART is in FIFO polled mode of operation. The receiver and transmitter are controlled separately, so either can be in polled mode of operation. In polled mode, the user program must check the UARTx\_LSR to see the status of the receiver and/or transmitter.

UARTx\_LSR3:6 specifies which errors (if any) have occurred. Character status errors are handled in the same way as in interrupt mode. Since UARTx\_IER[ELSI] = 0, the IIR is not affected. UARTx\_LSR[DR] is set as long as there is at least one character in the receiver FIFO. UARTx\_LSR[THRE] indicates if the transmitter FIFO is empty. UARTx\_LSR[TEMT] indicates if the transmitter FIFO and the transmitter shift register are empty. UARTx\_LSR[RFE] indicates if there are any errors in the receiver FIFO.

In FIFO polled mode, there are no character timeout or trigger levels; however, the FIFOs are still capable of holding characters.

## 21.5 UART and Sleep Mode

Both UARTs can be placed in sleep mode via the UART sleep bits in the CPC0\_ER register (CPC0\_ER[UART0:UART1]). The most common usage would be to save a little power if one or both of the UARTs were not going to be used.

Using sleep mode dynamically requires careful software control to make sure the UARTs are idle before putting them to sleep.

## 21.6 DMA Operation

The DMA controller can be configured to perform DMA operations using UART0, which appears as an 8-bit peripheral to the DMA controller. When selected, the UART receiver is internally wired to the DMAReq and DMAAck signals of DMA channel 2, and the transmitter is internally wired to the DMAReq and DMAAck signals of DMA channel 3.

The UART can be operated in FIFO mode or non-FIFO mode. In FIFO mode, the transfers can be done as single transfers (DMA mode 0) or multiple transfers (DMA mode 1), depending on the setting of the DMS field in the FIFO Control Register (FCR). In non-FIFO mode, DMA transfers are performed using single transfers, using the UART's DMA mode 0. This section describes proper UART0 DMA programming. For more information on general DMA programming, see Chapter 18, "Direct Memory Access Controller," on page 18-1.

## 21.6.1 Chip Control Register 0 (CPC0\_CR0)

Only CPC0\_CR0 fields related to UART are shown in Figure 21-13. Other non-related functions are not shown here.



| 0:18 |     | Reserved.                                                                                                  |
|------|-----|------------------------------------------------------------------------------------------------------------|
| 19   | DCS | DSR/CTS select<br>0 DSR is selected.<br>1 CTS is selected.                                                 |
| 20   | RDS | RTS/DTR select<br>0 RTS is selected.<br>1 DTR is selected.                                                 |
| 21   | DTE | DMA Transmit Enable for UART0<br>0 DMA transmit channel is disabled.<br>1 DMA transmit channel is enabled. |
| 22   | DRE | DMA Receive Enable for UART0<br>0 DMA receive channel is disabled.<br>1 DMA receive channel is enabled.    |

Figure 21-13. Chip Control Register 0 (CPC0\_CR0)

| 23    | DAEC       | DMA Allow Enable Clear for UABT0                     |                                               |
|-------|------------|------------------------------------------------------|-----------------------------------------------|
| 23    | DAEC       | 0 DTE and DRE for UABT0 are not cleared              |                                               |
|       |            | when the UART receives a corresponding               |                                               |
| 1     |            | terminal count                                       |                                               |
|       |            | 1 DTE and DRE for UABT0 are cleared                  |                                               |
|       |            | when the UART receives a corresponding               |                                               |
|       |            | terminal count.                                      |                                               |
|       | 11050      |                                                      |                                               |
| 24    | U0EC       | Select External Clock for UART0                      |                                               |
|       |            | 0 UART0 uses the internally derived serial<br>clock. |                                               |
|       |            |                                                      |                                               |
|       |            | 1 UART0 uses the UARTSerClk external                 |                                               |
|       |            | serial clock input.                                  |                                               |
| 25    | U1EC       | Select External Clock for UART1                      |                                               |
|       |            | 0 UART1 uses the internally derived serial           |                                               |
|       |            | clock.                                               |                                               |
|       |            | 1 UART1 uses the UARTSerClk external                 |                                               |
|       |            | serial clock input.                                  |                                               |
| 26:30 | UDIV       | UART Divisor                                         | UDIV specifies the divider ratio between the  |
|       |            | 00000 Divide by 1                                    | CPU and UART serial clock frequencies.        |
|       |            | 00001 Divide by 2                                    | UART0 and UART1 can use a serial clock        |
|       |            | 00010 Divide by 3                                    | frequency derived from the CPU clock          |
|       |            | •                                                    | frequency divided by UDIV, or use the         |
|       |            | •                                                    | UARTSerClk external serial clock input. For   |
|       |            |                                                      | example, if the CPU runs at 200MHz, a         |
|       |            | 11110 Divide by 31                                   | UDIV of 20 sets the serial clock frequency at |
|       |            | 11111 Divide by 32                                   | 10MHz.                                        |
|       |            |                                                      | Note: Maximum serial clock frequency is       |
|       |            |                                                      | slightly less than 1/2× OPB frequency.        |
| 31    | AND STREET | Reserved.                                            |                                               |

### 21.6.2 Transmitter DMA Mode

The UART0 Transmit Channel Enable field of the Chip Control Register 0, CPC0\_CR0[DTE], controls the use of the serial port transmitter as a DMA destination. For the transmitter in DMA mode 0, when the FIFOs are disabled or the FIFOs are enabled and there are no characters in the TX FIFO or Transmit Holding Register (THR), the DMA request goes active. Once activated, the DMA request goes inactive after the first character is loaded into the TX FIFO or THR. For the transmitter in DMA mode 1, when FIFOs are enabled and there is at least one unfilled position in the TX FIFO, the DMA request goes active. This signal will become inactive when the TX FIFO is completely full. To operate in this mode, DMA Channel Control Register 3 (DMA0\_CR3) must be configured to accept DMA requests from an internal source. Setting the Peripheral Location (PL) bit of DMA0\_CR3 to a logic 1 configures DMA channel to accept DMA requests from UART0. Table 21-5 lists required register

settings for UART0 transmit transfers. Other DMA registers and register fields must be programmed appropriately, see Chapter 18, "Direct Memory Access Controller," on page 18-1 for more information.

| Register [Field]     | Meaning                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| CPC0_CR0[DTE]=1      | UARTO DMA Transmit channel is enabled using DMA channel 3.                                                                          |
| CPC0_CR0[DAEC]       | Set to 0 to not clear CPC0_CR0[DTE] enable when terminal count is reached, set to 1 to clear enable when terminal count is reached. |
| DMA0_CR3[TD]=0       | DMA Channel 3 transfer direction is from memory to peripheral.                                                                      |
| DMA0_CR3[PL]=1       | DMA Channel 3 peripheral is on the OPB (UART0).                                                                                     |
| DMA0_CR3[PW]=00      | Peripheral width is byte (8 bits).                                                                                                  |
| DMA0_CR3[TM]=00      | DMA Channel 3 is in peripheral mode.                                                                                                |
| DMA0_CR3[PWC]=000010 | Peripheral Wait cycles, how long the internal DMAck is active. Three cycles are required.                                           |
| DMA0_CR3[PHC]=000    | Peripheral Hold Cycles are 0.                                                                                                       |
| DMA0_CR3[ETD]=1      | EOT/TC is programmed as terminal count output.                                                                                      |
| UART0_FCR[DMS]       | Set to 0 for a single DMA transfer or 1 for multiple DMA transfers.                                                                 |

Table 21-5. UART0 Transmitter DMA Mode Register Field Settings

**Note:** When using DMA Channel 3 for UART0 transmitter transfers, external DMA transfers cannot be performed on this channel.

### 21.6.3 Receiver DMA Mode

The UART0 Receive Enable field of the Chip Control Register 0, CPC0\_CR0[DRE], controls the use of the serial port receiver as a DMA source. For the receiver in DMA mode 0, when there is at least one character in the RX FIFO or Receive Buffer Register, RBR, the DMA request goes active. Once activated, the DMA request goes inactive when there are no more characters in the FIFO or RBR. For the receiver in DMA mode 1, when the FIFOs are enabled and the trigger level or the timeout has been reached, the DMA request goes active. Once activated, it will go inactive when there are no more characters in the RX FIFO or RBR. To operate in this mode, DMA Channel Control Register 2 (DMA0\_CR2) must be configured to accept DMA requests from an internal source. Setting the Peripheral Location (PL) bit of DMA0\_CR2 to a logic 1 configures DMA channel to accept DMA requests from UART0. Table 21-6 lists required register settings for UART0 receiver transfers. Other DMA registers and register fields must be programmed appropriately, see Chapter 18, "Direct Memory Access Controller," on page 18-1 for more information.

| Register [Field]     | Meaning                                                                                                                             |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| CPC0_CR0[DRE]=1      | UART0 DMA Receiver channel is enabled using DMA channel 2.                                                                          |
| CPC0_CR0[DAEC]       | Set to 0 to not clear CPC0_CR0[DRE] enable when terminal count is reached, set to 1 to clear enable when terminal count is reached. |
| DMA0_CR2[TD]=1       | DMA Channel 2 transfer direction is from peripheral to memory.                                                                      |
| DMA0_CR2[PL]=1       | DMA Channel 2 peripheral is on the OPB (UART0).                                                                                     |
| DMA0_CR2[PW]=00      | Peripheral width is byte (8 bits).                                                                                                  |
| DMA0_CR2[TM]=00      | DMA Channel 2 is in peripheral mode.                                                                                                |
| DMA0_CR3[PWC]=000010 | Peripheral Wait cycles, how long the internal DMAAck is active. Three cycles are required.                                          |
| DMA0_CR2[PHC]=000    | Peripheral Hold Cycles are 0.                                                                                                       |
| DMA0_CR2[ETD]=1      | EOT/TC is programmed as terminal count output.                                                                                      |
| UART0_FCR[DMS]       | Set to 0 for a single DMA transfer or 1 for multiple DMA transfers.                                                                 |

**Note:** When using DMA Channel 2 for UART0 receiver transfers, external DMA transfers cannot be performed on this channel.

# **Chapter 22. IIC Bus Interface**

The PPC405GP provides an inter-integrated circuit (IIC) bus interface complying with specifications contained in the Philips<sup>®</sup> Semiconductors document *The I<sup>2</sup>C-bus and how to use it (including specifications)* (1995 update).

The IIC bus is a two-wire, bi-directional, open-drain, low-speed serial interface. The serial clock (IICSCL) and serial data (IICSDA) lines are bidirectional, to support multiple bus masters and to mix high- and low-speed devices on the same bus.

The IIC interface (referred to as IIC to distinguish it from the Philips I<sup>2</sup>C bus) supports the following standard and enhanced features:

- 100-kHz and 400-kHz operation
- 8-bit data transfers
- 7-bit and 10-bit addressing
- Slave transmitter and receiver
- · Master transmitter and receiver
- Multiple bus masters

The IIC interface can switch between 7-bit and 10-bit addressing under program control.

# 22.1 Addressing

The IIC interface supports 7-bit and 10-bit addressing for master and slave transfers.

Addressing is described in detail in "IICO Low Master Address Register" on page 22-5, "IICO High Master Address Register" on page 22-6, "IICO Low Slave Address Register" on page 22-14, and "IICO High Slave Address Register" on page 22-14.

Descriptions of addressing modes and address formats follow.

### 22.1.1 Addressing Modes

For master transfers, the address mode (AMD) field of the IIC Control register (IIC0\_CNTL) controls whether 7-bit or 10-bit addresses are used. If IIC0\_CNTL[AMD] = 0, addresses contain 7 bits; if IIC0\_CNTL[AMD] = 1, addresses contain 10 bits.

For slave transfers, the contents of the IIC0 High Slave Address register (IIC0\_HSADR) determines whether 7-bit or 10-bit addressing is used. If IIC0\_HSADR = 0b00000000, 7-bit addressing is used. If 10-bit addressing is to be used for slave transfers, IIC0\_HSADR = 0b11110*yyx*, where *yy* contains the high-order bits of the 10-bit address, and x is a don't care.

Programming Note: For slave transfers, IIC0\_CNTL[AMD] does not control addressing mode.

#### 22.1.2 Seven-Bit Addresses

Figure 22-1 illustrates a 7-bit address. For master transfers, the address bits 0 through 6 (A0:A6) are read from IIC0\_LMADR. For slave transfers, A0:A6 are read from IIC0\_LSADR. Bit 7 of address byte 0 contains a transfer type bit provided by the IIC interface.





#### 22.1.3 Ten-Bit Addresses

Figure 22-2 illustrates a 10-bit address. A0:A1 of address byte 0 are read from IIC0\_HMADR[A6:A7] (for master transfers) or IIC0\_HSADR[A6:A7] (for slave transfers). These are the two highest-order address bits transmitted on the IIC bus. Bit 7 of address byte 0 contains a transfer type bit provided by the IIC interface.

For 10-bit addressing for master or slave transfers, respectively, IIC0\_HMADR[A0:A4] and IIC0\_HSADR [A0:A4] must contain 0b11110.

The low-order byte of the 10-bit address, contained in A0:A7 of address byte 1, are read from IIC0\_LMADR or IIC0\_LSADR for master or slave transfers, respectively.



Figure 22-2. 10-Bit Addressing

### 22.2 IIC Registers

IIC registers are accessed at memory locations 0xEF600500-0xEF600510 in the PPC405GP.

Table 22-1 lists the IIC registers. Descriptions of the registers, in the listed order, follow in "IIC Register Descriptions" on page 22-3.

| Register                | Mnemonic   | PPC405GP<br>Memory Map | Address | Access | Effect of<br>Reset | Bits |
|-------------------------|------------|------------------------|---------|--------|--------------------|------|
| IIC0 Master Data Buffer | IIC0_MDBUF | 0xEF60 0500            | 0x0     | R/W    | Cleared            | 8,16 |
| Reserved                |            | 0xEF60 0501            | 0x1     |        |                    |      |

| Register                                  | Mnemonic        | PPC405GP<br>Memory Map | Address | Access | Effect of<br>Reset | Bits |
|-------------------------------------------|-----------------|------------------------|---------|--------|--------------------|------|
| IIC0 Slave Data Buffer                    | IIC0_SDBUF      | 0xEF60 0502            | 0x2     | R/W    | Cleared            | 8,16 |
| IIC0 Reserved                             |                 | 0xEF60 0503            | 0x3     |        |                    |      |
| IIC0 Low Master Address                   | IIC0_LMADR      | 0xEF60 0504            | 0x4     | R/W    | No                 | 8    |
| IIC0 High Master Address                  | IIC0_HMADR      | 0xEF60 0505            | 0x5     | R/W    | No                 | 8    |
| IIC0 Control                              | IIC0_CNTL       | 0xEF60 0506            | 0x6     | R/W    | Cleared            | 8    |
| IIC0 Mode Control                         | IIC0_MDCNTL     | 0xEF60 0507            | 0x7     | R/W    | Cleared            | 8    |
| IIC0 Status                               | IIC0_STS        | 0xEF60 0508            | 0x8     | R/W    | Cleared            | 8    |
| IIC0 Extended Status                      | IIC0_EXTSTS     | 0xEF60 0509            | 0x9     | R/W    | Cleared            | 8    |
| IIC0 Low Slave Address                    | IIC0_LSADR      | 0xEF60 050A            | 0xA     | R/W    | No                 | 8    |
| IIC0 High Slave Address                   | IIC0_HSADR      | 0xEF60 050B            | 0xB     | R/W    | No                 | 8    |
| IIC0 Clock Divide                         | IIC0_CLKDIV     | 0xEF60 050C            | 0xC     | R/W    | Cleared            | 8    |
| IIC0 Interrupt Mask                       | IIC0_INTRMSK    | 0xEF60 050D            | 0xD     | R/W    | Cleared            | 8    |
| IIC0 Transfer Count                       | IIC0_XFRCNT     | 0xEF60 050E            | 0xE     | R/W    | Cleared            | 8    |
| IIC0 Extended Control and<br>Slave Status | IIC0_XTCNTLSS   | 0xEF60 050F            | 0xF     | R/W    | Cleared            | 8    |
| IIC0 Direct Control                       | IIC0_DIRECTCNTL | 0xEF60 0510            | 0x10    | R/W    | 0x0f               | 4    |

Table 22-1. IIC Registers

# 22.3 IIC Register Descriptions

The following sections contains the bit definitions for the various registers in the IIC interface.

### 22.3.1 IIC0 Master Data Buffer

The IIC0 Master Data Buffer (IIC0\_MDBUF) is a 1-byte  $\times$  4-byte first-in/first-out (FIFO) buffer. A byte written to IIC0\_MDBUF is placed into the fourth FIFO stage. If the third FIFO stage is empty, the data is moved into the third stage at the next OPB clock. This process is repeated for the second and first FIFO stages at each successive OPB clock. The byte moves through the buffer until it reaches the deepest unoccupied stage of the FIFO. The buffer data is either written on the IIC bus when the IIC interface performs a write, or is received from the IIC bus when the IIC interface performs a read.

Figure 22-3 illustrates the IIC0\_MDBUF.



| Figure 22-3. IIC0 Master Data Buffer (IIC0_MDBUF) | Figure 22-3. | IIC0 Master Da | ata Buffer (IIC0 | MDBUF) |
|---------------------------------------------------|--------------|----------------|------------------|--------|
|---------------------------------------------------|--------------|----------------|------------------|--------|

| 0 | Data bit |      |  |
|---|----------|------|--|
| 1 | Data bit | <br> |  |
| 2 | Data bit | <br> |  |
| 3 | Data bit |      |  |
| 4 | Data bit | <br> |  |

| 5 | Data bit |  |
|---|----------|--|
| 6 | Data bit |  |
| 7 | Data bit |  |

IIC0\_MDBUF is cleared (flushed and set to empty) whenever the IIC interface is reset, or IIC0\_MDCNTL[FMB] = 1. Figure 22-4 shows the four FIFO stages.





When IICO\_MDBUF is written with a byte, the byte is placed in the FIFO. The hardware pushes the byte into the deepest unoccupied stage in the FIFO and advances one FIFO stage per clock. Thus, if the FIFO is empty, four clocks are needed (one per stage) for the byte to walk to the first stage of the FIFO. This timing is important to consider when reading the IICO\_MDBUF immediately after data is written. When a master transfer is requested, the IIC interface handles this latency.

If a byte is written to IIC0\_MDBUF while the FIFO is full, the byte is discarded and not placed into the FIFO.

If IICO\_MDBUF is written with two bytes in a halfword access, and there is space in the FIFO, byte 0 of the halfword is placed ahead of byte 1 in the FIFO. The MSB, byte 0, is written to the IIC bus first, followed by the LSB, byte 1.

IIC0\_\_MDBUF receives data from the IIC bus when the requested master transfer is a read. The first byte received is the first byte read by software from IIC0\_MDBUF.

For halfword reads the first byte received is MSB ,byte 0, and the following byte is LSB, byte 1. When an empty FIFO is read, the byte (or halfword) most recently read is returned.

Care must be taken not to start a requested master operation while there is data in IICO\_MDBUF. If, for example, a master read transfer is requested and obsolete data is in IICO\_MDBUF, the obsolete data would be presented, to the requesting software, as data read by the requested transfer.

### 22.3.2 IIC0 Slave Data Buffer

The IICO Slave Data Buffer (IICO\_SDBUF) is a copy of IICO\_MDBUF. The data contained in the slave buffer is either received from the IIC bus when the IIC interface is addressed as a slave during a write, or is written on the IIC bus when the IIC interface is addressed as a slave during a read operation.

IIC0\_SDBUF works in the same way as IIC0\_MDBUF, except that IIC0\_SDBUF is used only to store data sent or received in slave transfers on the IIC bus. This enables overlapping slave and master transfers on the IIC bus.

Bit assignments for the IIC0\_MDBUF and IIC0\_SDBUF are identical, as illustrated in Figure 22-5.



Figure 22-5. IIC0 Slave Data Buffer (IIC0\_SDBUF)

| 0 | Data bit |  |
|---|----------|--|
| 1 | Data bit |  |
| 2 | Data bit |  |
| 3 | Data bit |  |
| 4 | Data bit |  |
| 5 | Data bit |  |
| 6 | Data bit |  |
| 7 | Data bit |  |

IIC0\_SDBUF is cleared (flushed and set to empty) whenever the IIC interface is reset, or IIC0\_MDCNTL[FSB] = 1.

#### 22.3.3 IIC0 Low Master Address Register

The IIC0 Low Master Address (IIC0\_LMADR) and IIC0 High Master Address Register (IIC0\_HMADR) form addresses that the IIC interface transmits on the IIC bus.

**Programming Note:** IIC0\_HMADR is used only for 10-bit addressing.

When IIC0\_CNTL[AMD] = 0 (7-bit addressing), only IIC0\_LMADR is written. IIC0\_LMADR[A0:A6] form the address transmitted on the IIC bus; IIC0\_LMADR[A7] is a don't care. When IIC0\_CNTL[AMD] = 1 (10-bit addressing), IIC0\_LMADR[A0:A7] form the second byte address transmitted on the IIC bus.

Figure 22-6 illustrates the IIC0\_LMADR.



| Figure 22-6. IIC0 Low Master Address Registe | (IIC0_LMADR) |
|----------------------------------------------|--------------|
|----------------------------------------------|--------------|

|   |    |               | U V         |
|---|----|---------------|-------------|
| 0 | A0 | Address bit 0 |             |
| 1 | A1 | Address bit 1 |             |
| 2 | A2 | Address bit 2 |             |
| 3 | A3 | Address bit 3 | · · · · · · |
| 4 | A4 | Address bit 4 |             |
| 5 | A5 | Address bit 5 |             |

| 6 | A6 | Address bit 6 | LSb for 7-bit addresses                                     |
|---|----|---------------|-------------------------------------------------------------|
| 7 | A7 | Address bit 7 | LSb for 10-bit addresses; don't care for<br>7-bit addresses |

#### 22.3.4 IIC0 High Master Address Register

IIC0 High Master Address Register (IIC0\_HMADR) is not used for 7-bit addressing.

When IIC0\_CNTL[AMD] = 1 (10-bit addressing), IIC0\_HMADR must be programmed to 0b1111 0yyx, where yy are the high-order bits of a 10-bit address and x is a don't care.

Thus, in 10-bit address mode, IIC0\_HMADR[A5:A6] are the two highest-order bits of the 10-bit address and IIC0\_HMADR[A7] is a don't care. IIC0\_LMADR contains the low-order byte of the 10-bit address.

Figure 22-7 illustrates the IIC0\_HMADR.



#### Figure 22-7. IIC0 High Master Address Register (IIC0\_HMADR)

| 0 | A0 | Address bit 0 | 1 for 10-bit addresses           |  |
|---|----|---------------|----------------------------------|--|
| 1 | A1 | Address bit 1 | 1 for 10-bit addresses           |  |
| 2 | A2 | Address bit 2 | 1 for 10-bit addresses           |  |
| 3 | A3 | Address bit 3 | 1 for 10-bit addresses           |  |
| 4 | A4 | Address bit 4 | 0 for 10-bit addresses           |  |
| 5 | A5 | Address bit 5 | MSb for 10-bit addresses         |  |
| 6 | A6 | Address bit 6 | Next to MSb for 10-bit addresses |  |
| 7 | A7 | Address bit 7 | Don't care for 10-bit addresses  |  |

#### 22.3.5 IIC0 Control Register

The IIC0 Control Register (IIC0\_CNTL) starts and stops IIC interface master transfers on the IIC bus. When a transfer begins, the IIC interface uses the values in IIC0\_CNTL to determine the type and size of the transfer.

**Programming Note:** IIC0\_CNTL *must* be the last register programmed. Whenever IIC0\_CNTL[PT] = 1, the IIC interface attempts to perform the requested transfer, using values set in other registers. Note that not all IIC registers must be programmed before performing each transfer.

During transfers, and after transfers finish, software can read the IIC0\_STS and IIC0\_EXTSTS registers to determine the state of the IIC interface and the IIC bus.

Only IIC0\_CNTL[PT] is cleared when a requested master transfer is complete; the remaining bits are not affected.

Figure 22-8 illustrates the IIC0\_CNTL.



| Figure 22-8. IIC | ) Control | Register ( |  | CNTL) |  |
|------------------|-----------|------------|--|-------|--|
|------------------|-----------|------------|--|-------|--|

| 0   | НМТ  | Halt Master Transfer<br>0 Normal transfer operation.<br>1 Issue Stop signal on the IIC bus as soon<br>as possible to halt master transfer. | If no transfer is in progress, no action is<br>taken.<br>IIC0_CNTL[PT] needs not be set.<br>If IIC0_MDCNTL[EINT] = 1, an interrupt is<br>generated. |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | AMD  | Addressing Mode<br>0 Use 7-bit addressing.<br>1 Use 10-bit addressing.                                                                     | Does not affect slave transfers.                                                                                                                    |
| 2:3 | ТСТ  | Transfer Count<br>00 Transfer one byte.<br>01 Transfer two bytes.<br>10 Transfer three bytes.<br>11 Transfer four bytes.                   |                                                                                                                                                     |
| 4   | RPST | Repeated Start<br>0 Normal start operation<br>1 Use repeated Start function to start<br>transfer.                                          |                                                                                                                                                     |
| 5   | СНТ  | Chain Transfer<br>O Transfer is only or last transfer.<br>1 Transfer is one of a sequence of transfers<br>(but not last in sequence).      | Completion of a requested transfer causes<br>a Stop signal to be issued on the IIC bus.                                                             |
| 6   | RW   | Read/Write<br>0 Transfer is a write.<br>1 Transfer is a read.                                                                              |                                                                                                                                                     |
| 7   | PT   | Pending Transfer<br>0 Most recent requested transfer is<br>complete.<br>1 Start transfer if bus is free.                                   |                                                                                                                                                     |

Table 22-2 summarizes IIC interface operation for settings of IIC0\_CNTL[HMT, RPST, CHT, PT] x is a don't care.

|     | llC0_C | Resulting Action on IIC Bus |    |                                             |
|-----|--------|-----------------------------|----|---------------------------------------------|
| HMT | RPST   | СНТ                         | PT | and Inside IIC Interface                    |
| 0   | x      | x                           | 0  | No action taken                             |
| 0   | 0      | 1                           | 1  | Start, Transfer, ACK on last byte,<br>Pause |
| 0   | 0      | 0                           | 1  | Start, Transfer, NACK on last byte, Stop    |
| 1   | x      | X                           | x  | NACK on current byte, Stop                  |
| 0   | 1      | x                           | 1  | Start, Transfer, NACK on last byte, Wait    |

| Table 22-2. IIC Response to IIC0_CNTL Field Settings |
|------------------------------------------------------|
|------------------------------------------------------|

Settings of IIC0\_CNTL[HMT, RPST, CHT, PT] result in the following actions.

Start IIC Start condition generated, if the IIC interface was stopped or waiting.

Stop IIC Stop condition generated; IIC interface enters the Stop condition.

ACK IIC Acknowledge condition generated.

NACK IIC Not Acknowledge condition generated, if performing a read.

Transfer Requested bytes are transferred.

Pause IIC interface enters the Pause state.

Wait IIC interface enters the Wait state.

IIC0\_CNTL[HMT] overrides IIC0\_CNTL[RPST, CHT].

IIC0\_CNTL[RPST, PT] overrides IIC0\_CNTL[CHT].

#### 22.3.6 IIC0 Mode Control Register

The IIC0 Mode Control Register (IIC0\_MDCNTL) sets the major modes of operation on the IIC bus. In addition, IIC0\_MDCNTL can force the data buffers into the empty state.

In typical applications, IIC0\_MDCNTL is configured once, during software initialization. Applications providing complex error handling may reconfigure this register more often.

**Programming Note:** IIC0\_CLKDIV must be initialized before IIC0\_MDCNTL. IIC0\_LSADR and IIC0\_HSADR should also be configured before IIC0\_MDCNTL.

Note that the IIC hardware does not implement time-out functions on the IIC bus. Such functions must be implemented, in software, by setting IIC0\_CNTL[HMT] = 1, or setting IIC0\_XTCNTLSS[SRST] = 1.

Regarding IIC0\_MDCNTL[HSCL], a "slave not ready" condition occurs during a slave receive operation, if a slave has no free space in its slave data buffer at the start of a write operation, or if the slave data buffer fills during the write. In a slave transmit operation, a slave not ready condition occurs if a slave has no data in its slave data buffer at the start of a read operation, or if the slave data buffer becomes empty during the read.

Using IIC0\_MDCNTL[HSCL] to handle slave not ready conditions can affect system performance. A slave holding the IICSCL signal low guarantees data delivery to or from the requesting master, but prevents other masters from performing transfers over the IIC bus. There is no general rule for handling slave not ready conditions; each system has its own requirements.

Figure 22-9 illustrates the IIC0\_MDCNTL.



|   |      | Figure 22-9. IICO Mode Control Regi                                                                                                                                                                                    | Ister (IICO_MDCNTL)                                                                                          |
|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| 0 | FSDB | Flush Slave Data Buffer<br>0 Normal operation<br>1 Set slave data buffer to empty.                                                                                                                                     | Cleared after buffer is emptied.                                                                             |
| 1 | FMDB | Flush Master Data Buffer<br>0 Normal operation<br>1 Set master data buffer to empty.                                                                                                                                   | Cleared after buffer is emptied.                                                                             |
| 2 | EGC  | Enable General Call<br>0 Ignore general call on IIC bus.<br>1 Respond to general call on IIC bus.                                                                                                                      | IIC0_MDCNTL[ESM] overrides this field; if<br>IIC0_MDCNTL[ESM] = 1, a general call is<br>ignored.             |
| 3 | FSM  | Fast/Standard Mode<br>0 IIC transfers run at 100 kHz (standard<br>mode).<br>1 IIC transfers run at 400 kHz (fast mode).                                                                                                |                                                                                                              |
| 4 | ESM  | Enable Slave Mode<br>0 Slave transfers are ignored.<br>1 Slave transfers are enabled.                                                                                                                                  | Program IIC0_LSADR and IIC0_HSADR before setting this field.                                                 |
| 5 | EINT | Enable Interrupt<br>0 Interrupts are disabled.<br>1 Enables interrupts for interrupts enabled<br>in IIC0_INTRMSK.                                                                                                      |                                                                                                              |
| 6 | EUBS | <ul> <li>Exit Unknown IIC Bus State</li> <li>0 Normal operation.</li> <li>1 IIC bus control state machine exits<br/>unknown bus state, if in an unknown<br/>state.</li> </ul>                                          | If the IIC bus control state machine is in a<br>known state, setting<br>IIC0_MDCNTL[EUBS] = 1 has no effect. |
| 7 | HSCL | <ul> <li>Hold IIC Serial Clock Low</li> <li>0 If slave is not ready, issue a NACK in response to slave transfer request.</li> <li>1 If slave is not ready, hold the IICSCL signal low until slave is ready.</li> </ul> | This field is used only when in slave mode.                                                                  |

#### Figure 22-9. IIC0 Mode Control Register (IIC0\_MDCNTL)

#### 22.3.7 IIC0 Status Register

The IIC0 Status register (IIC0\_STS) provides a summary of the state of the IIC interface and the status of any previously requested master transfer.

During and after transfers, software can read the IIC0\_STS and IIC0\_EXTSTS registers to determine the state of the IIC interface and the IIC bus.

**Programming Note:** IICO\_STS should be the first register read by an interrupt or error handler routine. IICO\_STS can also be read in a polling loop if software does not use the IIC interrupts.

Software must clear IIC0\_STS before requesting another master transfer, except for IIC0\_STS[SSS]. Because IIC0\_STS[SSS] involves slave transfers, it can remain set.

Figure 22-10 illustrates IIC0\_STS.



| 0 | SSS  | Slave Status Set<br>0 No slave operations are in progress.<br>1 Slave operation is in progress.                                                                                            | Read-only; this field is set when any of the<br>following fields are set:<br>IIC0_XTCNTLSS[SRC, SRRS, SWC,<br>SWRS].                  |
|---|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 1 | SLPR | Sleep Request<br>0 Normal operation.<br>1 Sleep mode (CPC0_ER[IIC] = 1).                                                                                                                   | Read-only. The IIC interface is awakened<br>when a start signal is detected on the IIC<br>bus or when the CPC0_ER[IIC] is<br>cleared. |
| 2 | MDBS | Master Data Buffer Status<br>0 Master data buffer is empty.<br>1 Master data buffer contains data.                                                                                         | Read-only.                                                                                                                            |
| 3 | MDBF | Master Data Buffer Full<br>0 Master data buffer is not full.<br>1 Master data buffer is full.                                                                                              | Read-only.                                                                                                                            |
| 4 | SCMP | <ul> <li>Stop Complete</li> <li>0 No request to halt transfer, or master data transfer, is complete.</li> <li>1 Request to halt transfer, or master data transfer, is complete.</li> </ul> | To clear IIC0_STS[SCMP], set<br>IIC0_STS[SCMP] = 1.                                                                                   |
| 5 | ERR  | Error<br>0 No error has occurred.<br>1 One of the following fields is set:<br>IIC0_EXTSTS[LA, ICT, XFRA] = 1.                                                                              | Read-only.                                                                                                                            |

#### Figure 22-10. IIC0 Status Register (IIC0\_STS)

| 6 | IRQA | <ul><li>IRQ Active</li><li>0 No IIC interrupt has been sent to the universal interrupt controller (UIC).</li><li>1 An IIC interrupt has been sent to the UIC.</li></ul> | To clear IIC0_STS[IRQA], set<br>IIC0_STS[IRQA] = 1.<br>If IIC0_MDCNTL[EINT] = 0, then<br>IIC0_STS[IRQA] is not set. |  |  |
|---|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|
| 7 | PT   | Pending Transfer<br>0 No transfer is pending, or transfer is in<br>progress.<br>1 Transfer is pending.                                                                  | Read-only.                                                                                                          |  |  |

The Error and Pending Transfer, IIC0\_STS[ERR, PT], bit fields indicate the success or failure of the requested transfer. Table 22-3 interprets the transfer status for all possible combinations of the IIC0\_\_STS[ERR,PT] bit fields.

| Table 22-3. |  | _STS[ERR, | PT] | Decoding |
|-------------|--|-----------|-----|----------|
|-------------|--|-----------|-----|----------|

| ERR | PT | Status                                                           |
|-----|----|------------------------------------------------------------------|
| 0   | 0  | Requested transfer completed without errors                      |
| 0   | 1  | Requested transfer is in progress; no errors were detected       |
| 1   | 0  | Requested transfer is complete, but not all data was transferred |
| 1   | 1  | Requested transfer is in progress; but an error was detected     |

**Programming Note:** Software should not take any action regarding a master transfer unless all pending transfers are completed, IICO\_STS[PT] = 0.

If an error requires the IIC interface to send a Stop, the Stop Complete bit field is set, IIC0\_STS[SCMP] = 1. Note that slave operations should be serviced regardless of the state of a requested master transfer.

The IIC interface is placed in sleep mode by setting the CPC0\_ER[IIC] via software. Awaking the IIC interface is possible directly through software by clearing the CPC0\_ER[IIC] or indirectly by detecting a Start condition on the IIC bus. When a Start condition is detected, the IIC interface is awakened, clearing the CPC0\_ER[IIC] and the IIC0\_\_STS[SLPR].

The IIC0\_STS[MDBS, MDBF] contain the current status of the Master Data Buffer, IIC0\_MDBUF. When the IIC0\_MDBUF contains data, IIC0\_STS[MDBS] is set. When the IIC0\_MDBUF is full, IIC0\_STS[MDBF] is set.

The state of the IIC0\_MDBUF is not instantly recorded by the IIC0\_STS[MDBS, MDBF]. The delay depends on the size of the buffer access. For halfword accesses, these fields are valid on the third OPB clock following the transfer. For byte accesses, these fields are valid on the second OPB clock following the transfer.

### 22.3.8 IIC0 Extended Status Register

The IIC0 Extended Status register (IIC0\_EXTSTS) reports additional IIC status.

During and after transfers, software can read the IIC0\_STS and IIC0\_EXTSTS registers to determine the state of the IIC interface and the IIC bus.

Figure 22-11 illustrates the IIC0\_EXTSTS.





| 0   | IRQP | <ul> <li>IRQ Pending</li> <li>No IRQ is pending.</li> <li>An IRQ is active, another IRQ is on-deck,<br/>and another interrupt-generating<br/>condition has occurred.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <ul> <li>IIC0_EXTSTS[IRQP] might be set<br/>momentarily while an IRQ moves from<br/>the Pending to the On-deck state.</li> <li>An interrupt remains pending,<br/>IIC0_EXTSTS[IRQP]=1, until the current<br/>on-deck interrupt becomes active,<br/>IIC0_STS[IRQD]=0 and<br/>IIC0_STS[IRQA]]=1.</li> <li>Writing 1 to IIC0_EXTSTS[IRQP] clears<br/>the field.</li> <li>When the IIC interrupt is disabled,<br/>IIC0_MDCNTL[IRQP] = 0,<br/>IIC0_EXTSTS[IRQP] should be ignored.</li> </ul> |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:3 | BCS  | <ul> <li>Bus Control State</li> <li>000 Unused; if this value is read, a major<br/>IIC hardware problem occurred.</li> <li>001 Slave-selected state; the IIC interface<br/>has detected and decoded a slave<br/>transfer request on the IIC bus.</li> <li>010 Slave Transfer state; the IIC interface<br/>has detected but has not decoded a<br/>slave transfer request on the IIC bus.</li> <li>011 Master Transfer state; entered after a<br/>master transfer request has started on<br/>the IIC bus.</li> <li>100 Free Bus state; the bus is free and no<br/>transfer request is pending.</li> <li>101 Busy Bus state; the bus is busy.</li> <li>110 Unknown state; value after IIC reset.</li> <li>111 Unused; if this value is read, a major<br/>IIC hardware problem occurred.</li> </ul> | Read-only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| 4 | IRQD | <ul> <li>IRQ On-Deck</li> <li>0 No IRQ is on-deck.</li> <li>1 An interrupt is active, and another interrupt-generating condition has occurred.</li> </ul>                                                                                                                                                                                                            | <ul> <li>IIC0_EXTSTS[IRQD] might be set<br/>momentarily while an IRQ moves from<br/>the On-deck to the Active state.</li> <li>An interrupt remains on-deck,<br/>IIC0_EXTSTS[IRQD = 1, until the cur-<br/>rent active interrupt is no longer active,<br/>IIC0_STS[IRQA] = 0.</li> <li>If IIC0_EXTSTS[IRQP] = 1,<br/>IIC0_EXTSTS[IRQD] is set on the next<br/>OPB clock.</li> <li>Writing 1 to IIC0_EXTSTS[IRQD] clears<br/>the field.</li> <li>When the IIC interrupt is disabled,<br/>IIC0_EXTSTS[IRQP]=0,<br/>IIC0_EXTSTS[IRQD] should be ignored.</li> </ul> |
|---|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | LA   | Lost Arbitration<br>0 Normal operation.<br>1 Loss of arbitration has ended the<br>requested master transfer.                                                                                                                                                                                                                                                         | <ul> <li>If arbitration is lost, any requested master transaction may have terminated prematurely. Read data may be incomplete and not all write data may have been written.</li> <li>If arbitration is lost during a repeat start, the master may not own the IIC bus.</li> </ul>                                                                                                                                                                                                                                                                             |
| 6 | ICT  | Incomplete Transfer<br>0 Normal operation.<br>1 Some of the bytes of the requested<br>master transfer were not transferred.                                                                                                                                                                                                                                          | For an incomplete transfer, read the transfer count, IIC0_XFRCNT, to determine how bytes were transferred.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7 | XFRA | <ul> <li>Transfer Aborted</li> <li>0 No transfer is pending, or transfer is in progress.</li> <li>1 A requested master transfer was aborted by a NACK during the transfer of the address byte, or was aborted because arbitration was lost. Lost arbitration can be caused by the loss of data during the transfer of the second or subsequent data byte.</li> </ul> | Transfer aborted. When set to a 1, a<br>requested master transfer was aborted by<br>a NOT acknowledge during the transfer of<br>the address byte. It is also set to a 1 when<br>a requested master transfer loses data.<br>Lost arbitration can be caused by the loss<br>of data during the transfer of the second or<br>subsequent data byte.                                                                                                                                                                                                                 |

IICO\_EXTSTS[IRQP, IRQD] and IICO\_STS[IRQA] provide a FIFO for storing interrupts. A new interrupt is considered pending, and remains pending while an on-deck interrupt is present. Once the on-deck interrupt becomes active, the pending interrupt moves on-deck, and remains on-deck until there is no active interrupt. When the active interrupt is cleared, the on-deck (initially pending) interrupt becomes active.

Programming Note: An active interrupt remains active until software clears it.

IIC0\_EXTSTS[BCS] indicates the state of the IIC interface. The field is read-only.

IIC0\_EXTSTS[LA, ICT, XFRA] are cleared when IIC0\_EXTSTS[PT] = 1.

Writing 1 to IIC0\_EXTSTS[IRQP, IRQD, LA, ICT, XFRA] clears these fields.

#### 22.3.9 IIC0 Low Slave Address Register

The IIC0 Low Slave Address Register (IIC0\_LSADR) and IIC0\_ High Slave Address Register (IIC0\_HSADR) program the slave address of the IIC interface. IIC0\_HSADR is used only for 10-bit addressing, and is not programmed in 7-bit addressing mode.

When 7-bit addressing is used, IIC0\_LSADR is written with the slave address; IIC0\_HSADR must be written with zeros. For 7-bit addressing, IIC0\_LSADR[A0:A6] contain the address transmitted on the IIC bus; IIC0\_LSADR[A7] is a don't care.

When 10-bit addressing is used, IIC0\_LSADR[A0:A7] contain the second address byte transmitted on the IIC bus.

Figure 22-6 illustrates the IIC0\_LSADR.



#### Figure 22-12. IIC0 Low Slave Address Register (IIC0\_LSADR)

| 0 | A0 | Address bit 0 | · · · · · · · · · · · · · · · · · · ·                    |
|---|----|---------------|----------------------------------------------------------|
| 1 | A1 | Address bit 1 |                                                          |
| 2 | A2 | Address bit 2 | · ·                                                      |
| 3 | A3 | Address bit 3 | ······································                   |
| 4 | A4 | Address bit 4 |                                                          |
| 5 | A5 | Address bit 5 | · ·                                                      |
| 6 | A6 | Address bit 6 | LSb for 7-bit addresses                                  |
| 7 | A7 | Address bit 7 | LSb for 10-bit addresses; don't care for 7-bit addresses |

#### 22.3.10 IIC0 High Slave Address Register

For 7-bit addressing, set IIC0 High Slave Address Register (IIC0\_HSADR) to 0.

To enable 10-bit slave addressing, IICO\_HSADR must be programmed to 0b1111 0yyx, where yy are the high-order bits of a 10-bit address and x is a don't care.

**Programming Note:** IICO\_HSADR is used only for 10-bit addressing, and should be set to 0 for 7-bit addressing mode.

Thus, in 10-bit address mode, IIC0\_HSADR[A6:A7] contain the two highest -order bits of the 10-bit address; IIC0\_HSADR[A7] is a don't care. IIC0\_LSADR contains the low-order byte of the 10-bit address.

Figure 22-13 illustrates the IIC0\_HSADR.



Figure 22-13. IIC0 High Slave Address Register (IIC0\_HSADR)

| 0 | A0 | Address bit 0 | 1 for 10-bit addresses           |
|---|----|---------------|----------------------------------|
| 1 | A1 | Address bit 1 | 1 for 10-bit addresses           |
| 2 | A2 | Address bit 2 | 1 for 10-bit addresses           |
| 3 | A3 | Address bit 3 | 1 for 10-bit addresses           |
| 4 | A4 | Address bit 4 | 0 for 10-bit addresses           |
| 5 | A5 | Address bit 5 | MSb for 10-bit addresses         |
| 6 | A6 | Address bit 6 | Next to MSb for 10-bit addresses |
| 7 | A7 | Address bit 7 | Don't care for 10-bit addresses  |

Thus, in 10-bit address mode, bits 0:6 are used to decode the first address byte that was transmitted on the IIC bus, and bit 7 is in a *don't care* state.

#### 22.3.11 IIC0 Clock Divide Register

The IIC0 Clock Divide Register (IIC0\_CLKDIV) establishes a reference between the OPB clock and the IIC bus serial clock.

**Programming Note:** IIC0\_CLKDIV must be initialized before IIC0\_MDCTRL. Until IIC0\_CLKDIV is initialized, all IIC bus activity is ignored.

Figure 22-14 illustrates the IIC0\_CLKDIV.



| Figure 22-14. | IIC0 Clock | Divide | Register | (IICO | CLKDIV) |
|---------------|------------|--------|----------|-------|---------|
|               |            |        |          |       |         |

| 0 | DIV0 | Divisor bit 0 |  |
|---|------|---------------|--|
| 1 | DIV1 | Divisor bit 1 |  |
| 2 | DIV2 | Divisor bit 2 |  |
| 3 | DIV3 | Divisor bit 3 |  |
| 4 | DIV4 | Divisor bit 4 |  |
| 5 | DIV5 | Divisor bit 5 |  |

| 6 | DIV6 | Divisor bit 6 |
|---|------|---------------|
| 7 | DIV7 | Divisor bit 7 |

IIC0\_CLKDIV divides PPC405GP's on-chip peripheral bus (OPB) clock to form the base clock for the IIC bus.

Table 22-4 lists the divisor values for several OPB frequency ranges. These divisor values apply for standard and fast mode. Select the divisor value by matching the OPB clock frequency to the corresponding frequency range in Table 22-4. For example, if the OPB clock frequency is 50MHz, select a divisor value of 0x4.

| OPB Frequency Range (MHz) | Divisor<br>Value |
|---------------------------|------------------|
| 20                        | 0x1              |
| 20 < <i>f</i> ≤ 30        | 0x2              |
| 30 < <i>f</i> ≤ 40        | 0x3              |
| 40 < <i>f</i> ≤ 50        | 0x4              |
| 50 < <i>f</i> ≤ 60        | 0x5              |

|  | Table 22-4. | <b>IIC</b> 0 | Clock | Divide | Programming |
|--|-------------|--------------|-------|--------|-------------|
|--|-------------|--------------|-------|--------|-------------|

#### 22.3.12 IIC0 Interrupt Mask Register

The IIC0 Interrupt Mask Register (IIC0\_INTRMSK) specifies which conditions can generate an IIC interrupt when the IIC interrupt is enabled, IIC0\_MDCNTL[EINT]=1.

Figure 22-15 illustrates the IIC0\_INTRMSK.



| Figure 22-15. IIC0 Interrupt Mask Register (IIC0_ |
|---------------------------------------------------|
|---------------------------------------------------|

| 0 | EIRC | Enable IRQ on Slave Read Complete<br>0 Disable<br>1 Enable      | The interrupt is activated upon receipt of a<br>Stop during a slave read on the IIC bus.<br>IIC0_XTCNTLSS[SRC] = 1 indicates a<br>Slave Read Complete.          |
|---|------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | EIRS | Enable IRQ on Slave Read Needs Service<br>0 Disable<br>1 Enable | The interrupt is activated upon receipt of a slave read on the IIC bus and the slave buffer was empty or went empty and more data was requested on the IIC bus. |
|   |      |                                                                 | Note: IIC0_XTCNTLSS[SRS] = 1<br>indicates a Slave Read Needs<br>Service.                                                                                        |

| 2 | EIWC  | Enable IRQ on Slave Write Complete<br>0 Disable<br>1 Enable                  | The interrupt is activated upon receipt of a<br>Stop during a slave write on the IIC bus.<br>Note: IIC0XTCNTLSS[SWC] = 1 indicates<br>a Slave Write Compete.              |
|---|-------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | EIWS  | Enable IRQ on Slave Write Needs Service<br>0 Disable<br>1 Enable             | The interrupt is activated when the slave<br>buffer becomes full during a slave write on<br>the IIC bus.<br>Note: IIC0_XTCNTLSS[SWS] = 1<br>indicates a Slave Write Needs |
|   |       |                                                                              | Service.                                                                                                                                                                  |
| 4 | EIHE  | Enable IRQ on Halt Executed<br>0 Disable<br>1 Enable                         |                                                                                                                                                                           |
| 5 | EIIC  | Enable IRQ on Incomplete Transfer<br>0 Disable<br>1 Enable                   |                                                                                                                                                                           |
| 6 | EITA  | Enable IRQ on Transfer Aborted<br>0 Disable<br>1 Enable                      |                                                                                                                                                                           |
| 7 | EIMTC | Enable IRQ on Requested Master Transfer<br>Complete<br>0 Disable<br>1 Enable |                                                                                                                                                                           |

# 22.3.13 IIC0 Transfer Count Register

The IIC0 Transfer Count Register (IIC0\_XFRCNT) reports the number of bytes transferred on the IIC bus during a master or a slave operation.

Figure 22-16 illustrates the IIC0\_XFRCNT.



| 0   |     | Reserved                |
|-----|-----|-------------------------|
| 1:3 | STC | Slave Transfer Count    |
|     |     | 000 0 bytes transferred |
|     |     | 001 1 byte transferred  |
|     |     | 010 2 bytes transferred |
|     |     | 011 3 bytes transferred |
|     |     | 100 4 bytes transferred |
|     |     | 101 Reserved            |
|     |     | 110 Reserved            |
|     |     | 111 Reserved            |

| 4   |     | Reserved                                                                                                                                                    |
|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:7 | MTC | Master Transfer Count<br>000 0 bytes transferred<br>001 1 byte transferred<br>010 2 bytes transferred<br>011 3 bytes transferred<br>100 4 bytes transferred |
|     |     | 101 Reserved<br>110 Reserved<br>111 Reserved                                                                                                                |

IIC0\_XFRCNT[MTC] is cleared when there is a pending transfer, IIC0\_CNTL[PT] = 1.

IIC0\_XFRCNT[STC] is cleared when:

- A slave operation starts on the IIC bus
- Software indicates the slave does not need service by clearing IIC0\_XTCNTLSS[SRS] or IIC0\_XTCNTLSS[SWS].

# 22.3.14 IIC0 Extended Control and Slave Status Register

The IIC0 Extended Control and Slave Status Register (IIC0\_XTCNTLSS) provides additional control of IIC interface functions and reports the status of slave operations.

Figure 22-17 illustrates the IIC0\_XTCNTLSS.



Figure 22-17. IIC0 Extended Control and Slave Status Register (IIC0\_XTCNTLSS)

| 0 | SRC | Slave Read Complete                                                                                                                                                                                                                                                      | Check whether the read operation emptied |
|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
|   |     | <ul> <li>0 Normal operation, or<br/>IIC0_MDCNTL[HSCL] = 0, IIC0_SDBUF<br/>is empty, and a read operation is in<br/>progress.</li> <li>1 A NACK or Stop condition was received<br/>over the IIC bus, or a repeated Start<br/>condition ended a read operation.</li> </ul> | IIC0_SDBUF.                              |

| 1 | SRS  | <ul> <li>Slave Read Needs Service</li> <li>0 Normal operation or slave read does not<br/>need service.</li> <li>1 IICO_SDBUF is empty, and a read<br/>operation was requested on the IIC bus.</li> <li>The set condition may also indicate that<br/>IICO_SDBUF is empty due to a slave read<br/>and additional data is requested by the<br/>master.</li> </ul> | <ol> <li>If IIC0_MDCNTL[HSCL]=0 and<br/>IIC0_SDBUF contains no data, the slave<br/>will issue a NACK and<br/>IIC0_XTCNTLSS[SRS] is set.</li> <li>If IC0MDCNTL[HSCL]=0, and<br/>IIC0_SDBUF contains data, the slave will<br/>send the data. IIC0_XTCNTLSS[SRS] is<br/>not set unless the master request<br/>additional data.</li> <li>If IIC0_MDCNTL[HSCL]=0, and<br/>IIC0_SDBUF contains no data, the slave<br/>will hold IICSCL low to indicate the slave is<br/>busy. IIC0_XTCNTLSS[SRS] is set until the<br/>IIC0_SDBUF is filled. Once filled, IICSCL is<br/>released, IIC0_XTCNTLSS[SRS] is<br/>cleared, and the slave sends the data.</li> <li>If IIC0_MDCNTL[HSCL]=1, and<br/>IIC0_SDBUF contains data, the slave will<br/>send the data. IIC0_XTCNTLSS[SRS] is<br/>not set unless the master requests<br/>additional data.</li> </ol> |
|---|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | SWC  | <ul> <li>Slave Write Complete</li> <li>Normal operation or slave write in progress.</li> <li>A Stop signal was received during a write operation, or a repeated Start condition ended a write operation.</li> </ul>                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3 | SWS  | <ul> <li>Slave Write Needs Service</li> <li>0 Normal operation or slave write does not need service.</li> <li>1 IIC0_SDBUF is full during a slave write.</li> </ul>                                                                                                                                                                                            | <ol> <li>If IICO_MDCNTL[HSCL] = 1 and<br/>IICO_SDBUF is full, the slave will hold<br/>IICSCL low to indicate the slave is busy.<br/>IICO_XTCNTLSS[SWS] is set until<br/>IICO_SDBUF is empty. Once empty,<br/>IICSCL is released,<br/>IICO_XTCNTLSS[SWS] is cleared, and the<br/>slave receives the data.</li> <li>If IICO_MDCNTL[HSCL] = 0 and<br/>IICO_SDBUF is full, the slave will issue a<br/>NACK and IICO_XTCNTLSS[SWS] is set.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                              |
| 4 | SBDD | Slave Data Buffer Has Data<br>0 IIC0_SDBUF is empty<br>1 IIC0_SDBUF contains data                                                                                                                                                                                                                                                                              | Read-only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5 | SDBF | Slave Data Buffer Full<br>0 IIC0_SDBUF is not full<br>1 IIC0_SDBUF is full                                                                                                                                                                                                                                                                                     | Read-only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| 6 | EPI  | Enable Pulsed IRQ on Transfer Aborted                                                                                                                                                                                                                |
|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      | <ul> <li>0 The internal IIC interrupt signal to the<br/>UIC remains active until the status is<br/>cleared, IIC0STS[IRQA] =0.</li> <li>1 The internal IIC interrupt signal to the<br/>PPC405GP UIC is active for one OPB<br/>clock cycle.</li> </ul> |
| 7 | SRST | Soft Reset<br>O Normal operation<br>1 Soft reset                                                                                                                                                                                                     |

Writing a 1 to IIC0\_XTCNTLSS[SRC, SRS, SWC, SWS] clears these fields.

Care must be used when changing IICO\_XTCNTLSS[EPI]. If this field changes (from 1 to 0 or from 0 to 1) while an interrupt is active, the IIC interrupt signal is asserted to the universal interrupt controller (UIC).

The IIC0\_XTCNTLSS[SBSS, SDBF] contain the current status of the Slave Data Buffer, IIC0\_SDBUF. When the IIC0\_SDBUF contains data, IIC0\_XTCNTLSS[SBDD] is set. When the IIC0\_SDBF is full, IIC0\_XTCNTLSS[SDBF] is set.

The state of the IIC0\_SDBUF is not instantly recorded by the IIC0\_XTCNTL[SBSS, SDBF]. The delay depends on the size of the buffer access. For half-word accesses, these fields are valid on the third OPB clock following the transfer. For byte accesses, these fields are valid on the second OPB clock following the transfer.

If any of the following fields: IIC0\_XTCNTLSS[SRC, SRS, SWC, SWS] = 1 and IIC0\_MDCNTL[HSCL] = 0; no new slave operations will be accepted over the IIC bus. A NACK is issued until IIC0\_XTCNTLSS[SRS] or IIC0\_XTCNTLSS[SRS], and IIC0\_XTCNTLSS[SRS] or IIC0\_XTCNTLSS[SRS], are cleared.

Soft reset, IIC0\_XTCNTLSS[SRST], provides a last means of recovery from IIC interface or IIC bus failure. Once enabled, soft reset completely resets the IIC interface. All IIC registers are affected. All transmissions from the IIC interface are terminated. Enabling soft reset during an IIC transmission may improperly terminate the transmission and hang the IIC bus.

#### 22.3.15 IIC0 Direct Control Register

The IIC0 Direct Control Register (IIC0\_DIRECTCNTL), which controls and monitors the IIC serial clock (IICSCL) and serial data (IICSDA) signal, is used for error recovery when a malfunction is detected on the IIC interface.

Figure 22-18 illustrates the IIC0\_DIRECTCNTL.



| 0:3 | and a state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the state of the | Reserved                                                                                                        |           |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------|
| 4   | SDAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IICSDA Output Control<br>Directly controls the IICSDA output.<br>0 IICSDA is a logic 0<br>1 IICSDA is a logic 1 |           |
| 5   | SCC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | IICSCL Output Control<br>Directly controls the IICSCL output<br>0 IICSCL is a logic 0<br>1 IICSCL is a logic 1  |           |
| 6   | MSDA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Monitor IICSDA<br>Used to monitor the IICSDA input<br>0 IICSDA is a logic 0<br>1 IICSDA is a logic 1            | Read-only |
| 7   | MSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Monitor IICSCL. Used to monitor the<br>IICSCL input.<br>0 IICSCL is a logic 0<br>1 IICSCL is a logic 1          | Read-only |

IIC0\_DIRECTCNTL[SDAC, SCC] can be written to control the IICSDA and IICSCL signals. When controlling the IICSDA and IICSCL signals directly, the IIC controller must be placed in the reset state, IIC0\_XTCNTL[SRST] = 1.

IIC0\_DIRECTCNTL[MSDA, MSC] are used to verify that IIC0\_DIRECTCNTL[SDAC, SCC] were written successfully, and that the IICSCL signals can be controlled. If IIC0\_DIRECTCNTL[MSDA, MSC] do not correspond to IIC0\_DIRECTCNTL[SDAC, SCC], respectively, toggle IICSCL repeatedly to regain control.

IIC0\_DIRECTCNTL[SDAC, SCC, MDSA, MSC] = 1 after a chip or system reset. A Soft Reset, IIC0\_XTCNTLSS[SRST] = 1, does not affect the state IIC0\_DIRECRCNTL.

# 22.4 Interrupt Handling

The IIC interface can handle interrupts in two ways. The processor can poll IIC0\_STS[SSS, PT]. Alternatively, software can use IIC interface interrupts.

IIC0\_MDCNTL[EINT] and the interrupt mask bits in the IIC0\_INTRMSK control interrupts. IIC0\_XTCNTLSS[EPI] controls whether the IIC IRQ is set at a 1-clock pulse or at a constant level. The IIC controller guarantees that the interrupt is activated after the state of the has been set to ensure that interrupt handlers read stable values from the IIC interface registers. IIC interrupts can generate interrupt requests to the UIC. If enabled properly in the UIC, an IIC interrupt can interrupt the processor core. See "Interrupt Handling in the Processor Core" on page 10-22 for more information.

Because a master operation can have one interrupt and a slave operation can have two interrupts, the IIC interface can queue up to three interrupts. The current interrupt is referred to as the *active* interrupt. The first interrupt in the queue is referred to as the *on-deck* interrupt; the second queued interrupt is called the *pending* interrupt. The queue holds multiple interrupts until the active interrupt is cleared by writing a 1 to IIC0\_STS[IRQA]. When an active interrupt is cleared, the on-deck interrupt becomes the active interrupt and the pending interrupt becomes the on-deck interrupt.

Status associated with an IIC interrupt is immediately set in its corresponding register. Thus, an interrupt handler can see the status for the current and the queued interrupts. This can occur if, for example, the interrupt handler is itself interrupted before reading any status in the IIC registers. If a second or third interrupt occurs before the interrupt handler regains control, the status seen at this time will include status associated with all three interrupting conditions. In this case, the interrupt handler cannot determine the first interrupting condition; all the interrupts will appear to have been merged. Note that if the interrupt handler is intelligent enough to handle and clear all conditions currently set in the status, instead of choosing only one interrupt and servicing it, the routine would not see status for the subsequent interrupts.

A more typical situation involves the case where an interrupt handler has read the IIC status for the active interrupt and a second (on-deck) interrupt occurs. In this case, the status changed after it was first read by the interrupt handler. Because status bits are cleared by writing a 1, no ill effects, such as lost status information, result from this case. To illustrate, consider that the interrupt handler might have read IIC0\_XTCNTLSS = 0x10 when the first interrupt occurred. Then, sometime later, the routine clears this status by writing 0x10 back to the IIC0\_XTCNTLSS. If the slave write operation completes while the register is read and written, the register will contain a 0x30 when the 0x10 is written. Because writing 0 to a bit has no effect after it is set to 1, the slave write complete status is not lost.

Under certain conditions, the IIC interface merges slave read (write) needs service and slave read (write) complete interrupts into one interrupt. If a slave read (write) needs service interrupt is active, or queued, and a slave read (write) complete interrupt occurs, and IIC0\_XTCNTLSS has not yet been read, the two interrupts are merged into a single interrupt. This merge function is performed in the IIC interface logic, and is not under software control.

### 22.5 General Considerations

- After a reset, the IIC interface enters the unknown IIC bus state. This state is exited when either activity is seen on the bus or when the exit unknown IIC bus state bit, in the mode control register, is set to a 1. If the IIC interface is being used in a single master system as the master, then the exit unknown IIC bus state bit must be used to force the logic out of the unknown state.
- 2. Once a byte is written into either the master or slave buffer, a total of four OPB clock periods must occur before the data can be read. Flushing the master or slave buffer also requires four OPB clock periods to complete.

- 3. The master and slave buffers are actually 4 × 1 byte-wide FIFOs. Exercise care when using master and slave buffers. As an example, consider the case where one byte of data is written on the IIC bus. The data is first written into the master or slave buffer. After four OPB clock cycles the data is placed on the IIC bus. There is no way to verify data in the buffer without disturbing the IIC transaction. The act of verification requires removing the data. If the data is removed, invalid data is placed on the IIC bus.
- 4. Use care when monitoring the IICO\_XCNTLSS[SBDD] or to IICO\_STS[MDBS] to determine when data is present. These bits are set to 1 when the buffer contains data in any stage. Consider the case where the master buffer is empty prior to being loaded with a byte received over the IIC bus. The byte enters the fourth stage of the buffer and the IICO\_STS[MDBS] is set to 1. Stages 1, 2, and 3 do not contain data. Therefore, the data is not available for four OPB clock cycles. Any attempt to prematurely read the data yields invalid data.
- 5. When responding to a slave needs service request, manage the data first. Read data out of the slave buffer, IIC0\_SDB, for slave reads or write data into the IIC0\_SDB for slave writes. Next clear the slave needs service request. For reads, clear IIC0\_XTCNTLSS[SRS]. For writes, clear IIC0\_XTCNTLSS[SWS]. Last, clear the active interrupt, IIC0\_STS[IRQA] =0.
- 6. There is no timeout function implemented in the IIC interface. If this type of error recovery function is needed, it must be implemented in software.
- 7. Avoid the situations listed in Section 7.2 of the *Philips Semiconductors I<sup>2</sup>C Specification*, dated 1995. For your convenience, the section is summarized as follows:

If multiple masters can be simultaneously involved in a transfer to the same address, or device, then the design of the system must be done in such a way that arbitration between:

- A repeated Start condition and a data bit does not occur.
- A Stop condition and a data bit does not occur.
- A repeated Start condition and a Stop condition does not occur.

One example of a not allowed case would be if one master were to write 1 byte while another device wrote 2 bytes to the same device. In this situation, the first master would issue a Stop while the second master sends the MSb of the second data byte.

# **Chapter 23. GPIO Operations**

This chapter describes the General Purpose I/O (GPIO) controller located on the on-chip peripheral bus (OPB) of the PPC405GP. The GPIO controller allows flexible control of up to 23 multiplexed I/Os with user-defined functions.

# 23.1 GPIO Controller Overview

The GPIO Controller is an OPB macro that controls up to 23 bidirectional module I/O pins with userprogrammable functions. Each of these IOs are multiplexed with other signals to reduce the quantity of module I/O on the PPC405GP package. Control for this multiplexing is performed using the CPC0\_CR0 register. See "External Module Signals" on page 23-3 for more information.

The GPIO outputs can be programmed to emulate an open drain driver.

All module I/O inputs are synchronized to the OPBClk before being stored in the Input register.

All registers, except the Input Register, are both read and write accessible. The Input register is readonly. Registers provide direct control of all GPIO Controller functions.

All register bits and core input and output signals maintain a bit-for-bit correspondence. For example, GPIO\_Out[20] is controlled by GPIO0\_OR Register Bit 20.

# 23.2 Features

The GPIO Controller has the following features:

- · Direct control of all functions from registers programmed via memory-mapped addresses
- · Control of 23 bidirectional GPIO module pins
  - Each GPIO output has programmable three-state control
  - Each GPIO output is separately programmable to emulate an open drain driver
  - Each GPIO input is observable from a register bit

# 23.3 GPIO Interface Signals



Figure 23-1. GPIO Functional Block Diagram

The following sections discuss the GPIO interface signals.

# 23.3.1 External Macro Signals

All registers within the GPIO Controller are synchronous to OPBClk, and all GPIO\_In inputs are synchronized to OPBClk before being stored.

Table 23-1. Macro I/O Interface Signals

| Signal Name           | 1/0 | Function                                                                                                                                                                                                                                        |
|-----------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIO_In(0:23)         | 1   | Input to the GPIO Controller directly from Pin Z (Receiver Output).<br>The bi-directional three-state driver books must be in the high<br>impedance state in order to receive valid data as input from off chip.                                |
| GPIO_Out(0:23)        | 0   | Data outputs from the GPIO Controller. These signals are designed to tie directly to Pin A (Driver Data Input).                                                                                                                                 |
| GPIO_TS_Control(0:23) |     | Three-state control outputs from the GPIO Controller macro. These<br>signals are designed to tie directly to each corresponding module I/O<br>Pin TS (Driver Three-State Control).<br>0 = High Impedance.<br>1 = Active (drive GPIO_Out signal) |

#### 23.3.2 External Module Signals

The GPIO signals do not have dedicated module pins. The module pins, used by the GPIO signals, are shared (multiplexed) with other signals. The Chip Control Register 0 (CPC0\_CR0) controls the way in which the signal on a shared pin is interpreted. The following sections provide details of the CPC0\_CR0 register bit settings and the function of the GPIO registers.

The GPIO signals are multiplexed with the nine instruction trace signals, seven of the eight EBC chip selects, and the seven external interrupt request inputs. Multiplexing is controlled by the setting of CPC0\_CR0[4:18] as follows:

|       | GPIO Enable/Disable |       |    |
|-------|---------------------|-------|----|
|       | Ļ                   |       |    |
| 0 3 4 |                     | 18 19 | 31 |

| 4  | TRE  | CPU Trace Enable<br>0 GPIO1-9 are enabled<br>1 GPIO1-9 are disabled             | Trace interface cannot be used when GPIO is enabled. |
|----|------|---------------------------------------------------------------------------------|------------------------------------------------------|
| 5  | G10E | GPIO 10 Enable<br>0 Enable PerCS1 as a chip select<br>1 Enable PerCS1 as GPIO10 |                                                      |
| 6  | G11E | GPIO 11 Enable<br>0 Enable PerCS2 as a chip select<br>1 Enable PerCS2 as GPIO11 | •                                                    |
| 7  | G12E | GPIO 12 Enable<br>0 Enable PerCS3 as a chip select<br>1 Enable PerCS3 as GPIO12 |                                                      |
| 8  | G13E | GPIO 13 Enable<br>0 Enable PerCS4 as a chip select<br>1 Enable PerCS4 as GPIO13 |                                                      |
| 9  | G14E | GPIO 14 Enable<br>0 Enable PerCS5 as a chip select<br>1 Enable PerCS5 as GPIO14 |                                                      |
| 10 | G15E | GPIO 15 Enable<br>0 Enable PerCS6 as a chip select<br>1 Enable PerCS6 as GPIO15 |                                                      |
| 11 | G16E | GPIO 16 Enable<br>0 Enable PerCS7 as a chip select<br>1 Enable PerCS7 as GPIO16 |                                                      |

#### Figure 23-2. CPC0\_CR0 Bits Controlling GPIO

| 12 | G17E | GPIO 17 Enable<br>0 Enable interrupt IRQ0 as an interrupt<br>1 Enable interrupt IRQ0 as GPIO17 | The purpose of GPIO_17_EN through<br>GPIO_23_EN is to isolate the interrupt<br>controller from activity on a shared pin                                                                                                                                                                                                                                                                                                      |
|----|------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |      |                                                                                                | when that pin is being used as a GPIO. For<br>instance, when G17E is set to a 1, IRQ0 at<br>the UIC will always be forced to a zero.<br>Note: Setting G17E to a 0 will not prevent<br>GPIO channel 17 (if configured as an<br>output) from creating contention with<br>the off-chip source of the IRQ input.<br>Therefore, be sure to leave the shared<br>GPIO channel disabled when using<br>the pin as an interrupt input. |
| 13 | G18E | GPIO 18 Enable<br>0 Enable interrupt IRQ1 as an interrupt<br>1 Enable interrupt IRQ1 as GPIO18 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14 | G19E | GPIO 19 Enable<br>0 Enable interrupt IRQ2 as an interrupt<br>1 Enable interrupt IRQ2 as GPIO19 | · .                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15 | G20E | GPIO 20 Enable<br>0 Enable interrupt IRQ3 as an interrupt<br>1 Enable interrupt IRQ3 as GPIO20 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16 | G21E | GPIO 21 Enable<br>0 Enable interrupt IRQ4 as an interrupt<br>1 Enable interrupt IRQ4 as GPIO21 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 17 | G22E | GPIO 22 Enable<br>0 Enable interrupt IRQ5 as an interrupt<br>1 Enable interrupt IRQ5 as GPIO22 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18 | G23E | GPIO 23 Enable<br>0 Enable interrupt IRQ6 as an interrupt<br>1 Enable interrupt IRQ6 as GPIO23 |                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### Figure 23-2. CPC0\_CR0 Bits Controlling GPIO (continued)

In all cases when a pin is used as a GPIO, it is necessary to configure the appropriate bit in this register as well as the GPIO registers located in the GPIO controller.

# 23.4 Clock and Power Management

The GPIO Controller macro supports Clock and Power Management. Unconditional Sleep (Class 1) power management is implemented, and is enabled by setting the CPC0\_ER[GPIO] bit.

# 23.5 GPIO Register Overview

The following table contains a summary of the GPIO registers.

| MMIO Address | Mnemonic  | Description              | Access Mode |
|--------------|-----------|--------------------------|-------------|
| EF600700     | GPIO0_OR  | GPIO Output              | R/W         |
| EF600704     | GPIO0_TCR | GPIO Three-State Control | R/W         |
| EF600718     | GPIO0_ODR | GPIO Open Drain          | R/W         |
| EF60071C     | GPIO0_IR  | GPIO Input               | R           |

| Table 23-2. GPIO Register Summar | Table | 23-2. | GPIO | Register | Summary |
|----------------------------------|-------|-------|------|----------|---------|
|----------------------------------|-------|-------|------|----------|---------|

# 23.5.1 GPIO Register Reset Values

When a system reset occurs, each register in the GPIO macro, except GPIOO\_IR, is reset to 0. All outputs are in the high-impedance state. GPIOO\_IR is not reset because it is always clocked and always follows the GPIO\_In state.

### 23.5.2 Detailed Register Description

The following sections provide a bit description of the GPIO registers. All registers are accessed from the OPB. The GPIO0\_IR register is read-only; all other registers are both read and write accessible.

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 31

#### Figure 23-3. GPIO Registers

| 0     | Reserved           |
|-------|--------------------|
| 1:23  | GPIO register bits |
| 24:31 | Reserved           |

### 23.5.2.1 GPIO Output Register (GPIO0\_OR)

The state of each bit in the GPIO0\_OR Register may be reflected in the corresponding GPIO Controller macro output signal GPIO\_Out.

### 23.5.2.2 GPIO Three-State Control Register (GPIO0\_TCR)

Each bit in the GPIO0\_TCR Register controls the corresponding GPIO\_TS\_Control macro output signal.Each bit in the GPIO0\_TCR Register controls the corresponding GPIO\_TS\_Control macro output signal.

When 0, GPIO\_TS\_Control forces the module I/O drivers into the high-impedance state.

The state of the GPIO\_Out signal driving Pin A (Driver Data Input) of the module I/O three-state driver is irrelevant when the driver is in the high impedance state. High impedance take precedence over data output signals.

## 23.5.2.3 GPIO Open Drain Register (GPIO0\_ODR)

The GPIO Open Drain Register configures the module I/O three-state driver to emulate open drain drivers on a bit-by-bit basis. This is done by controlling the GPIO\_Out and GPIO\_TS\_Control signals, via the GPIO0\_OR and GPIO0\_TCR registers, respectively.

When programmed to 1, each bit in the GPIO0\_ODR register forces the corresponding GPIO\_Out signal to 0 and the corresponding GPIO\_TS\_Control signal to the inverted GPIO\_Out signal. In this case, the value of the corresponding bit in the GPIO0\_TCR register is ignored. The open drain logic is shown in the table below.

When emulating an open drain driver, the module I/O driver never drives a 1 level. It either drives a 0 level or it is in the high impedance state emulating an open drain 1 level.

| GPIO0_ODR<br>Bit | GPIO0_OR<br>Bit | GPIO_Out<br>Macro Output | GPIO0_TCR<br>Bit | GPIO_TS_Control<br>Macro Output | Module I/O Three-<br>State Driver     |
|------------------|-----------------|--------------------------|------------------|---------------------------------|---------------------------------------|
| 0                | x               | x                        | 0                | 0                               | Forced to high-<br>impedance<br>state |
| 0                | 0               | 0                        | 1                | 1                               | Driving 0                             |
| 0                | 1               | 1                        | 1                | 1                               | Driving 1                             |
| 1                | 0               | 0                        | x                | 1                               | Driving 0                             |
| 1                | 1               | 0                        | x                | 0                               | Forced to high-<br>impedance<br>state |

Table 23-3. GPIO0\_ODR Control Logic

### 23.5.2.4 GPIO Input Register (GPIO0\_IR)

The state of each bit in the GPIO0\_IR Register reflects the corresponding GPIO Controller macro input signal GPIO\_In. All GPIO\_In signals are synchronized to OPBClk before being stored in the GPIO0\_IR Register. The GPIO0\_IR Register is read-only and does not change during a read access.

All bi-directional three-state drivers must be in the high-impedance state in order to receive valid data as input from off chip.

# Index

#### Α

AA field conditional branches 3-35 unconditional branches 3-34 access protection cache instructions 6-15 string instructions 6-16 virtual mode 6-12 add 24-6 add. 24-6 addc 24-7 addc. 24-7 addco 24-7 addco. 24-7 adde 24-8 adde. 24-8 addeo 24-8 addeo. 24-8 addi 24-9 addic 24-10 addic. 24-11 addis 24-12 addme 24-13 addme. 24-13 addmeo 24-13 addmeo. 24-13 addo 24-6 addo. 24-6 address map illustrated 3-2 address translation illustrated 6-2 MMU 6-1 relationship between TLBs, illustrated 6-8 addressing modes 1-11 addze 24-14 addze. 24-14 addzeo 24-14 addzeo. 24-14 alignment for cache control instructions 3-27 for storage reference instructions 3-27 of data types 3-26 alignment interrupts causes of 3-28 register settings 10-40 summary 10-39 and 24-15 and. 24-15 andc 24-16 andc. 24-16 andi. 24-17 andis. 24-18 architecture, PowerPC 1-4 arithmetic compares 3-13 arithmetic instructions 3-49

asynchronous interrupts 10-22 В b 24-19 ba 24-19 bc 24-20 bca 24-20 bcctr 24-26 bcctrl 24-26 bcl 24-20 bcla 24-20 bclr 24-30 bcirl 24-30 bctr 24-27 bctrl 24-27 bdnz 24-21 bdnza 24-21 bdnzf 24-21 bdnzfa 24-21 bdnzfl 24-21 bdnzfla 24-21 bdnzflr 24-31 bdnzflrl 24-31 bdnzl 24-21 bdnzla 24-21 bdnzlr 24-31 bdnzlrl 24-31 bdnzt 24-21 bdnzta 24-21 bdnztl 24-21 bdnztia 24-21 bdnztlr 24-31 bdnztlrl 24-31 bdz 24-21 bdza 24-21 bdzf 24-22 bdzfa 24-22 bdzfl 24-22 bdzfla 24-22 bdzflr 24-31 bdzfiri 24-31 bdzl 24-21 bdzla 24-21 bdzlr 24-31 bdzlrl 24-31 bdzt 24-22 bdzta 24-22 bdztl 24-22 bdztla 24-22 bdztlr 24-31 bdztlrl 24-31 beg 24-22 bega 24-22 begctr 24-27 begctrl 24-27 beql 24-22 begir 24-31

bealrl 24-31 bf 24-22 bfa 24-22 bfctr 24-27 bfctrl 24-27 bfl 24-22 bfla 24-22 bflr 24-32 bflrl 24-32 bge 24-23 bgea 24-23 bgectrl 24-27 bgel 24-23 bgela 24-23 bgelr 24-32 bgelrl 24-32 bgrctr 24-27 bgt 24-23 bgta 24-23 bgtctr 24-27 bgtctrl 24-27 batl 24-23 botla 24-23 batlr 24-32 batiri 24-32 BI field conditional branches 3-35 big endian alignment 3-27 defined 3-28 mapping 3-29 storage regions byte-reverse instructions 3-32- 3-33 bl 24-19 bla 24-19 ble 24-23 blea 24-23 blectr 24-27 blectri 24-27 blel 24-23 blela 24-23 blelr 24-32 bleiri 24-32 blr 24-30 birl 24-30 blt 24-23 blta 24-23 bltctr 24-27 bltctrl 24-27 bltl 24-23 bitla 24-23 bitir 24-32 bitiri 24-32 bne 24-24 bnea 24-24 bnectr 24-28 bnectrl 24-28 bnel 24-24 bnela 24-24 bnelr 24-32 bnelri 24-32

bng 24-24 bnga 24-24 bngctr 24-28 bngctrl 24-28 bngl 24-24 bngla 24-24 bnglr 24-32 bnglrl 24-32 bnl 24-24 bnla 24-24 bnictr 24-28 bnictri 24-28 bnll 24-24 bnlla 24-24 bnllr 24-33 bnllrl 24-33 bns 24-24 bnsa 24-24 bnsctr 24-28 bnsctrl 24-28 bnsl 24-24 bnsla 24-24 bnslr 24-33 bnslrl 24-33 bnu 24-25 bnua 24-25 bnuctr 24-28 bnuctrl 24-28 bnul 24-25 bnula 24-25 bnulr 24-33 bnulrl 24-33 BO field conditional branches 3-35- 3-36 branch instructions 3-51 branch prediction 3-36, A-1, B-9 controlling through mnemonics 3-37 branching control AA field on conditional branches 3-35 AA field on unconditional branches 3-34 BI field on conditional branches 3-35 BO field on conditional branches 3-35- 3-36 branch prediction 3-36 bso 24-25 bsoa 24-25 bsoctr 24-28 bsoctrl 24-28 bsol 24-25 bsola 24-25 bsolr 24-33 bsolrl 24-33 bt 24-25 bta 24-25 btctr 24-28 btctrl 24-28 btl 24-25 btla 24-25 btlr 24-33 btirl 24-33

bun 24-25

buna 24-25

bunctr .24-29 bunctrl 24-29 bunl 24-25 bunla 24-25 bunlr 24-33 buniri 24-33 bus timeout error 16-11 byte ordering big endian, defined 3-28 little endian defined 3-28 supported 3-30 overview 3-28 byte reversal during load/store access 3-31 byte-reverse instructions augmented by endian (E) storage attribute 3-33 compare to endian (E) storage attribute 3-32

#### С

cache instructions DAC debug events 12-20 cache block, defined 4-9 cache control instructions access protection 6-15 causing data storage interrupts 6-15 cache line dirty, defined 4-16 See also cache block cache line fills DCU 4-6 defined 4-6 types 4-3 cache organization DCU 4-5 ICU 4-2 caches. See ICU;DCU caching inhibited (I) storage attribute for data accesses, controlled by DCCR 6-19 for instruction fetches, controlled by ICCR 6-19 virtual mode 6-5 CCR0 25-15 character mode NS16450 21-1 clrislwi 24-147 cirlslwi, 24-147 clrlwi 24-147 clrlwi, 24-147 cirrwi 24-148 clrrwi. 24-148 cmp 24-34 cmpi 24-35 cmpl 24-36 cmpli 24-37 cmplw 24-36 cmplwi 24-37 cmpw 24-34 cmpwi 24-35 cntlzw 24-38 cntlzw. 24-38 compare instructions

arithmetic 3-13 in core, listed 3-50 effect on CR fields 3-13 logical 3-13 Condition Register. See CR conditional branches AA field 3-35 Bl field 3-35 BO field 3-35- 3-36 mnemonics used to control prediction 3-37 context synchronization defined 3-44 for ITLB 6-8 limitations 3-44 context, defined 3-44 conventions notational xlviii Count Register. See CTR CPC0\_CR1 25-20 CPC0\_ER 25-21 CPC0 FR 25-22 CPC0 JTAGID 25-23 CPC0\_PLLMR 25-24 CPC0 PSR 25-26 CPC0\_SR 25-28 CR 25-29 CR (Condition Register) arithmetic and logical instructions 3-49 compare instructions 3-13, 3-50 CR0 field 3-14 logical instructions 3-50 setting fields 3-12 summarized 1-11 crand 24-39 crandc 24-40 crclr 24-46 creqv 24-41 critical input interrupts 10-34 register settings 10-35 critical interrupts 10-23 defined 10-26 processing 10-27 crmove 24-44 crnand 24-42 crnor 24-43 crnot 24-43 cror 24-44 crorc 24-45 crset 24-41 crxor 24-46 CTR 15-6, 15-14, 15-15, 15-16, 15-17, 15-20, 25-30, 25-209, 25-210, 25-218, 25-219, 25-220, 25-221 CTR (Count Register) branch instructions 3-51 functions 3-7 testing by branch instructions 3-35

## D

DAC1 12-14 DAC1-DAC2 12-14, 14-7, 25-31, 25-48 Data Address Compare Register (DAC1) 12-14

Index

data alignment in little endian storage 3-32 overview 3-26 Data Cache Cachability Register. See DCCR Data Cache Cachability Register. See DCCR data cache unit. See DCU Data Cache Write-through Register. See DCWR Data Cache Write-through Register. See DCWR Data Exception Address Register. See DEAR data machine check interrupts register settings 10-36 data storage interrupts caused by cache control instructions 6-15 causes 10-36 described 6-9 programming note 10-37 register settings 10-37 data TLB. See DTLB data types illustrated 3-26 summarized 1-10 DBCR 12-9 DBCR0 25-32, 25-34 DBCR0 (Debug Control Register 0) resets 8-2 DBSR 12-12, 25-36 dcba does not cause interrupts 6-15 functions 4-10 dcbf 24-49 data storage interrupts 6-16 functions 4-10 dcbi 24-50 data storage interrupts 6-15 functions 4-10 dcbst 24-51 data storage interrupts 6-16 functions 4-10 dcbt 24-52 data storage interrupts 6-16 functions 4-10 dchtst functions 4-10 dcbz 24-54 data storage interrupts 6-15 functions 4-11 dccci 24-56 data storage interrupts 6-16 functions 4-11 when use not recommended 6-16 DCCR 25-38 DCCR (Data Cache Cachability Register) controlling cachability 4-8 controlling the caching inhibited (I) storage attribute 6-19 DCP0\_ADDR0-DCP0\_ADDR1 25-40 DCP0\_ADDR0-DCP0\_ADDR3 14-5, 25-40 DCP0\_CFG 14-6, 25-41 DCP0\_CFGADDR 25-42 DCP0\_CFGADDR (Decompression Controller Address Register)

accessing 3-21 DCP0 CFGDATA 25-43 DCP0\_CFGDATA (Decompression Controller Data Register) accessing 3-21 DCP0\_ESR 14-8, 25-44 DCP0\_ID 14-6, 25-46 DCP0 ITOR0-DCP0 ITOR3 14-4, 25-47 DCP0\_MEMBEAR 14-7, 25-48 DCP0\_PLBBEAR 14-7, 25-49 DCP0\_RAM0-DCP0\_RAM3FF 25-50 DCP0\_VER 14-7, 25-51 dcread 24-57 controlled by CCR0 4-11 as debugging tool 4-15 functions 4-11 DCRs (device control registers) indirectly accessed 3-19 instructions for reading 3-43 summary 1-11 uses for 3-16 DCU (data cache unit) cachability control 4-8 cache line fills 4-6 coherency 4-9 debugging 4-15 features 4-1 instructions 4-10 load commands, accepting 4-17 load strategies 4-7 organization 4-5 performance 4-16 pipeline stalls 4-16 priority changes 4-17 priority signal 4-17 sequential caching 4-18 simultaneous cache operations 4-18 store commands 4-17 tag information in GPRs 4-16 write strategies 4-7 DCWR 25-52 DCWR (Data Cache Write-through Register) controlling write strategies 4-7 write-through policy 6-18 DEAR 25-54 DEAR (Data Exception Address Register) illustrated 10-34 Debug Control Register (DBCR) 12-9 Debug Control Register 0. See DBCR0 debug interrupts register settings 10-44 debugging boundary scan chain 12-3 DCU 4-15 debug events 12-16 debug interfaces 12-1 JTAG test access port 12-1 trace status port 12-5 development tools 12-1 ICDBDR 4-14 modes 12-6

external 12-6 internal 12-6 real-time trace 12-7 processor control 12-8 processor status 12-8 decompression controller access procedures, overview 3-19 indirect access of DCRs 3-21 offsets for DCRs 3-21 Decompression Controller Address Register. See DCP0\_CFGADDR Decompression Controller Data Register. See DCP0 CFGDATA Device Control Registers. See DCRs device-paced transfers 16-11 bus timeout error 16-11 dirty cache line, defined 4-16 divw 24-59 divw. 24-59 divwo 24-59 divwo. 24-59 divwu 24-60 divwu. 24-60 divwuo 24-60 divwuo, 24-60 DMA memory-to-memory mode transfers initiated by software 18-21 DMA operations arbitration transfer priorities 18-13 data parity 18-14 errors 18-14 interrupts 18-15 DMA0\_CR0-DMA0\_CR3 18-8, 25-55 DMA0\_CT0-DMA0\_CT3 18-11, 25-58 DMA0\_DA0-DMA0\_DA3 18-11, 25-59 DMA0\_POL 25-60 DMA0 SA0-DMA0 SA3 18-10 DMA0\_SA0-DMA0\_SA3\_25-62 DMA0\_SG0-DMA0\_SG3\_18-12 DMA0\_SG0-DMA0\_SG3 25-63 DMA0\_SGC 18-13, 25-64 DMA0\_SLP 25-65 DMA0\_SR 18-7, 25-66 DTLB (data translation lookaside buffer) accesses 6-7 miss interrupts 6-10, 10-43 summary 6-7 F EA (effective address) forming 3-27 translation to RA, illustrated 6-2 when non-cachable 4-8 EAs (effective addresses) indexing the cache array 4-4 EBC (external bus controller) DCRs access procedures, overview 3-19

EBC0 BESR0 25-69 EBC0 BESR1 25-71 EBC0\_BnAP 25-73 EBC0\_BnCR 25-75 EBC0 CFG 25-76 EBC0\_CFGADDR 25-78 EBC0 CFGADDR (Peripheral Controller Address Register) accessing 3-20 EBC0 CFGDATA 25-79 EBC0\_CFGDATA (Peripheral Controller Data Register) accessing 3-20 effective address. See EA effective addresses. See EAs eieio 24-61 storage synchronization 3-47 EMAC\_0IAHR 25-81 EMAC0\_GAHT1-EMAC0\_GAHT4 25-80 EMAC0 IAHT1-EMAC0 IAHT4 25-82 EMAC0\_TMR0 25-83 EMAC0\_TMR1 25-84 EMAC0\_TRTR 25-85 EMAC0\_VTC1 25-86 EMAC0\_VTPID 25-87 embedded controllers instruction set 3-48 endian (E) storage attribute and byte-reverse load/store instructions 3-33 controlled by SLER 6-19 and little endian 3-30 when controlled by TLB 6-6 eqv 24-62 eqv. 24-62 ESR 25-88 ESR (Exception Status Register) usage for program interrupts 10-40 ESR (Exception Syndrome Register) clearing privileged exceptions 3-42 illustrated 10-31 MCI bit, behavior of 10-33 EVPR 25-89 EVPR (Exception Vector Prefix Register) illustrated 10-31 Exception Syndrome Register. See ESR Exception Vector Prefix Register. See EVPR exceptions defined 10-22 handling, and MSR bits 3-41 privileged, clearing 3-42 registers during debug exceptions 10-45 exceptions. See also interrupts execution mode controlling by MSR 3-41 execution synchronization, defined 3-46 extended memonics bealr 24-31 extended menmonics blectrl 24-27 bnlctrl 24-28 extended mnemonicd bngla 24-24

indirect access 3-20

offsets 3-20

EBC0\_BEAR 25-68

X-5

extended mnemonics alphabetical B-9 bctr 24-27 bctrl 24-27 bdnz 24-21 bdnza 24-21 bdnzf 24-21 bdnzfa 24-21 bdnzfkr 24-31 bdnzfl 24-21 bdnzfla 24-21 bdnzflrl 24-31 bdnzl 24-21 bdnzla 24-21 bdnzlr 24-31 bdnziri 24-31 bdnzt 24-21 bdnzta 24-21 bdnzti 24-21 bdnztla 24-21 bdnztlr 24-31 bdnztlrl 24-31 bdz 24-21 bdza 24-21 bdzf 24-22 bdzfa 24-22 bdzfl 24-22 bdzfla 24-22 bdzflr 24-31 bdzfiri 24-31 bdzl 24-21 bdzla 24-21 bdzlr 24-31 bdzlrl 24-31 bdzt 24-22 bdzta 24-22 bdztl 24-22 bdztla 24-22 bdztlr 24-31 bdztlrl 24-31 beg 24-22 bega 24-22 begctr 24-27 beqctrl 24-27 begl 24-22 begiri 24-31 bf 24-22 bfa 24-22 bfctr 24-27 bfctrl 24-27 bfl 24-22 bfla 24-22 bflr 24-32 bflrl 24-32 bge 24-23 bgea 24-23 bgectr 24-27 bgectrl 24-27 bgel 24-23 bgela 24-23 bgelr 24-32

bgelri 24-32 bgt 24-23 bgta 24-23 bgtctr 24-27 bgtctrl 24-27 bati 24-23 bgtia 24-23 bgtlr 24-32 batlrl 24-32 ble 24-23 blea 24-23 blectr 24-27 blel 24-23 blela 24-23 bleir 24-32 bleirl 24-32 blr 24-30 birl 24-30 blt 24-23 blta 24-23 bltctr 24-27 bltctrl 24-27 bltl 24-23 bltla 24-23 bltir 24-32 bitiri 24-32 bne 24-24 bnea 24-24 bnectrl 24-28 bnel 24-24 bnela 24-24 bnelr 24-32 bnelrl 24-32 bng 24-24 bnga 24-24 bngctr 24-28 bngctri 24-28 bngl 24-24 bnglr 24-32 bnglrl 24-32 bnl 24-24 bnla 24-24 bnlctr 24-28 bnll 24-24 bnlia 24-24 bnllr 24-33 bnllrl 24-33 bns 24-24 bnsa 24-24 bnsctr 24-28 bnsctrl 24-28 bnsl 24-24 bnsla 24-24 bnslr 24-33 bnslrl 24-33 bnu 24-25 bnua 24-25 bnuctr 24-28 bnuctrl 24-28 bnul 24-25 bnula 24-25

bnulr 24-33 bnulrl 24-33 bsalr 24-33 bso 24-25 bsoa 24-25 bsoctr 24-28 bsoctrl 24-28 bsol 24-25 bsola 24-25 bsoirl 24-33 bt 24-25 bta 24-25 btctr 24-28 btctrl 24-28 btl 24-25 btla 24-25 btlr 24-33 btiri 24-33 bun 24-25 buna 24-25 bunctr 24-29 bunctrl 24-29 bunl 24-25 bunla 24-25 bunir 24-33 buniri 24-33 cirisiwi 24-147 clrisiwi, 24-147 clrlwi 24-147 ciriwi. 24-147 clrrwi 24-148 clrrwi. 24-148 cmplw 24-36 cmplwi 24-37 cmpw 24-34 cmpwi 24-35 crclr 24-46 crmove 24-44 crnot 24-43 crset 24-41 explained 3-53 extlwi 24-148 extlwi. 24-148 extrwi 24-148 extrwi. 24-148 for addi 24-9 for addic 24-10 for addic. 24-11, 24-115 for addis 24-12 for bc, bca, bcl, bcla 24-21 for bcctr, bcctrl 24-27 for bclr, bclrl 24-30 for cmp 24-34 for cmpi 24-35 for cmpl 24-36 for cmpli 24-37 for creav 24-41 for crnor 24-43 for cror 24-44 for crxor 24-46 for mfspr 24-113

for mtcrf 24-116 for mtspr 24-120 for nor, nor. 24-139 for or, or. 24-140 for ori 24-142 for rlwimi, rlwimi. 24-146 for rlwinm, rlwinm, 24-147 for rlwnm, rlwnm, 24-150 for subf, subf., subfo, subfo. 24-176 for subfc, subfc., subfco, subfco. 24-177 for tibre 24-185 for tw 24-191 for twi 24-194 inslwi 24-146 inslwi. 24-146 insrwi 24-146 insrwi. 24-146 li 24-9 lis 24-12 mftb 24-115 mftbu 24-115 mr 24-140 mr. 24-140 mtcr 24-116 nop 24-142 not 24-139 not. 24-139 rotlw 24-150 rotlw. 24-150 rotlwi 24-148 rotlwi, 24-148 rotrwi 24-148 rotrwi. 24-148 slwi 24-148 slwi. 24-148 srwi 24-149 srwi. 24-149 sub 24-176 sub. 24-176 subc 24-177 subc. 24-177 subco 24-177 subco. 24-177 subi 24-9 subic 24-10 subic. 24-11 subis 24-12 subo 24-176 subo. 24-176 tblrehi 24-185 tbirelo 24-185 tblwehi 24-189 tblwelo 24-189 trap 24-191 tweg 24-191 tweai 24-194 twge 24-191 twgei 24-194 twale 24-191 twgt 24-191 twati 24-194

twle 24-191 twlei 24-194 twlgei 24-194 twlgt 24-191 twigti 24-194 twile 24-192 twllei 24-194 twilt 24-192 twilti 24-194 twing 24-192 twlngi 24-194 twini 24-192 twlnli 24-195 twlt 24-192 twlti 24-195 twne 24-192 twnei 24-195 twng 24-192 twngi 24-195 twni 24-192 twnli 24-195 extended mnemonics for tlbre 24-189 external bus controller. See EBC external bus master 16-17 arbitration 16-17 interface 16-17 external interrupts programming note 10-38 register settings 10-39 extlwi 24-148 extlwi. 24-148 extrwi 24-148 extrwi. 24-148 extsb 24-63 extsb. 24-63 F features DCU 4-1 ICU 4-1 fetcher, improved performance of 4-3 FIFO 21-15 FIFO control register 21-7 **FIFO** operation interrupt mode 21-15 polled mode 21-16 FIT 11-5 FIT (fixed interval timer) interrupts, causes 10-42 interrupts, register settings 10-42

# G

fixed interval timer 11-5

fixed interval timer. See FIT

general interrupt handling registers, listed 10-27 general purpose registers. *See* GPRs GPIO0\_IR 25-90 GPIO0\_IRO 23-1 GPIO0\_ODR 25-91 GPIO0\_OR 25-92

Fixed Point Exception Register. See XER

GPIO0 TCR 25-93 GPR0-GPR31 25-94 GPRs (general purpose registers) interrupt control instructions 3-52 overview 3-6 summary 1-10 guarded (G) storage attribute controlled by SGR 6-19 preventing speculative accesses 3-37 virtual mode 6-6 L I storage attribute. See caching inhibited (I) storage attribute IAC1-IAC4 25-67, 25-95 IAC1-IAC4 12-14 icbi 24-65 data storage interrupts 6-16 function 4-9 icbt 24-66 data storage interrupts 6-16 function 4-9 iccci 24-67 function 4-9 when use not recommended 6-16 ICCR 25-96 ICCR (Instruction Cache Cachability Register) controlling the I storage attribute 6-19 controls cachability 4-4 ICDBCR (Instruction Cache Debug Control Register) programming note 4-15 ICDBDR 25-98 ICDBDR (Instruction Cache Debug Data Register) illustrated 4-14, 25-98 icread 24-68 controlled by CCR0 4-11 function 4-9 programming note 4-15 ICU (instruction cache unit) cachability control 4-4 cache line fills 4-3 coherency 4-5 features 4-1 instruction flow, illustrated 4-3 instructions 4-9 least-recently-used (LRU) policy 4-2 organization 4-2 synchronization 4-5 synonyms 4-4 IIC 22-1 IIC0\_CLKDIV 25-99 IIC0\_CNTL 25-100 IIC0\_DIRECTCNTL 25-101 IIC0\_EXTSTS 25-102 IIC0 HMADR 25-104 IIC0\_HSADR 25-105 IIC0\_INTRMSK 25-106 IIC0\_LMADR 25-107 IICO\_LSADR 25-108 IIC0\_MDBUF 25-109 IIC0 MDCNTL 25-110 IIC0\_SDBUF 25-111

IIC0\_STS 25-112 IIC0\_XFRCNT 25-113 IIC0 XTCNTLSS 25-114 imprecise interrupts 10-22 initialization code example 8-16 of processor 8-14 requirements 8-15 sequence 8-15 inslwi 24-146 inslwi, 24-146 insrwi 24-146 insrwi. 24-146 instruction add 24-6 add. 24-6 addc 24-7 addc. 24-7 addco 24-7 addco. 24-7 adde 24-8 adde. 24-8 addeo 24-8 addeo. 24-8 addi 24-9 addic 24-10 addic. 24-11 addis 24-12 addme 24-13 addme. 24-13 addmeo 24-13 addmeo. 24-13 addo 24-6 addo. 24-6 addze 24-14 addze, 24-14 addzeo 24-14 addzeo. 24-14 and 24-15 and. 24-15 andc 24-16 andc. 24-16 andi. 24-17 andis. 24-18 b 24-19 ba 24-19 bc 24-20 bca 24-20 bcctr 24-26 bcctrl 24-26 bcl 24-20 bcla 24-20 bclr 24-30 bclrl 24-30 bl 24-19 bla 24-19 cmp 24-34 cmpi 24-35 cmpl 24-36 cmpli 24-37 cntlzw 24-38

cntlzw. 24-38 crand 24-39 crandc 24-40 creav 24-41 crnand 24-42 crnor 24-43 cror 24-44 crorc 24-45 crxor 24-46 dcbf 24-49 dcbi 24-50 dcbst 24-51 dcbt 24-52 dcbz 24-54 dccci 24-56 dcread 24-57 divw 24-59 divw. 24-59 divwo 24-59 divwo. 24-59 divwu 24-60 divwu, 24-60 divwuo 24-60 divwuo. 24-60 eieio 24-61 eqv 24-62 eqv. 24-62 extsb 24-63 extsb. 24-63 icbi 24-65 icbt 24-66 iccci 24-67 icread 24-68 isync 24-70 lbz 24-71 lbzu 24-72 lbzx 24-74 lha 24-75 lhau 24-76 Ihax 24-78 lhbrx 24-79 ihz 24-80 lhzu 24-81 lhzux 24-82 lhzx 24-83 lmw 24-84 Iswi 24-85 Iswx 24-87 lwarx 24-89 lwz 24-91 lwzu 24-92 lwzux 24-93 lwzx 24-94 macchw 24-95 macchws 24-96 macchwsu 24-97 macchwu 24-98 machhw 24-99 machhwsu 24-101 machhwu 24-102 maclhw 24-103

maclhws 24-104, 24-138 maclhwu 24-106 mcrf 24-107 mcrxr 24-108 mfcr 24-109 mfdcr 24-110 mfmsr 24-111 mfspr 24-112 mtcrf 24-116 mtdcr 24-117 mtspr 24-119 mulchw 24-121 mulchwu 24-122 mulhhw 24-123 mulhhwu 24-124 mulhwu 24-126 mulhwu, 24-126 mullhw 24-127 mullhwu 24-128 mulli 24-129 mullw 24-130 mullw. 24-130 mullwo 24-130 muliwo. 24-130 nand 24-131 nand. 24-131 neg 24-132 neg. 24-132 nego 24-132 nego. 24-132 nmacchw 24-133 nmacchws 24-134 nmachhw 24-135 nmachhws 24-136 nmaclhw 24-137 nmaclhws 24-138 nor 24-139 nor. 24-139 or 24-140 or. 24-140 orc 24-141 orc. 24-141 ori 24-142 oris 24-143 rfci 24-144 rfi 24-145 rlwimi 24-146 rlwimi. 24-146 rlwinm 24-147 rlwinm. 24-147 rlwnm 24-150 rlwnm. 24-150 sc 24-151 siw 24-152 slw. 24-152 sraw 24-153 sraw. 24-153 srawi 24-154 srawi. 24-154 srw 24-155 srw. 24-155

stb 24-156 stbu 24-157 stbux 24-158 stbx 24-159 sth 24-160 sthbrx 24-161 sthu 24-162 sthux 24-163 sthx 24-164 stmw 24-165 stswi 24-166 stswx 24-167 stw 24-169 stwbrx 24-170 stwcx. 24-171 stwu 24-173 stwux 24-174 stwx 24-175 subf 24-176 subf. 24-176 subfc 24-177 subfc. 24-177 subfco 24-177 subfco. 24-177 subfe 24-178 subfe. 24-178 subfeo 24-178 subfeo. 24-178 subfic 24-179 subfme 24-180 subfme, 24-180 subfmeo 24-180 subfmeo. 24-180 subfo 24-176 subfo. 24-176 subfze 24-181 subfze. 24-181 subfzeo 24-181 subfzeo. 24-181 sync 24-182 tlbia 24-183 tlbre 24-184 tlbsx 24-186 tlbsx. 24-186 tlbsync 24-187 tlbwe 24-188 tw 24-190 twi 24-193 wrtee 24-196 wrteei 24-197 xor 24-198 xori 24-199 instruction cache array, improved fetcher performance 4-3 Instruction Cache Cachability Register. See ICCR Instruction Cache Cachability Register. See ICCR Instruction Cache Debug Data Register. See ICDBDR instruction cache synonym, defined 4-4 instruction cache unit. See ICU instruction fetching

from little endian storage 3-31

instruction fields A-41 instruction formats 24-2, A-41 diagrams A-43 instruction forms A-41, A-43 instruction queue illustrated 3-34 role in processing instructions 3-33 instruction set brief summaries by category 3-47 for embedded controllers 3-48 instruction set portability 24-1 instruction set summary cache control 3-52 CR logical 3-51 instruction storage interrupts causes 10-38 register settings 10-38 instruction timings C-3 branches and cr logicals C-3 general rules C-3 instruction cache misses C-7 loads and stores C-6 strings C-6 instruction TLB. See ITLB instructions alphabetical, including extended mnemonics A-1 arithmetic and logical 3-49, B-33 arithmetic compares 3-13 branch 3-51, B-38 branch conditional, testing CTR 3-35 byte-reverse, usefulness of 3-32 cache DAC debug events 12-20 cache control B-41 cache control, alignment of 3-27 compare 3-50 comparison B-39 condition register logical B-37 context synchronizing, defined 3-44 CR logical 3-50 extended mnemonics B-9 format diagrams A-43 formats A-41 forms A-41, A-43 ICU controlling 4-9 interrupt control 3-52, B-42 logical compares 3-13 opcodes A-33 privileged B-7 privileged, listed 3-42 processor management 3-53, B-42 for reading DCRs 3-43 for reading privileged SPRs 3-42 rotate and shift B-40 specific to PowerPC Embedded Controllers B-1, B-5 storage reference B-29 storage reference, alignment of 3-27 storage reference, in core 3-48 TLB management 3-53 interrupt controller interface 1-9 interrupt enable register

description 21-5 interrupt identification register description 21-6 Interrupts 22-21 interrupts alignment 3-28 register settings 10-40 summary 10-39 asynchronous, defined 10-22 behavior 10-22 critical defined 10-26 processing 10-27 critical input 10-34 data machine check 10-36 data storage 6-9, 10-36 register settings 10-37 debug, register settings 10-44 defined 10-22 DTLB miss 6-10 DTLB, register settings 10-43 external programming note 10-38 register settings 10-39 fetching past, speculatively 3-39 FIT, causes 10-42 FIT, register settings 10-42 handling as critical 10-23 handling priorities 10-24 handling priorities, illustrated 10-25 imprecise, defined 10-22 instruction storage 6-10 causes 10-38 register settings 10-38 ITLB miss 6-10 ITLB miss, registers 10-44 machine check, causes of 10-35 machine check, defined 10-23 machine check-instruction handling 10-35 register settings 10-36 synchronism 10-24 noncritical defined 10-26 processing 10-26 PIT, register settings 10-41 precise handling 10-23 precise, defined 10-22 program causes 10-40 ESR usage 10-40 register settings 10-41 register settings during critical 10-35 synchronous, defined 10-22 system call, register settings 10-41 TLB miss, preventing 6-10 TLB-related 6-9 vector offsets, illustrated 10-27 WDT, causes 10-43 WDT, register settings 10-43 isync 24-70

```
and ITLB 6-8
   context synchronization, example 3-45
ITLB (instruction translation lookaside buffer)
   accesses 6-6
  consistency 6-8
  defined 6-6
   miss interrupts 6-10, 10-44
   programming note 6-9
L
lbz 24-71
lbzu 24-72
lbzx 24-74
least-recently-used policy. See LRU
lha 24-75
lhau 24-76
lhax 24-78
lhbrx 24-79
lhz 24-80
lhzu 24-81
lhzux 24-82
lhzx 24-83
li 24-9
line control register
  description 21-8
line status register 21-11
Link Register. See LR
lis 24-12
little endian
  alignment 3-27
  byte ordering supported 3-30
  defined 3-28
  mapping 3-30
  storage attributes 3-30
  storage regions
     accessing data from 3-31
     byte-reverse instructions 3-32- 3-33
     fetching instructions from 3-31
lmw 24-84
load strategies, controlled by DCU 4-7
logical compares 3-13
logical instructions
  CR 3-50
  overview 3-49
LR 25-116
LR (Link Register)
  branch instructions 3-51
  function 3-8
LRU (least-recently-used) policy
  DCU 4-6
  ICU 4-2
lswi 24-85
lswx 24-87
lwarx 24-89
lwz 24-91
lwzu 24-92
lwzux 24-93
lwzx 24-94
М
macchw 24-95
macchws 24-96
```

macchwsu 24-97 macchwu 24-98 machhw 24-99 machhwsu 24-101 machhwu 24-102 machine check interrupts causes 10-35 defined 10-23 machine check-instruction interrupts handling 10-35 register settings 10-36 synchronism 10-24 Machine State Register. See MSR maclhw 24-103 maclhws 24-104, 24-138 maclhwu 24-106 MAL0\_CFG 25-117 MAL0\_ESR 25-119 MAL0\_IER 25-121 MAL0\_RCBS0 25-122 MALO RXCARR 25-123 MALO\_RXCASR 25-124 MALO\_RXCTPOR 25-125 MAL0\_RXDEIR 25-126 MAL0\_RXEOBISR 25-127 MAL0\_TXCASR 25-129 MALO TXCTPOR 25-130 MAL0\_TXCTP1R 25-130 MAL0\_TXDEIR 25-131 MAL0\_TXEOBISR 25-132 mapping big endian 3-29 little endian 3-30 structure, examples 3-29 mcrf 24-107 mcrxr 24-108 Memory Controller Address Register. See SDRAM0\_CFGADDR Memory Controller Data Register. See SDRAM0\_CFGDATA memory interface bus attachment alternative 16-3 external bus master 16-17 SRAM burst mode 16-8 bus timeout error 16-11 device-paced transfers 16-11 timing 15-1, 16-2 memory map address space usage 3-2 PCI configuration registers 25-13 memory mapping of hardware 3-40 memory models, non-supported 4-7, 6-5 memory organization 3-1 memory-mapped input/output registers. See MMIO registers mfcr 24-109 mfdcr 24-110 mfmsr 24-111

mfspr 24-112 mftb 24-115 mftbu 24-115 misalignments, defined 3-27 MMIO (memory-mapped input/output) registers directly accessed 3-22 indirectly accessed 3-25 MMU (memory management unit) accesses, interrupts from 6-9 address translation 6-1 data storage interrupts 6-9 DTLB miss interrupts 6-10 execute permissions 6-13 general access protection 6-12 instruction storage interrupts 6-10 ITLB miss interrupts 6-10 MSR and access protection 6-12 overview 1-6 recording page references and changes 6-11 TLB management 6-10 zone protection 6-13 mnemonics, extended. See extended mnemonics modes execution 3-41 real, storage attribute control 6-17 mr 24-140 mr. 24-140 MSR 3-15, 25-133 MSR (Machine State Register) bits and exception handling 3-41 contents after resets 8-3 controlling execution mode 3-41 DR bit 6-1 illustrated 10-28 interrupt control instructions 3-52 IR bit 6-1 programming note 10-28 summarized 1-10 mtcr 24-116 mtcrf 24-116 mtdcr 24-117 mtmsr execution synchronization 3-46 mtspr 24-119 mulchw 24-121 mulchwu 24-122 mulhhw 24-123 mulhhwu 24-124 mulhwu 24-126 mulhwu. 24-126 mullhw 24-127 mulihwu 24-128 mulli 24-129 mullw 24-130 mullw. 24-130 muliwo 24-130 mullwo. 24-130 Ν nand 24-131 nand. 24-131

neg. 24-132 nego 24-132 nego. 24-132 nmacchw 24-133 nmacchws 24-134 nmachhw 24-135 nmachhws 24-136 nmacihw 24-137 nmaclhws 24-138 noncritical interrupts defined 10-26 processing 10-26 nop 24-142 nor 24-139 nor. 24-139 not 24-139 not. 24-139 notation xlviii, 24-2, A-41 notational conventions xlviii 0 OCM0\_DSARC 25-135 OCM0\_DSCNTL 25-136 OCM0\_ISARC 25-137 OCM0\_ISCNTL 25-138 on-chip peripheral bus 2-11 features 2-11 OPB 2-11 **OPB** arbiter registers 2-12 OPBA0\_CR 2-12, 25-139 opcodes A-33 optimization coding guidelines C-1 alignment C-2 boolean variables C-1 branch prediction C-2 dependency upon CR C-2 floating point emulation C-1 or 24-140 or. 24-140 orc 24-141 orc. 24-141 ori 24-142 oris 24-143 overlapped PLB transfers 2-4 page identification fields, UTLB 6-3 parallel-to-serial conversion 21-1 PCI configuration registers 25-13 PCI configuration registers

configuration registers 25-13 PCI configuration registers accessing 3-25 offsets 3-25, 17-20, 25-13 PCIC0\_BAR0 25-141 PCIC0\_BRDGOPT1 25-143 PCIC0\_BRDGOPT2 25-144 PCIC0\_CACHELS 25-145 PCIC0\_CAP 25-146 PCIC0\_CAPID 25-147

neg 24-132

PCIC0\_CFGADDR 25-148 PCIC0\_CFGDATA 25-149 PCIC0 CLS 25-150 PCIC0\_CMD 25-151 PCIC0 DATA 25-153 PCIC0 DEVID 25-154 PCIC0\_ERREN 25-155 PCIC0\_ERRSTS 25-156 PCIC0\_HDTYPE 25-157 PCIC0\_ICS 25-158 PCICO INTLN 25-159 PCIC0\_INTPN 25-160 PCIC0\_LATTIM 25-161 PCIC0\_MAXLTNCY 25-162 PCIC0 MINGNT 25-163 PCIC0\_NEXTIPTR 25-164 PCIC0 PLBBEAR 25-165 PCIC0\_PLBBESR0 25-166 PCIC0\_PMC 25-170 PCIC0\_PMCSR 25-171 PCIC0 PMSCRR 25-173 PCIC0\_PTM1BAR 25-174 PCIC0\_PTM2BAR 25-175 PCIC0 REVID 25-176 PCIC0\_SBSYSID 25-177 PCIC0\_SBSYSVID 25-178 PCIC0 STATUS 25-179 PCIC0\_VENDID 25-181 PCILO PMMOLA 25-182 PCILO PMM0MA 25-183 PCIL0\_PMM0PCIHA 25-184 PCIL0\_PMM0PCILA 25-185 PCIL0 PMM1LA 25-186 PCIL0\_PMM1MA 25-187 PCIL0\_PMM1PCIHA 25-188 PCIL0 PMM1PCILA 25-189 PCIL0\_PMM2LA 25-190 PCIL0\_PMM2MA 25-191 PCIL0 PMM2PCIHA 25-192 PCIL0\_PMM2PCILA 25-193 PCIL0 PTM1LA 25-194 PCIL0 PTM1MS 25-195 PCIL0\_PTM2LA 25-196 PCIL0\_PTM2MS 25-197 PCIPCIC0 PLBBESR1 25-168 performance DCU improve with simultaneous caching 4-18 limited by sequential caching 4-18 overview 4-16 improve through byte-writeability 4-6 lower from cache-inhibited regions 4-4 Peripheral Controller Address Register. See EBC0\_CFGADDR Peripheral Controller Data Register. See EBC0\_CFGDATA physical address map 3-2 PID 25-198 PID (process ID)

illustrated 6-12 PIT 11-4, 25-199 PIT (programmable interval timer) interrupts, register settings 10-41 PLB 2-1 PLB arbiter registers 2-5 PLB to OPB bridge registers 2-8 PLB0\_ACR 2-5, 25-200 PLB0\_BEAR 2-5, 25-201 PLB0\_BESR 2-6, 25-202 POB0\_BEAR 2-8, 25-204 POB0\_BESR0 25-205 POB0 BESR1 25-207 portability, instruction set 24-1 PowerPC architecture 1-4 precise interrupts 10-22 pre-fetch branches to CTR 3-38 branches to LR 3-38 buffers 3-33 past interrupts 3-39 primary opcodes A-33 priority signal DCU 4-17 privileged mode defined 3-41 instructions, listed 3-42 registers 3-5 privileged programming model 3-1 privileged SPRs instructions for reading 3-42 problem state. See user mode process ID. See PID processor management instructions 3-53 processor local bus 2-1 overlapped transfers 2-4 transfer protocol 2-3 Processor Version Register. See PVR program interrupts causes 10-40 ESR usage 10-40 register settings 10-41 programmable interval timer 11-4 programming model features 3-1 programming models privileged 3-1 user 3-1 programming note data storage interrupts 10-37 EA access in DCU 4-8 external or timer interrupts 10-38 instruction pipeline 4-15 MSR affected by instructions 10-28 non-supported memory models 4-7 reserved fields 3-3 RPN field 6-4 synchronizing the ITLB 6-9

pseudocode 24-2 PVR 25-208 PVR (Processor Version Register) illustrated 3-12 R real mode storage attribute control 6-17 register description 21-4 register set summary 1-10- 1-11 registers categories 3-3, 25-1 CCR0 25-15 CPC0\_CR1 25-20 CPC0\_ER 25-21 CPC0\_FR 25-22 CPC0\_JTAGID 25-23 CPC0\_PLLMR 25-24 CPC0\_PSR 25-26 CPC0\_SR 25-28 CR 25-1, 25-29 CTR 15-6, 15-14, 15-15, 15-16, 15-17, 15-20, 25-30, 25-209, 25-210, 25-218, 25-219, 25-220, 25-221 DAC1 12-14 DAC1-DAC2 12-14, 14-7, 25-31, 25-48 DBCR 12-9 DBCR0 25-32, 25-34 DBSR 12-12, 25-36 DCCR 25-38 DCP0\_ADDR0-DCP0\_ADDR1 25-40 DCP0\_ADDR0-DCP0\_ADDR3 14-5, 25-40 DCP0\_CFG 14-6, 25-41 DCP0\_CFGADDR 25-42 DCP0\_CFGDATA 25-43 DCP0\_ESR 14-8, 25-44 DCP0\_ID 14-6, 25-46 DCP0\_ITOR0-DCP0\_ITOR3 14-4, 25-47 DCP0\_MEMBEAR 14-7, 25-48 DCP0\_PLBBEAR 14-7, 25-49 DCP0\_RAM0-DCP0\_RAM3FF 25-50 DCP0\_VER 14-7, 25-51 DCR numbering 25-4 **DCRs** indirectly accessed 3-19 summarized 1-11 uses for 3-16 DCWR 25-52 DEAR 25-54 descriptions of commonly used 3-3 DMA0\_CR0-DMA0\_CR3 18-8, 25-55 DMA0\_CT0-DMA0\_CT3 18-11, 25-58 DMA0\_DA0-DMA0\_DA3 18-11, 25-59 DMA0\_POL 25-60 DMA0\_SA0-DMA0\_SA3 18-10 DMA0\_SA0-DMA0\_SA3 25-62 DMA0 SG0-DMA0 SG3 18-12 DMA0\_SG0-DMA0\_SG3 25-63 DMA0\_SGC 18-13, 25-64 DMA0\_SLP 25-65 DMA0\_SR 18-7, 25-66 during debug exceptions 10-45

EBC0\_\_BEAR 25-68 EBC0\_BESR0 25-69 EBC0\_BESR1 25-71 EBC0\_BnAP 25-73 EBC0\_BnCR 25-75 EBC0\_CFG 25-76 EBC0\_CFGADDR 25-78 EBC0\_CFGDATA 25-79 EMAC0\_GAHT1-EMAC0\_GAHT4 25-80 EMAC0\_IAHR 25-81 EMAC0\_IAHT1-EMAC0\_IAHT4 25-82 EMAC0\_TMR0 25-83 EMAC0\_TMR1 25-84 EMACO\_TRTR 25-85 EMAC0\_VTCI 25-86 EMAC0\_VTPID 25-87 ESR 25-88 EVPR 25-89 GPIO0\_IR 25-90 GPIO0\_ODR 25-91 GPIO0\_OR 25-92 GPIO0\_TCR 25-93 GPR 25-1 GPR0-GPR31 25-94 GPRs overview 3-6 summary 1-10 IAC1-IAC4 25-67, 25-95 IAC1-IAC4 12-14 ICCR 25-96 ICDBDR 25-98 IIC0\_CLKDIV 25-99 IIC0\_CNTL 25-100 IIC0\_DIRECTCNTL 25-101 IIC0\_EXTSTS 25-102 IIC0\_HMADR 25-104 IIC0\_HSADR 25-105 IIC0\_INTRMSK 25-106 IIC0\_LMADR 25-107 IICO\_LSADR 25-108 IIC0\_MDBUF 25-109 IIC0\_MDCNTL 25-110 IIC0\_SDBUF 25-111 IIC0\_STS 25-112 IIC0\_XFRCNT 25-113 IIC0\_XTCNTLSS 25-114 interrupt handling 10-27 LR 25-116 MAL0\_CFG 25-117 MAL0\_ESR 25-119 MAL0\_IER 25-121 MAL0\_RCBS0 25-122 MAL0\_RXCARR 25-123 MAL0\_RXCASR 25-124 MALO\_RXCTPOR 25-125 MAL0\_RXDEIR 25-126 MALO RXEOBISR 25-127 MAL0\_TXCASR 25-129 MAL0\_TXCTPOR 25-130 MAL0\_TXCTP1R 25-130 MAL0\_TXDEIR 25-131

MAL0\_TXEOBISR 25-132 MMIO registers directly accessed 3-22 indirectly accessed 3-25 MSR 3-15, 25-1, 25-133 OCM0\_DSARC 25-135 OCM0\_DSCNTL 25-136 OCM0\_ISARC 25-137 OCM0\_ISCNTL 25-138 OPB arbiter 2-12 OPBA0\_CR 2-12, 25-139 PCI configuration 25-13 PCIC0\_BAR0 25-141 PCIC0\_BIST 25-142 PCIC0\_BRDGOPT1 25-143 PCIC0\_BRDGOPT2 25-144 PCIC0\_CACHELS 25-145 PCIC0\_CAP 25-146 PCIC0\_CAPID 25-147 PCIC0\_CFGADDR 25-148 PCIC0\_CFGDATA 25-149 PCIC0\_CLS 25-150 PCIC0\_CMD 25-151 PCIC0\_DATA 25-153 PCIC0\_DEVID 25-154 PCIC0\_ERREN 25-155 PCICO ERRSTS 25-156 PCIC0\_HDTYPE 25-157 PCIC0 ICS 25-158 PCIC0\_INTLN 25-159 PCIC0\_INTPN 25-160 PCIC0\_LATTIM 25-161 PCIC0\_MAXLTNCY 25-162 PCIC0\_MINGNT 25-163 PCIC0\_NEXTIPTR 25-164 PCIC0\_PLBBEAR 25-165 PCIC0\_PLBBESR0 25-166 PCIC0\_PMC 25-170 PCICO PMCSR 25-171 PCIC0\_PMSCRR 25-173 PCIC0 PTM1BAR 25-174 PCIC0\_PTM2BAR 25-175 PCIC0\_REVID 25-176 PCIC0\_SBSYSID 25-177 PCIC0 SBSYSVID 25-178 PCIC0\_STATUS 25-179 PCIC0\_VENDID 25-181 PCILO\_PMM0LA 25-182 PCILO\_PMM0MA 25-183 PCIL0\_PMM0PCIHA 25-184 PCILO PMM0PCILA 25-185 PCILO\_PMM1LA 25-186 PCIL0 PMM1MA 25-187 PCILO PMM1PCIHA 25-188 PCIL0\_PMM1PCILA 25-189 PCILO\_PMM2LA 25-190 PCILO PMM2MA 25-191 PCIL0\_PMM2PCIHA 25-192 PCIL0\_PMM2PCILA 25-193 PCIL0\_PTM1LA 25-194 PCIL0\_PTM1MS 25-195

PCIL0\_PTM2LA 25-196 PCIL0\_PTM2MS 25-197 PCIPCICO PLBBESR1 25-168 PID 25-198 PIT 11-4, 25-199 PLB arbiter 2-5 PLB to OPB bridge 2-8 PLB0\_ACR 2-5, 25-200 PLB0\_BEAR 2-5, 25-201 PLB0\_BESR 2-6, 25-202 POB0\_BEAR 2-8, 25-204 POB0\_BESR0 25-205 POB0\_BESR1 25-207 PVR 25-208 reserved 25-1 reserved fields 3-3, 25-1 SDRAM0 B0CR-SDRAM0 B3CR 25-209 SDRAM0 BEAR 25-210 SDRAM0\_BESR0 25-211 SDRAM0\_BESR1 25-213 SDRAM0\_CFG\_25-214 SDRAM0\_CFGADDR 25-216 SDRAM0 CFGDATA 25-217 SDRAM0\_ECCCFG 25-218 SDRAM0\_ECCESR 25-219 SDRAM0\_PMIT 25-220 SDRAM0 RTR 25-221 SDRAM0\_TR 25-222 SGR 25-224 SLER 25-226 SPR numbering 25-1 SPRG0-SPRG4 3-11 SPRG0-SPRG7 25-228 SPRs overview 3-6 summary 1-10 SRR0 25-229 SRR1 25-230 SRR2 25-231 SRR3 25-232 SU0R 25-233 summary of sets 1-10- 1-11 supervisor, illustrated 3-5 TBL 25-235 TBU 25-236 TCR 11-5, 11-6, 11-9, 25-237 TSR 11-6, 11-8, 25-238 UARTx DLL 25-239 UARTx\_DLM 25-240 UARTx\_FCR 25-241 UARTX IER 25-242 UARTx\_IIR 25-243 UARTX LCR 25-244 UARTx\_LSR 25-245 UARTx\_MCR 25-247 UARTX MSR 25-248 UARTx\_RBR 25-249 UARTx\_SCR 25-250 UARTx\_THR 25-251 UIC0\_CR 25-252 UIC0\_ER 25-255

UIC0 MSR 25-258 UIC0\_PR 25-261 UIC0 SR 25-264 UIC0 TR 25-267 UIC0\_VCR 25-270 UIC0\_VR 25-271 user, illustrated 3-5 USPRG0 3-11, 25-272 XER 25-273 ZPR 25-274 reservation bit 24-89, 24-171 reserved fields 25-1 programming note 3-3 reserved registers 25-1 resets effects on MSR 8-3 effects on SPRs 8-4 processor initialization 8-14 processor state after 8-2 rfci 24-144 effect on MSR reserved fields 10-28 rfi 24-145 effect on MSR reserved fields 10-28 rlwimi 24-146 rlwimi, 24-146 rlwinm 24-147 rlwinm. 24-147 rlwnm 24-150 rlwnm. 24-150 rotlw 24-150 rotlw. 24-150 rotlwi 24-148 rotlwi. 24-148 rotrwi 24-148 rotrwi. 24-148 rxtended mnemonics bnectr 24-28 S Save/Restore Registers 0-1. See SRR0-1

sc 24-151

DCRs

Register)

SDRAM controller

scratchpad register 21-13

offsets 3-19

SDRAM0\_BEAR 25-210

SDRAM0\_BESR0 25-211

SDRAM0\_BESR1 25-213

SDRAM0 CFGADDR 25-216

SDRAM0\_CFGDATA 25-217

SDRAM0\_ECCCFG 25-218

SDRAM0\_ECCESR 25-219

SDRAM0\_CFG 25-214

accessing 3-19

accessing 3-19

SDRAM0\_PMIT 25-220

indirect access 3-19

access procedures, overview 3-19

SDRAM0\_CFGADDR (Memory Controller Address

SDRAM0\_B0CR-SDRAM0\_B3CR 25-209

SDRAM0\_TR 25-222 secondary opcodes A-33 serial-interface characteristic 21-2 serial-to-parallel conversion 21-1 SGR 25-224 SGR (Storage Guarded Register) controlling speculative accesses 3-38 controlling the guarded (G) storage attribute 6-19 shadow TLB. See DTLB SLER 25-226 SLER (Storage Little Endian Register) controlling the endian (E) storage attribute 6-19 slw 24-152 slw. 24-152 slwi 24-148 slwi. 24-148 Special Purpose Register General 0-7. See SPRG0-7 special purpose registers. See SPRs speculative accesses to CTR or LR 3-38 defined 3-37 down predicted path 3-38 fetching past interrupts 3-39 fetching past tw or twi 3-39 fetching past unconditional branches 3-40 preventing inappropriate 3-37- 3-41 SPRG0-7 (Special Purpose Register General 0-7) temporary storage to 3-11 SPRG0-SPRG4 3-11 SPRG0-SPRG7 25-228 SPRs (special purpose registers) contents after resets 8-4 listed, with page references 3-7 overview 3-6 privileged and non-privileged 3-6 privileged, instructions for reading 3-42 summary 1-10 SRAM timing 15-1, 16-2 sraw 24-153 sraw. 24-153 srawi 24-154 srawi. 24-154 SRR0 25-229 SRR0-1 (Save/Restore Registers 0-1) illustrated 10-29 SRR1 25-230 SRR2 25-231 SRR3 25-232 srw 24-155 srw. 24-155 srwi 24-149 srwi. 24-149 stb 24-156 stbu 24-157 stbux 24-158 stbx 24-159 sth 24-160 sthbrx 24-161

SDRAM0\_RTR 25-221

SDRAM0\_CFGDATA (Memory Controller Data Register)

sthu 24-162

sthux 24-163 sthx 24-164 stmw 24-165 storage attribute control registers DCCR 6-19 DCWR 6-18 ICCR 6-19 SGR 6-19 SLER 6-19 SU0R 6-19 storage attributes caching inhibited (I) real mode 6-19 virtual mode 6-5 endian (E) and little endian 3-30 real mode 6-19 when controlled by TLB 6-6 guarded (G) controlling speculative accesses 3-37 real mode 6-19 virtual mode 6-6 memory coherent (M) not supported 6-6 overview 3-3 real mode 6-17 TLB control of 6-5 user-defined (U0) real mode 6-19 virtual mode 6-5 write-through (W) real mode 6-18 virtual mode 6-5 Storage Guarded Register. See SGR Storage Guarded Register. See SGR Storage Little Endian Register. See SLER storage reference instructions 3-48 storage regions big endian alignment 3-27 byte-reverse instructions 3-32- 3-33 little endian accessing data from 3-31 alignment 3-27 byte reversal 3-31 byte-reverse instructions 3-32- 3-33 data alignment 3-32 fetching instructions from 3-31 storage synchronization 3-46 Storage User-Defined 0 Register. See SU0R string instructions access protection 6-16 structure mapping examples 3-29 stswi 24-166 stswx 24-167 stw 24-169 stwbrx 24-170 stwcx. 24-171 stwu 24-173 stwux 24-174

stwx 24-175 SU0R 25-233 SUOR (Storage User-Defined 0 Register) controlling the user-defined (U0) storage attribute 6-19 sub 24-176 sub. 24-176 subc 24-177 subc. 24-177 subco 24-177 subco. 24-177 subf 24-176 subf. 24-176 subfc 24-177 subfc. 24-177 subfco 24-177 subfco. 24-177 subfe 24-178 subfe. 24-178 subfeo 24-178 subfeo. 24-178 subfic 24-179 subfme 24-180 subfme. 24-180 subfmeo 24-180 subfmeo. 24-180 subfo 24-176 subfo. 24-176 subfze 24-181 subfze, 24-181 subfzeo 24-181 subfzeo. 24-181 subi 24-9 subic 24-10 subic. 24-11 subis 24-12 subo 24-176 subo. 24-176 supervisor state. See privileged mode sync 24-182 storage synchronization 3-46 synchronization context 3-44 execution, defined 3-46 ICU 4-5 references to PowerPC Architecture 3-43 storage 3-46 synchronous interrupts 10-22 system call interrupts register settings 10-41 т TBL 25-235 tblrehi 24-185 tbirelo 24-185 tblwehi 24-189 tblwelo 24-189 TBU 25-236 TCR 11-9, 25-237 TID (translation ID) and MMU access protection

time base 11-2

implementation 3-15 writing 3-15 timer interrupts programming note 10-38 timers FIT 11-5 fixed interval timer 11-5 PIT 11-4 programmable interval timer 11-4 TCR 11-9 timer control register 11-9 timer status register 11-8 TSR 11-8 watchdog 11-6 timings instruction C-3 branches and cr logicals C-3 general rules C-3 instruction cache misses C-7 loads and stores C-6 strings C-6 TLB (translation lookaside buffer) 6-2 access protection 6-12, 6-15 and cacheability control 4-8 execute permissions 6-13 interrupts 6-9 invalidate instruction 6-11 management instructions 3-53 preventing miss interrupts 6-10 read/write instructions 6-11 search instructions 6-11 sync instruction 6-11 zone protection 6-13 See also ITLB;UTLB;DTLB tlbia 24-183 and TLB management 6-11 tlbre 24-184 and TLB management 6-11 tlbsx 24-186 and TLB management 6-11 tlbsx. 24-186 and TLB management 6-11 tlbsync 24-187 and TLB management 6-11 tlbwe 24-188 and TLB management 6-11 transfer protocol processor local bus 2-3 translation ID. See TID translation lookaside buffer. See TLB translation, address, See address translation trap 24-191 TSR 11-8, 25-238 tw 24-190 fetching past 3-39 tweq 24-191 twegi 24-194 twge 24-191 twgei 24-194 twgle 24-191 twgt 24-191

twgti 24-194 twi 24-193 fetching past 3-39 twle 24-191 twlei 24-194 twlaei 24-194 twigt 24-191 twlgti 24-194 twlle 24-192 twllei 24-194 twllt 24-192 twllti 24-194 twing 24-192 twlngi 24-194 twini 24-192 twlnli 24-195 twit 24-192 twiti 24-195 twne 24-192 twnei 24-195 twng 24-192 twngi 24-195 twnl 24-192 twnli 24-195 U UART Reset and Sleep mode 21-16 UARTx DLL 25-239 UARTx DLM 25-240 UARTx\_FCR 25-241 UARTx\_IER 25-242 UARTx\_IIR 25-243 UARTx\_LCR 25-244 UARTx\_LSR 25-245 UARTx\_MCR 25-247 UARTx\_MSR 25-248 UARTx\_RBR 25-249 UARTx\_SCR 25-250 UARTx\_THR 25-251 UIC0\_CR 25-252 UIC0\_ER 25-255 UIC0\_MSR 25-258 UIC0\_PR 25-261 UIC0\_SR 25-264 UIC0\_TR 25-267 UIC0\_VCR 25-270 UIC0\_VR 25-271 unconditional branches AA field 3-34 speculative accesses 3-40 unified TLB. See UTLB user mode defined 3-41 registers 3-5 user programming model 3-1 user-defined (U0) storage attribute controlled by SUOR 6-19 USPRG0 3-11, 25-272 UTLB (unified translation lookaside buffer) access control fields 6-5 entry format, illustrated 6-3 EPN field 6-3

EX field 6-5 field categories 6-3 functional overview 6-2 page identification fields 6-3 RPN field 6-4 SIZE field 6-4 TID field 6-4 TID field 6-4 V field 6-4 WR field 6-5 ZSEL field 6-5

## ۷

virtual mode and TLB control of storage attributes 6-5

#### W

watchdog timer 11-6 WDT (watchdog timer) interrupts, causes 10-43 interrupts, register settings 10-43 write strategies controlled by DCWR 4-7 used by DCU 4-7 write-through (W) storage attribute controlled by DCWR 6-18 when controlled by TLB 6-5 wrtee 24-196 wrteei 24-197

### х

XER 25-273 XER (Fixed Point Exception Register) illustrated 3-8 xor 24-198 xori 24-199

# z

zone fault 10-37 Zone Protection Register. *See* ZPR zone, defined 6-13 ZPR 25-274 ZPR (Zone Protection Register) illustrated 6-13

.



© International Business Machines Corporation 1996, 2000 Printed in the United States of America 6/19/00 All Rights Reserved

The information contained in this document is subject to change without notice. The products described in this document are NOT intended for use in implantation or other life support applications where malfunction may result in injury or death to persons. The information contained in this document does not affect or change IBM's product specifications or warranties. Nothing in this document shall operate as an express or implied license or indemnity under the intellectual property rights of IBM or third parties. All information contained in this document was obtained in specific environments, and is presented as illustration. The results obtained in other operating environments may vary.

While the information contained herein is believed to be accurate, such information is preliminary, and should not be relied upon for accuracy or completeness, and no representations or warranties of accuracy or completeness are made.

THE INFORMATION CONTAINED IN THIS DOCUMENT IS PROVIDED ON AN "AS IS" BASIS. In no event will IBM be liable for any damages arising directly or indirectly from any use of the information contained in this document.

IBM Microelectronics Division 1580 Route 52, Bldg. 504 Hopewell Junction, NY 12533-6531

The IBM home page can be found at www.ibm.com

The IBM Microelectronics Division home page can be found at www.chips.ibm.com

Address technical queries about this product to ppcsupp@us.ibm.com



© International Business Machines Corporation 2000 Printed in the United States of America June 2000 All Rights Reserved

IBM and PowerPC are trademarks of International Business Machines Corporation in the United States and/or other countries.

While the information contained herein is believed to be accurate, such information is preliminary, and should not be relied upon for accuracy or completeness, and no representations or warranties of accuracy or completeness are made.

All information contained in this document is subject to change without notice. The products described in this document are NOT intended for use in implantation or other life support applications where malfunction may result in injury or death to persons. The information contained in this document does not affect or change IBM's product specifications or warranties. Nothing in this document shall operate as an express or implied license or indemnity under the intellectual property rights of IBM or third parties. All information contained in this document was obtained in specific environments, and is presented as illustration. The results obtained in other operating environments may vary.

THE INFORMATION CONTAINED IN THIS DOCUMENT IS PROVIDED ON AN "AS IS" BASIS. In no event will IBM be liable for any damages arising directly or indirectly from any use of the information contained in this document.

IBM Microelectronics Division 1580 Route 52, Bldg. 504 Hopewell Junction, NY 12533-6531

The IBM home page can be found at  $_{\ensuremath{\scriptscriptstyle >}}$  www.ibm.com

The IBM Microelectronics Division home page can be found at www.chips.ibm.com





-

-

55

-